.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站點的過程及遇到的坑講一遍。