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