.net core mvc 發佈有很長時間了,但是一直沒有用過,最近突然想開發一個導航網站,於是就抽時間開發了一個專門為開發者使用的導航站點,想看的話請移步我的上一篇博客 "https://www.cnblogs.com/weiwin/p/11941684/" 這個網站雖然小但是網站該有的功能它都有 ...
.net core mvc 發佈有很長時間了,但是一直沒有用過,最近突然想開發一個導航網站,於是就抽時間開發了一個專門為開發者使用的導航站點,想看的話請移步我的上一篇博客https://www.cnblogs.com/weiwin/p/11941684/
這個網站雖然小但是網站該有的功能它都有。如果你想做一個小的網站,看這個帖子足夠了
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不然還會繼續執行控制器里的方法
2 全局異常日誌設置
nuget引用log4net
配置log4net.config文件
<?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里添加代碼
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>(); })
}
新建類ErrorFilter
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();
在控制器里使用
private IMemoryCache _cache;
public HomeController(IMemoryCache cache)
{
_cache = cache;
}
4 session使用
在statup.cs里添加代碼
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站點的過程及遇到的坑講一遍。