第一次获取Session值为null,第二次有值的解决办法
登陆页面:Session["USERNAME"]=name;//赋值Response.Redirect("Default.aspx");Default页面:protect...
登陆页面:
Session["USERNAME"] = name;//赋值
Response.Redirect("Default.aspx");
Default页面:
protected void Page_Load(object sender, EventArgs e)
{
if (Session["USERNAME"] == null)
{
System.Web.HttpContext.Current.Response.Write("<script>parent.location.href='Admin_login.aspx';</script>");
}
}
每次第一次登陆时都会返回到登陆页面,第二次登陆才能跳到Default,这个情况以前没出现过,请大神帮忙 展开
Session["USERNAME"] = name;//赋值
Response.Redirect("Default.aspx");
Default页面:
protected void Page_Load(object sender, EventArgs e)
{
if (Session["USERNAME"] == null)
{
System.Web.HttpContext.Current.Response.Write("<script>parent.location.href='Admin_login.aspx';</script>");
}
}
每次第一次登陆时都会返回到登陆页面,第二次登陆才能跳到Default,这个情况以前没出现过,请大神帮忙 展开
2个回答
展开全部
因为你第一次登陆时,session本身就是空值,到default页,他会执行session=null里面的语句也就是跳转到登录页,而这时候session已经将name记录,所以第二次登陆的时候就能跳到Default。
改进方法:在跳转到default前将你输入的用户名付给session,但是也别忘了验证它是不是存在于数据库中
望采纳。。。
改进方法:在跳转到default前将你输入的用户名付给session,但是也别忘了验证它是不是存在于数据库中
望采纳。。。
追问
我肯定是先判断用户存在的情况下,赋值给session["USERNAME"]的,然后再执行的跳转,这个确实是这样的
追答
那你就进行调试吧,这样就可以知道问题出在哪了
展开全部
1、检查服务中的"ASP.NET 状态服务"是否设置为自动启用
2、将Web.Config文件中关于Session的设定如下:<sessionState mode=´StateServer´
stateConnectionString=´tcpip=127.0.0.1´ sqlConnectionString=´data
source=127.0.0.1;Trusted_Connection=yes´ cookieless=´true´
timeout=´60´/>
2、将Web.Config文件中关于Session的设定如下:<sessionState mode=´StateServer´
stateConnectionString=´tcpip=127.0.0.1´ sqlConnectionString=´data
source=127.0.0.1;Trusted_Connection=yes´ cookieless=´true´
timeout=´60´/>
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询