一、session介绍:
1. session和cookie的区别在于,cookie是把信息保存在用户本地的浏览器中,而session是把信息保存在服务器端的内存中,
2. 浏览器向服务器发送一个类键值对的数据,同时还会生成一个sessionID,这样才会保证数据的正确性。
3 . session的默认有效期为20分钟
4. session的主要作用是用来登录,登录时需要校验用户输入的用户名和密码都正确,如果正确,那么会将用户的信息存储到session中,在需要登录以后才能访问的页面中校验session,如果session有值,说明用户登录了,继续访问页面,如果没有值,说明用户没有登录,那么跳转到登录页面,让用户重新进行登录,防止用户跨过登陆直接进入主页面
5. asp后台使用session时可以直接使用,因为该程序继承了session的接口,但是其余的需要继承session
6. 创建和写入session:
a. 创建session对象
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls; namespace CZBK.ItcastProject.WebApp._2015_5_31
{
public partial class SessionDemo : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
if (IsPostBack)
{
string name=Request.Form["txtName"];
//创建session
Session["userName"] = name;
// Session.Timeout = 30;
Response.Redirect("Test.aspx");
} }
}
}
//取出session的值
protected bool CheckValidateCode()
{
bool isSucess = false;
if (Session["validateCode"] != null)//在使用Session时一定要校验是否为空,因为如果为null的时候,执行到后面的.tostring()代码会出异常
{
string txtCode = Request.Form["txtCode"];//获取用户输入的验证码。
//获取session值
string sysCode = Session["validateCode"].ToString();
//equals方法需要两个参数,第一个是对比的字符串,第二个如果是字母表示不计大小写
if (sysCode.Equals(txtCode, StringComparison.InvariantCultureIgnoreCase))
{
isSucess = true;
Session["validateCode"] = null;
}
}
return isSucess;
}
清除session: Session["validateCode"] = null;
为session设置有效时间:
Session.Timeout = 30;
b . aspx文件使用session,直接 context.Session["名称"] = code; 如 context.Session["validateCode"] = code;
c . ashx文件以及一些其余的文件使用session,必须实现.IRequiresSessionState 接口,具体代码如下:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web; namespace CZBK.ItcastProject.WebApp._2015_5_31
{
/// <summary>
/// ValidateImageCode 的摘要说明
/// </summary> //使用session创建对象,必须引入以下System.Web.SessionState.IRequiresSessionState
public class ValidateImageCode : IHttpHandler,System.Web.SessionState.IRequiresSessionState
{
//在一般处理程序中如果要使用Session必须实现.IRequiresSessionState接口.
public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/plain";
Common.ValidateCode validateCode = new Common.ValidateCode();
//创建一个4位数字的图形验证码
string code=validateCode.CreateValidateCode();
//创建session对象
context.Session["validateCode"] = code;
validateCode.CreateValidateGraphic(code,context);
} public bool IsReusable
{
get
{
return false;
}
}
}
}
二、使用session遇到的问题。
使用session如果项目比较大,可能会面临着创建一个集群,就是指把项目部署在不同的多个机器上,这样用户存储session时可能存储在A机器中,但是校验的时候就可能会访问的是B机器,这样,session的值就是一个null值。所以,就需要用到一个分布式缓存,就是指把所有的session值统一放置在一个服务器上,比如用到memcache,或许Redis。
分布式缓存访问我的此博客:https://www.cnblogs.com/wangjinya/p/10706739.html