ASP.Net Core Razor 部署AdminLTE框架

1、AdminLTE

一个基于 bootstrap 的轻量级后台模板

640?wx_fmt=jpeg

2、AdminLTE 文档

在线中文Demo:http://adminlte.la998.com/

在线中文文档:http://adminlte.la998.com/documentation/index.html

Github:https://github.com/almasaeed2010/AdminLTE/releases

3、AdminLTE 布局

AdminLTE依赖于两个主要框架:JQ和Bootstrap,其他插件可以按需增加。

从文档可以知道,使用AdminLTE主要有四个部分:

  • 包装.wrapper。包裹整个网站的div。

  • 主标题.main-header。包含徽标和导航栏。

  • 边栏.sidebar-wrapper。包含用户面板和侧边栏菜单。

  • 内容.content-wrapper。包含页眉和内容。

在文档中,可以找到下载地址,本文示例是使用最新的版本V2.4.5。

4、Asp.Net Core Razor

640?wx_fmt=jpeg

新建项目Asp.net Core Web应用程序,默认就是Razor Pages,然后添加相应的模块,

如图:本文使用的SDK版本为:dotNet Core 2.1。

640?wx_fmt=jpeg

5、First

在Asp.Net Core项目中,引用AdminLTE,在wwwroot仅添加如图三个文件夹即可:

640?wx_fmt=jpeg

  • bower_components  基本组件。

  • dist  adminlte的主要文件。

  • plugins 其他插件。

6、Second

在_Layout.cshtml文件中添加引入相关文件:

640?wx_fmt=png


在body中,添加js:

640?wx_fmt=png


sidebarskins.js是个人汉化的侧边栏皮肤,框架包里不存在

7、Third

开始使用AdminLTE

640?wx_fmt=jpeg

最后就可以运行项目来预览一下效果了:

640?wx_fmt=gif

移动端的效果:

640?wx_fmt=gif

需要注意的是,点击这个小图标640?wx_fmt=jpeg可以实现左侧边栏收缩展开的功能,当只有侧边栏可以正常收缩展开但Logo无动于衷的时候,

你可能是少了【sidebar-mini】样式和【logo-mini】logo小图的引用

640?wx_fmt=jpeg

640?wx_fmt=jpeg

8、添加一个登陆

登录界面写得比较简约,在Pages文件夹中,添加一个Razor界面

640?wx_fmt=png

在Startup中引入Authentication身份验证:

640?wx_fmt=png


Configure方法内调用

在Login.cshtml.cs中增加一个OnPostAsync的方法:

640?wx_fmt=png


userService和CookieService都是在业务层定义的,gayhub会在文章末尾。

在.Net Core Razor中,xx.cshtml.cs中默认触发的是Get和Post方法,

  • OnGet

  • OnPost

  • OnGetAsync

  • OnPostAsync

如果是需要自定义的,举个栗子,定义为:OnPostLoginAsync,然后在Form表单提交的【按钮】增加asp-page-handler="Login",

详细的推荐大家阅读这篇文章:ASP.NET Core - Razor页面之Handlers处理方法。

接着,然后再Index和需要身份验证的地方都加上Authorize特性即可:

640?wx_fmt=png


9、踩坑

一、Ajax Post请求, 400 Bad Request

   

640?wx_fmt=png


640?wx_fmt=jpeg

折腾许久,原因是Razor被设计为可以自动防止跨站请求伪造(CSRF / XSRF)攻击。你不必编写任何其他代码。Razor页面中自动包含防伪令牌生成和验证。

这里请求失败,是因为POST没有提交AntiForgeryToken。

解决方法:

1.增加"XSRF-TOKEN"标识到框架中

//增加了"XSRF-TOKEN"标识,值为表单自动生成的防伪标记
services.AddAntiforgery(o => o.HeaderName = "XSRF-TOKEN");

2.页面*.cshtml头部加上 

3.ajax引入

  

640?wx_fmt=png


然后既可以正常访问Handler

640?wx_fmt=jpeg

二、DataTables参数实例加说明

640?wx_fmt=png

640?wx_fmt=png


10、Banana

Demo中会使用到这两个个人封装的组件:

640?wx_fmt=jpeg

