
.NET Core 2.0 新时代
万众瞩目的.NET Core 2.0终于发布了,原定于9.19的dotnetconf大会的发布时间大大提前了1个月,.NET Core 2.0/.NET Standard 2.0的正式发布是.NET 开源跨平台的一个重大里程碑。
.NET Core 2.0 SDK下载地址:https://www.microsoft.com/net/download/core#/sdk
Visual Studio 2017 15.3下载地址:https://www.visualstudio.com/zh-hans/downloads/
更新ASP.NET Core 项目中的目标框架
更新ASP.NET Core Web项目中的Nuget依赖项
备注:删除之前的 Microsoft.* 依赖项,使用 Microsoft.AspNetCore.All。
.NET Core 2.0 更新Cookie中间件使用方法
备注:我这边当前项目单独使用的Cookie中间件,未结合Identity使用。
1:在ConfigureServices添加Cookie中间件,使用自定义Scheme(坑就在这里)
services.AddAuthentication(options=> {
options.DefaultChallengeScheme = CookieAuthenInfo.QwCmsWebCookieInstance;
options.DefaultSignInScheme = CookieAuthenInfo.QwCmsWebCookieInstance;
options.DefaultAuthenticateScheme = CookieAuthenInfo.QwCmsWebCookieInstance;
})
.AddCookie(CookieAuthenInfo.QwCmsWebCookieInstance, m =>
{
m.LoginPath = new PathString("/Account/Login");
m.AccessDeniedPath = new PathString("/Account/Denied");
m.LogoutPath = new PathString("/Account/Logout");
m.Cookie.Path = "/";
});
踩坑:报异常 No authenticationScheme was specified, and there was no DefaultChallengeScheme found.
特别感谢Zonciu提供的帮助。
2:在Configure使用Cookie中间件
app.UseAuthentication();
使用扩展类AuthenticationHttpContextExtensions
引入命名空间
using Microsoft.AspNetCore.Authentication;
新的扩展方法
使用方式
//登录
await HttpContext.SignInAsync(CookieAuthenInfo.QwCmsWebCookieInstance, userPrincipal,
new AuthenticationProperties
{
ExpiresUtc = DateTime.UtcNow.AddHours(12),
IsPersistent = true,
AllowRefresh = false
}); //退出
await HttpContext.SignOutAsync(CookieAuthenInfo.QwCmsWebCookieInstance);
AuthorizeAsync现在返回结果为AuthorizationResult
新的扩展方法

使用方式
var result = await HttpContext.AuthenticateAsync("xxxx");
if (result.Succeeded)
{
......
}