以前,我已经实现了两个单独的 ASP.NET Web 应用程序,一个作为另一个子文件夹中的虚拟应用程序,它成功地共享表单身份验证,如http://msdn.microsoft.com/en-us/library/eb0zx8fc中所述.aspx
(基本上,在 Web.config 中设置相同<forms>
的部分,并在该<machineKey>
部分中设置键)
现在,我正在尝试做一些类似的事情来让BlogEngine.NET(它是一个网站,而不是一个 Web 应用程序)与我的一个 Web 应用程序共享表单身份验证。我尝试将其作为虚拟应用程序放在子文件夹中,并将其设置为单独的 IIS 站点(相同的域名,不同的端口号),但我根本无法进行身份验证:当我去登录到我的 Web 应用程序时的博客Page.User.Identity.IsAuthenticated
始终是“假的”。
我真的不确定如何开始调试它,因为表单身份验证是在我的任何代码运行之前处理的。
<authentication>
两个 Web.config 的部分相同:
<authentication mode="Forms">
<forms path="/" domain="localhost" timeout="129600" name=".WebSiteName"
protection="All" slidingExpiration="true" loginUrl="/admin/login.aspx"
cookieless="UseCookies"/>
</authentication>
还有<machineKey>
:
<machineKey validationKey="DD45C42ACEAF1E208E9B78288177EBF9C8C7C54C6D05BA2FBA90B5348B8F6987216CB098056891CFE81DC33E37C5F9A2BF1845DBF902C6E4BBFEC2341FFA3635"
decryptionKey="0C69852D8BE0948D545C35B932D394102802FAF7FA46E99B4E5B5E12546E4620"
validation="SHA1" decryption="AES" />
有人对我应该检查或尝试什么有任何建议吗?