Response.Redirect(x.aspx);跳转后session为null的解决方法
通常我們做登陸的時(shí)候都是登錄成功后為管理員保存一些信息,一般都會寫類似下面的代碼
if(登錄成功)
{
Session["xx"] = "user";?
Response.Redirect("Framework.aspx");
}
當(dāng)我們登錄后再從其它頁面訪問Session["xx"]的時(shí)候發(fā)現(xiàn)報(bào)錯(cuò)說為null.郁悶具體是為什么我也不清楚.
網(wǎng)上百度一下有人做了如下解釋,不知道是否合理
原因:當(dāng)asp.net 執(zhí)行 response.redirect 時(shí)會強(qiáng)制終止當(dāng)前response ,不發(fā)送當(dāng)前頁面的cookie 給瀏覽器,而是發(fā)送一個(gè)指令告訴瀏覽器重新發(fā)送一個(gè)新的http請求到新的url,結(jié)果導(dǎo)致當(dāng)前的session 丟失。
解決這個(gè)問題的方法是在當(dāng)前頁面接受get請求時(shí)就設(shè)置一下session ,這樣瀏覽器就會記錄下當(dāng)前的session id,當(dāng)瀏覽器再發(fā)送post 請求到當(dāng)前頁面時(shí),server就不需要再發(fā)送一次session id 的cookie 給瀏覽器了。
所以為了解決這個(gè)問題我改成這樣寫了。
if(登錄成功)
{
TempData["xx"] = "user";?
Response.Redirect("a.aspx");
}
然后在a.aspx里寫
Session["xx"]=TempData["xx"].ToString();
這個(gè)問題就解決了……
注意我是用MVC開發(fā)的,webform好像沒有TempData["xx"]這個(gè)東東的……
總結(jié)
以上是生活随笔為你收集整理的Response.Redirect(x.aspx);跳转后session为null的解决方法的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: iBatis.Net(C#)数据库查询
- 下一篇: 项目受源代码管理。向源代码管理注册此项目