Banana.Uow是基于Dapper封装的工作单元和仓储;

Banana.Utility是常用的工具类,有Redis,加解密,拼音等等;

原文地址:https://www.cnblogs.com/zyg316/p/10953831.html

.NET社区新闻,深度好文,欢迎访问公众号文章汇总 http://www.csharpkit.com 
640?wx_fmt=jpeg

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/315698.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

CF1178H Stock Exchange

CF1178H Stock Exchange 题目描述 简要题意:给定2n2n2n个一次函数yaixbi(a,b>0)ya_ixb_i(a,b>0)yai​xbi​(a,b>0),刚开始你有前nnn个函数各一个,在任意时刻ttt,xxx函数可以转换为yyy函数当且仅当axtbx>aytbya_xtb_…

.NET CORE 对接天翼云 OOS

最近,因公司项目需要对接天翼云OOS,在百度多次折腾后,大部分的都是基于java、php 等其他语言,很少基于C#语言的相关资料,即使有也是基于.NET Framwork开发的SDK,内容几乎是千篇一律,很少基于.NE…

盘点618 .NET 程序员必“败”书单

六月到了,有三个节日迎接我们,心中微微一盘算:儿童节和端午节仿佛对我们都不重要。我们期待的只有:618狂欢购物节!没错一年一度的618来了,哪些书值得买? 小编盘点了2019年1-5月.NET 相关的图书,…

CF1028F. Make Symmetrical

CF1028F. Make Symmetrical 题目描述 Solution 结论1:两个点(x1,y1),(x2,y2)(x_1,y_1),(x_2,y_2)(x1​,y1​),(x2​,y2​)关于(0,0),(x3,y3)(0,0),(x_3,y_3)(0,0),(x3​,y3​)对称的必要条件为(x1,y1)(x_1,y_1)(x1​,y1​)和(x2,y2)(x_2,y_2)(x2​,y2​)在同一个…

ApplicationInsights的探测器尝鲜

通常我们可以依靠ApplicationInsights(以下简称ai)来收集比如请求(request),依赖项(dependencies),异常(exception)等信息,但是无法收集到比如一个方法(方法内部比如没有依赖项调用)的信息。很多时候如果一个方法很慢,…

CF917C. Pollywog

CF917C. Pollywog 题目描述 Solution 看完题,基本的方向就是状压DP。 因为每次都是最左边的青蛙跳至多kkk步,容易发现任意两个青蛙之间的距离始终小于kkk。 因此可以把连续kkk个位置的空闲状态压在(kx)≤70\binom{k}{x}\leq70(xk​)≤70个二进制数中…

开源/免费界面自动化测试工具对比研究

摘要:随着我行自动化测试实施范围的不断扩大,参与界面自动化测试的应用系统越来越多。我行的应用系统现阶段多采用商用工具QTP(UFT)作为执行工具来进行界面自动化测试,采购的QTP license是有限的,使得资源的…

CF1119G. Get Ready for the Battle

CF1119G. Get Ready for the Battle 题目描述 Solution 妙妙构造题。 考虑这样一个过程&#xff1a;所有人一起打第一个怪&#xff0c;每次打nnn&#xff0c;最后剩下k1<nk_1<nk1​<n&#xff0c;就找一些加起来正好为k1k_1k1​的组打掉k1k_1k1​&#xff0c;剩下的…

使用 ConfigMap 挂载配置文件

使用 ConfigMap 挂载配置文件Intro有一些敏感信息比如数据库连接字符串之类的出于安全考虑&#xff0c;这些敏感信息保存在了 AzureKeyVault 中&#xff0c;最近应用上了 k8s 部署&#xff0c;所以想把 AzureKeyVault 的信息迁移到 ConfigMap&#xff0c;不再依赖 AzureKeyVaul…

CF1158D. Beautiful Array

CF1158D. Beautiful Array Solution 构造 对于所有点(xi,yi)(x_i,y_i)(xi​,yi​)选择yiy_iyi​最小的点作为起点&#xff0c;每次考虑下一步若是LLL&#xff0c;则往最右边&#xff08;与当前线段夹角最大&#xff09;的点走&#xff0c;否则往最左边的点走。 时间复杂度O…

