asp.net Core IIS Hosting Cookie验证在站点重启后失效

1、asp.net Core用Cookie身份验证,身份信息是加密后保存在Cookie的,保证了Cookie的安全。加密的Cookie只有Server端可以解密,所以其实Server端有保存密钥。这个加解密的过程,在asp.net Core用的是Data Protection这个机制来自动完成的,有关Data Protection可参考微软官方:https://docs.microsoft.com/en-us/aspnet/core/security/data-protection/introduction?view=aspnetcore-6.0

2、当asp.net Core 应用通过IIS Hosting的时候,IIS就需要负责保存第1点提到的密钥。Data Protection文档中提到密钥的存储有多种Provider:File System、Azure存储、Redis、注册表、EFCore。对于IIS Hosting来说,则会按照以下顺序自动选择一种存储方式:

1)用户配置文件User Profile

对于IIS来说,如果想要启用用户配置文件,需要设置两个部分:

a. 启用应用程序池Application Pool的 setProfileEnvironment attribute

导航到 %windir%/system32/inetsrv/config 文件夹。
打开 applicationHost.config 文件。
查找 <system.applicationHost><applicationPools><applicationPoolDefaults><processModel> 元素。
如果 setProfileEnvironment 属性不存在,各个操作系统的默认值不同,Server来说一般默认会是 true,或者将属性的值显式设置为 true

b.应用程序池loadUserProfile启用

 

2)注册表

如果没有启用用户配置文件,IIS会通过HKLM 注册表的特殊注册表项来取得密钥。注册表项仅列在工作进程帐户的 ACL 中,使用 DPAPI 对密钥静态加密。

这个注册表项路径大概是:计算机\HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\ASP.NET\4.0.30319.0\AutoGenKeys

好像如果安装IIS(with ASP.NET)时会自动生成,但是如果IIS默认安装又不会自动生成,如果没有自动生成,也可以通过脚本生成。

3)内存

如果既没有启用用户配置文件,也找不到注册表项,IIS只能把密钥保存到进程内存中(w3wp.exe)。这种情况下,如果IIS或者站点重启,旧密钥就会丢失,所有Cookie无法解密,会需要重新产生密钥,重新登录颁发新的加密Cookie。

综上,如果IIS默认安装,没有生成特殊注册表项,应用程序池默认也没有开启用户配置文件,密钥就会保存在内存,站点重启Cookie虽然仍然存在,但就会因为解密失败而失效,需要重新登录验证。此时,可以考虑启用用户配置文件。

当然,也可以考虑在asp.net Core应用程序中,用代码来指定Data Protection的存储Provider。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
IIS上部署ASP.NET Core Web API项目及Swagger可以按照以下步骤进行: 1. 首先,我们需要确保已经在本地系统上安装了ASP.NET Core Runtime和ASP.NET Core Hosting Bundle,以便在IIS中运行ASP.NET Core应用程序。 2. 在Visual Studio中,打开你的ASP.NET Core Web API项目。确保项目已经设置为IIS Express作为本地开发服务器。 3. 在项目根目录下的`Properties`文件夹中找到`launchsettings.json`文件,检查并确保该文件中已经配置了`applicationUrl`为`http://localhost:{port}/`,其中`port`为你希望的端口号。 4. 在Visual Studio的顶部菜单中,找到 `Build` -> `Publish {YourProjectName}`,选择发布目标为`Folder`,点击 `Publish`。 5. 在弹出的窗口中选择一个输出文件夹,用于存储发布项目的文件。 6. 打开发布文件夹,在该文件夹中应该有一个名为`web.config`的文件。双击打开该文件,确保其中有以下代码片段: ```xml <aspNetCore processPath="dotnet" arguments=".\{YourProjectName}.dll" stdoutLogEnabled="false" stdoutLogFile=".\logs\stdout" forwardWindowsAuthToken="false" /> ``` 7. 打开IIS管理器,右键点击`Sites`节点,选择`Add Website`。填写网站名称以及物理路径为刚刚发布项目的目录。 8. 对于应用程序池,选择一个合适的.NET CLR版本和托管管道模式(例如:.NET CLR版本为No Managed Code,托管管道模式为集成)。 9. 在网站的右侧,找到`Authentication`,禁用匿名身份验证并启用Windows身份验证。 10. 重新启动IIS。 11. 现在,我们可以在浏览器中访问`http://localhost:{port}`,应该能够看到你的ASP.NET Core Web API已经在IIS上成功部署。 12. 最后,要在部署的项目中添加Swagger,可以通过NuGet包管理器,添加`Swashbuckle.AspNetCore`包。 13. 在`Startup.cs`文件的`ConfigureServices`方法中,添加以下配置: ```csharp services.AddSwaggerGen(c => { c.SwaggerDoc("v1", new OpenApiInfo { Title = "API", Version = "v1" }); }); ``` 14. 在`Startup.cs`文件的`Configure`方法中,添加以下代码: ```csharp app.UseSwagger(); app.UseSwaggerUI(c => { c.SwaggerEndpoint("/swagger/v1/swagger.json", "API v1"); }); ``` 15. 重新发布并重新启动IIS,现在你的ASP.NET Core Web API应该在IIS上部署并且通过Swagger可以浏览和调用你的API接口。 以上就是在IIS上部署ASP.NET Core Web API项目及Swagger的步骤。请注意,确保按照正确的顺序执行每一步,并根据自己的项目配置进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值