zoukankan      html  css  js  c++  java
  • 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"]这个东东的……

  • 相关阅读:
    UEmacs/PK Keybindings
    ubunut install golang
    vyos ipsec l2tp simple experiment
    Lynx 命令行操作
    Linux开启路由转发功能
    PROTEUS的元器件及模型制作
    5G模拟网自动化测试的需求和挑战
    vyos site-to-site ipsec simple experiment
    kubeadm 搭建 k8s 时用到的常用命令汇总
    html 特殊符号标记
  • 原文地址:https://www.cnblogs.com/lvcha/p/1735865.html
Copyright © 2011-2022 走看看