SciSharpCube:容器中的SciSharp,.NET机器学习开箱即用

SciSharp Cube在Docker容器中快速体验SciSharp机器学习工具的最新功能。项目地址(原文链接)&#xff1a;https://github.com/SciSharp/SciSharpCube从Docker Hub运行docker run --name scisharp -it -p 8888:8888 scisharpstack/scisharpcube这条命令会拉取最新的SciSharpCube镜…

CF704B. Ant Man

CF704B. Ant Man Solution 经典dpdpdp&#xff0c;第一次见好像是在ZJOIZJOIZJOI的某题&#xff1f; 先按xxx排序 用f[i][j]f[i][j]f[i][j]表示放入前iii个数&#xff0c;有jjj个端点&#xff08;不算边界点&#xff09;的最小代价。 每次可以&#xff1a; 1.合并两段折线 2.…

.NET Core 3中的性能提升(译文)

回顾我们准备推出.NET Core 2.0的时候&#xff0c;我写了一篇博文来介绍.NET已经引入的诸多性能优化中的一部分&#xff0c;我很喜欢把它们放在一起讲述&#xff0c;也收获了很多正面反馈&#xff0c;因此我又给.NET Core 2.1&#xff0c;一个同样高度聚焦于性能的版本&#xf…

CF594D. REQ

CF594D. REQ Solution 离线询问&#xff0c;按左端点排序。 对于每个质因数都会有p−1p\frac{p-1}{p}pp−1​的贡献&#xff0c;考虑把贡献维护在当前左端点右边最早出现的ppp倍数的位置上。 每次lll增加的时候&#xff0c;把这一位变成1&#xff0c;并把这一位的质因数的贡…

程序员修神之路--高并发下为什么更喜欢进程内缓存

菜菜哥&#xff0c;告诉你一个好消息YY妹子&#xff0c;什么好消息&#xff0c;你有男票了&#xff1f;不是啦&#xff0c;我做的一个网站&#xff0c;以前经常由于访问量太大而崩溃&#xff0c;现在我加上了缓存&#xff0c;很稳定啦加的什么缓存呢&#xff1f;我用的redis&am…

CF364B. Free Market

CF364B. Free Market Solution 显然最终能取到的物品必然是按cic_ici​从小到大排序后的一段前缀。能取到的价值集合可由这段前缀做背包得到。每一轮取数的价值最多增加ddd。 因此先对所有cic_ici​做背包&#xff0c;从000开始每次贪心地选取距离不超过ddd的能被ccc表出的最…

6月数据库排行:PostgreSQL和MongoDB分数罕见下降

DB-Engines 数据库流行度排行榜 6 月更新已发布&#xff0c;排名前二十如下&#xff1a;总体排名和上个月相比基本一致&#xff0c;其中排名前三的 Oracle、MySQL 和 Microsoft SQL Server 也是分数增加最多的三个数据库&#xff0c;增加的分数分别为 13.67、4.67 和 15.57&…

CF611F. New Year and Cleaning

CF611F. New Year and Cleaning Solution 还挺巧妙的套路。 把起点整体看作一个矩阵&#xff0c;在操作时移出原来矩阵外的部分的起点都是超越边界的&#xff0c;可以直接通过超出的面积计算贡献&#xff0c;再把超出的部分删去&#xff0c;模拟即可&#xff08;第一轮模拟会…

在ASP.Net Core 中使用枚举类而不是枚举

前言&#xff1a;我相信大家在编写代码时经常会遇到各种状态值&#xff0c;而且为了避免硬编码和代码中出现魔法数&#xff0c;通常我们都会定义一个枚举&#xff0c;来表示各种状态值&#xff0c;直到我看到Java中这样使用枚举&#xff0c;我再想C# 中可不可以这样写&#xff…

CF626E. Simple Skewness

CF626E. Simple Skewness Solution 先排序。 nnn为奇数时&#xff0c;枚举中位数&#xff0c;两边贪心地选择最大的数&#xff0c;显然平均数是凸函数&#xff0c;三分即可确定最值。 当nnn为偶数时&#xff0c;必然选择最大值&#xff0c;然后转化为nnn为奇数的情况。 PS&a…