.net core mvc 发布有很长时间了,可是一直没有用过,最近忽然想开发一个导航网站,因而就抽时间开发了一个专门为开发者使用的导航站点,想看的话请移步个人上一篇博客http://www.javashuo.com/article/p-ougowmeb-bs.html
这个网站虽然小可是网站该有的功能它都有。若是你想作一个小的网站,看这个帖子足够了,下面全是代码干货,没有废话html
1 登陆过滤器设置
新建一个类,继承 ActionFilterAttribute重写OnActionExecuting方法缓存
public class LoginFilter :ActionFilterAttribute { public FilterLogin() { } public override void OnActionExecuting(ActionExecutingContext context) { base.OnActionExecuting(context); //登陆逻辑 //---- //若是没有登陆 context.Result = new StatusCodeResult(401); } } //控制器里使用 [HttpPost] [FilterLogin()] public IActionResult GetUser() { }
坑:这里必定注意要设置context.Result否则还会继续执行控制器里的方法session
2 全局异常日志设置
nuget引用log4net
配置log4net.config文件mvc
<?xml version="1.0" encoding="utf-8" ?> <configuration> <!-- This section contains the log4net configuration settings --> <log4net> <appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender"> <layout type="log4net.Layout.PatternLayout" value="%date [%thread] %-5level %logger - %message%newline" /> </appender> <appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender"> <file value="logfile/" /> <appendToFile value="true" /> <rollingStyle value="Composite" /> <staticLogFileName value="false" /> <datePattern value="yyyyMMdd'.log'" /> <maxSizeRollBackups value="10" /> <maximumFileSize value="1MB" /> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" /> </layout> </appender> <!-- Setup the root category, add the appenders and set the default level --> <root> <level value="ALL" /> <appender-ref ref="ConsoleAppender" /> <appender-ref ref="FileAppender" /> <appender-ref ref="RollingLogFileAppender" /> </root> </log4net> </configuration>
在startup里添加代码app
public static ILoggerRepository repository { get; set; } public Startup(IConfiguration configuration) { Configuration = configuration; repository=LogManager.CreateRepository("NETCoreRepository"); XmlConfigurator.Configure(repository, new FileInfo("log4net.config")); } public void ConfigureServices(IServiceCollection services) { services.AddMvc(options => { options.Filters.Add<FunClass.ErrorFilter>(); }) }
新建类ErrorFilteride
public class ErrorFilter : IExceptionFilter { private ILog log = LogManager.GetLogger(Startup.repository.Name, typeof(HttpGlobalExceptionFilter)); public void OnException(ExceptionContext context) { log.Error(context.Exception); } }
3 缓存IMemoryCache使用
在startup里添加代码网站
services.AddMemoryCache();
在控制器里使用ui
private IMemoryCache _cache; public HomeController(IMemoryCache cache) { _cache = cache; }
4 session使用
在statup.cs里添加代码.net
public void ConfigureServices(IServiceCollection services) { services.AddSession(); } public void Configure(IApplicationBuilder app, IHostingEnvironment env) { app.UseSession(); }
坑:这里必须在services.AddMvc()以后。日志
5 手动获取DI对象
有时候咱们须要手动获取注入的对象,好比在过滤器里要使用缓存能够这样写
IMemoryCache _cache = (IMemoryCache)context.HttpContext.RequestServices.GetService(typeof(IMemoryCache));
还有第二种方法
新建类ServiceLoader
public class ServiceLoader { public static IServiceProvider Instance { get; set; } }
在startup.cs 添加代码
public void Configure(IApplicationBuilder app, IHostingEnvironment env) { ServiceLoader.Instance = app.ApplicationServices; }
使用
(IMemoryCache)FunClass.ServiceLocator.Instance.GetService(typeof(IMemoryCache));
完结散花。 若是你们喜欢的话,别忘点了个站,下篇博客,我将把一个网站怎么从购买域名,备案,域名解析,发布部署.net core mvc站点的过程及遇到的坑讲一遍。