.net 多个子域名共享Form登陆认证

本文介绍了如何在ASP.NET应用中配置Form认证,包括在web.config文件中设置认证方式、统一machineKey、登录成功后的Ticket写入过程以及验证登录状态的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、首先需要在web.config中配置Form认证方式

    <authentication mode="Forms" >
      <forms  loginUrl="~/WeiXin/Login" timeout="2880" domain="66kangba.com" />
    </authentication>

二、需要设置成相同的machineKey

<machineKey validationKey="9F5DDD161399AC575F8CF52A447327E06D5F928B0F4F76C5A9A46D172A4DE4C1862D5ECD57609A36AE009CA365B241FCB3855607EF0E910215660A3003FA1B5E" decryptionKey="584F573B21B40C2B490E457D6EE39E27E3B80D3806E049FE0FA026EF9220EB83" validation="SHA1" decryption="AES" />

三、登陆成功后写入Ticket

   FormsAuthenticationTicket authTicket = new FormsAuthenticationTicket(
          1,
          unionid,//CookieName
          DateTime.Now,
          DateTime.Now.AddMinutes(60),
          false,
          userInfoStr//额外保存的信息
          );
            string encryptedTicket = FormsAuthentication.Encrypt(authTicket);
            System.Web.HttpCookie authCookie = new System.Web.HttpCookie(FormsAuthentication.FormsCookieName, encryptedTicket);
            authCookie.Domain = "66kangba.com";//必须是是webconfig中配置的相同域名
            System.Web.HttpContext.Current.Response.Cookies.Add(authCookie); 

四、验证登陆,获取Ticket

           ViewData["uid"] = User.Identity.Name;
            var cookie = Request.Cookies[FormsAuthentication.FormsCookieName];
            var ticket = FormsAuthentication.Decrypt(cookie.Value);
            string data = ticket.UserData;
            ViewData["userInfo"] = data;


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值