asp.net core + layui.js 搭建仓储系统
时间:2019-09-26
本文章向大家介绍asp.net core + layui.js 搭建仓储系统,主要包括asp.net core + layui.js 搭建仓储系统使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
先放几张网站图片:
第一步先从layui 网站https://www.layui.com/doc/ 下载相关文件,复制到项目 wwwroot 目录下:
然后在 _Layout.cshtml 中引用 layui.js 和 layui.css,以及添加左侧栏和头部布局(具体操作见 : https://www.layui.com/doc/element/nav.html)
后端框架:
控制器通过依赖注入引用服务(asp.net core 默认支持)。
Startup.cs 配置数据库连接,Session(用于登录和菜单缓存),添加服务到服务容器。
public class Startup { public Startup(IConfiguration configuration) { Configuration = configuration; } public IConfiguration Configuration { get; } // This method gets called by the runtime. Use this method to add services to the container. public void ConfigureServices(IServiceCollection services) { services.AddMemoryCache(); services.AddSession(options => { options.IdleTimeout = TimeSpan.FromMinutes(10); }); services.Configure<CookiePolicyOptions>(options => { // This lambda determines whether user consent for non-essential cookies is needed for a given request. options.CheckConsentNeeded = context => true; options.MinimumSameSitePolicy = SameSiteMode.None; }); services.AddAuthentication(CookieAuthenticationDefaults.AuthenticationScheme) .AddCookie(); services.AddMvc( options => { options.Filters.Add<HttpGlobalExceptionFilter>(); //加入全局异常类 }).SetCompatibilityVersion(CompatibilityVersion.Version_2_2); services.AddDbContext<AccessManagementContext>(options => options.UseSqlServer(Configuration.GetConnectionString("DefaultConnection"), providerOptions => providerOptions.EnableRetryOnFailure())); services.AddDbContext<LuJCDBContext>(options => options.UseSqlServer(Configuration["WMSConnectionStrings:DefaultConnection"], providerOptions => providerOptions.EnableRetryOnFailure())); services.AddTransient<CompanyServices, CompanyServices>(); services.AddTransient<BasicInfoServices, BasicInfoServices>(); services.AddTransient<AppMenuServices>(); services.AddTransient<IAccountServices,AccountServices>(); services.AddTransient<BranchServices>(); services.AddTransient<PresetFunctionServices>(); services.AddTransient<RoleServices>(); services.AddTransient<LocationServices>(); services.AddTransient<SupplierServices>(); services.AddTransient<CustomerServices>(); services.AddTransient<MeasureServices>(); services.AddTransient<ProductCategoryServices>(); services.AddTransient<ProductServices>(); services.AddTransient<InStorageServices>(); services.AddTransient<OutStorageServices>(); services.AddTransient<BadReportServices>(); services.AddTransient<CheckStockServices>(); services.AddTransient<LocalProductServices>(); //services.AddScoped<AddHeaderFilterWithDI>(); services.AddAutoMapper(typeof(Startup)); Mapper.Initialize(cfg => { cfg.AddProfile<AccessManagementProfile>(); } ); //Mapper.Initialize(cfg => cfg.CreateMap<AppMenu, AppMenuViewModel>()); } // This method gets called by the runtime. Use this method to configure the HTTP request pipeline. public void Configure(IApplicationBuilder app, IHostingEnvironment env,ILoggerFactory loggerFactory) { app.UseSession(); loggerFactory.AddNLog(); //添加NLog NLog.LogManager.LoadConfiguration("nlog.config"); app.UseLog(); if (env.IsDevelopment()) { app.UseDeveloperExceptionPage(); } else { app.UseExceptionHandler("/Home/Error"); // The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts. app.UseHsts(); } app.UseAuthentication(); app.UseHttpsRedirection(); app.UseStaticFiles(); var cookiePolicyOptions = new CookiePolicyOptions { MinimumSameSitePolicy = SameSiteMode.Strict, }; app.UseCookiePolicy(cookiePolicyOptions); app.UseAccountSession(); app.UseMvc(routes => { routes.MapRoute( name: "default", template: "{controller=Home}/{action=Index}/{id?}"); routes.MapAreaRoute("IMS", "IMS", "IMS/{controller}/{action}/{id?}", defaults: new { Controller = "Location", Action = "Index" }); routes.MapAreaRoute("WMS", "WMS", "WMS/{controller}/{action}/{id?}", defaults: new { Controller = "InStorage", Action = "Index" }); routes.MapAreaRoute("Report", "Report", "Report/{controller}/{action}/{id?}", defaults: new { Controller = "LocalProduct", Action = "Index" }); }); } }
原文地址:https://www.cnblogs.com/afei-24/p/11592697.html
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 写一个方法,输入一个文件名和一个字符串,统计这个字符串在这个文件中出 现的次数。
- SSRF漏洞简单分析
- 树莓派基础实验30:BMP180气压传感器实验
- DC-1靶机实战和分析
- 如何用Python优雅的登录校园网?
- PHP入门之类型与运算符
- 栈论 : 递归与栈式访问,如何用栈实现所有递归操作(幼儿园题目篇,题目3)
- Maven是什么? Maven的概念+作用+仓库的介绍+常用命令
- JDK8;HashMap:再散列解决hash冲突 ,源码分析和分析思路
- 写一个 Singleton
- 树莓派基础实验31:MPU6050陀螺仪加速度传感器实验
- springboot gradle mybatis mysql配置(注解)
- PHP入门之流程控制
- 常用进制转换方法(取商留余)原理解析, 附基于栈实现进制转换的代码
- 用 jdom 解析 xml 文件时如何解决中文问题?如何解析?