方法一:最麻烦也是最容易想到的方法,在每个页面的page_load()方法里面判断:
代码如下:
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
if (Session["username"] != null)
{
//登陆成功的情况
Page.ClientScript.RegisterClientScriptBlock(this.GetType(), "", "<script>alert('登录成功!')</script>");
}
else
{
//过期,重新登录
Response.Redirect("LoginForm.aspx");
}
}
}
缺点:代码冗余,重复写判断session代码。
方法二:重写HttpModule中的Init()方法,然后判断session过期情况。
1.新建一个继承IHttpModule接口的类Module ,让Module类实现IHttpModule接口成员。
2.在Init()方法中对Context进行注册AcquireRequestState事件。
3.在AcquireRequestState方法中实现判断session代码。
代码如下:
using System;
using System.Data;
using System.Configuration;
using System.Linq;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.HtmlControls;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Xml.Linq;
namespace JudgeSessionOutTime
{
//1.继承IHttpModule类,实现接口成员
public class Module:IHttpModule
{
#region IHttpModule 成员
public void Dispose()
{
throw new NotImplementedException();
新闻热点
疑难解答
图片精选