Cookie和Session(session过程和设置进程外session)

cookie 和  session 的区别

cookie 是保存在客户端上的一种机制   而session 是保存在服务端的一种机制

cookie的理解:

打个简单的比方,一个人生病了去A医院看病,回来的时候医生给了病人一个病历本(相当于cookie)  那么下次病人去复查的时候  就要带着这个病例本队A医院,如果拿着这个病历本去了B医院 B医院肯定是不承认的(不能够跨域取cookie,比如a.com的cookie只能由a.com, x.a.com, y.a.com等站点读取,b.com则不可以)

cookie的保存机制分两种:  第一种是会话cookie    第二种是 持久cookie

会话cookie:  如果没有设置过期时间  那么cookie的生命周期就是当前浏览器的会话时间   当浏览器关闭之后 那么cookie就会失效   这种生命期为浏览会话期的cookie称之为会话cookie

持久cookie:    cookie对象 上加上了Expries属性之后    就会将这个cookie保存在客户端的硬盘上 在cookie为过期之前 那么再次访问这个网站的时候 会再次把cookie带过来

设置持久cookie

   HttpCookie   cookie=new  HttpCookie(string,string);

   cookie.Expires = DateTime.Now.AddDays(3);

context.response.cookies.Add(cookie);

取出设置的cookie的值

先判断context.request.cookies[string]!=null

string  str=context.request.cookies[string].Value;

session的理解

1.0  session是存储在当前服务器的session池中 可以储存任何自定义的对象

2.0  当浏览器第一次访问的时候 会在session池中创建一个session 对象  同时产生一个sessionid   以set-cookie的形式发送给浏览器   浏览器将其保存在当前的进程中

3.0 当浏览器再次访问这个网站下的任何一个页面的时候  就会带上sessionid返回给服务器   在管道事件中的第9个和第10个事件之间进行赋值

判断当前页面是否有实现IRequiresSessionState 接口

从set-cookie 中取出sessionid  从服务器的session池中找到session对象

将session对象赋值给上下文的session属性

4.0  考虑到服务器的session池的容量有限  当储存的sessionde 数据过多  那么回导致session池的重启 然后session池里面的老数据就会丢失

考虑到进程内session的问题  可以使用进程外session 来解决

进程外session

状态服务器(优点:速度快: 缺点不稳定)

数据库 (优点:可以存储大量的数据  缺点:每次访问session都要访问db   比较消耗资源)

进程外session的设置

使用进程外session  是因为 一般储存shession的是使用的是进程内session储存的数据有限

使用进程外session 的要求

1.0 首相将session 中进行保存的对象所属的类药进行序列化[serializable]

2.0 在计算机管理-服务-  asp.net  State  Services   进行开启服务

3.0  在当前站点的web.config 中添加配置

<system.web>

<sessionState stateConnectionString="tcpip=127.0.0.1:42424" mode="StateServer"></sessionState>

</system.web>

配置完成之后 那么就可以使用进程外session了

进程外session 的优点  速度快   缺点: 只能拿个储存少量的session数据

-------------------------------------------------------------------------------------------------------------------------------------------

进程外session 之数据库

优点:比较稳定   确定  每一次访问session的时候都要访问数据库   比较消耗性能

使用数据库  的操作步骤

1.0 找到aspnet_regsql.dll程序集所在的位置(C:\Windows\Microsoft.NET\Framework\v4.0.30319)

2.0   使用cmd 命令 切换到当前的文件夹之下(cd   C:\Windows\Microsoft.NET\Framework\v4.0.30319)

3.0 输入创建数据库的cmd命令 aspnet_regsql -S . -U sa -P 123 -ssadd -sstype c -d aspnetdb

如果  -S后面街上127.0.0.1  无法连接到SQL   server   这里可以把127.0.0.1  换成点 在尝试    -U  -P   -d  根据情况而定

配置完成之后在数据库中会有两个表    还有有一个触发器和一个存储过程

4.0  在web.config 中使用 <sessionState</sessionState> 节点下配置

<sessionState sqlConnectionString="server=.;database=aspnetdb;uid=sa;pwd=123;" allowCustomSqlDatabase="true" mode="SQLServer">

</sessionState>

节点中的  server 选择自己要链接的数据库地址     database:需要链接的数据库的名称    uid:database所在的服务器的登录名称   pwd:登陆密码   mode 数据库类型

时间: 2024-10-09 12:48:48

Cookie和Session(session过程和设置进程外session)的相关文章

探索ASP.NET MVC5系列之~~~5.Session篇(进程外Session)

其实任何资料里面的任何知识点都无所谓,都是不重要的,重要的是学习方法,自行摸索的过程(不妥之处欢迎指正) 汇总:http://www.cnblogs.com/dunitian/p/4822808.html#mvc 本章Demo:https://github.com/dunitian/LoTCodeBase/blob/master/NetCode/6.网页基础/BMVC5/MVC5Base/Controllers/SessionController.cs 方法有很多,今天主要说不改代码的那两种(状

探索ASP.NET MVC5系列之~~~6.Session篇(进程外Session)

其实任何资料里面的任何知识点都无所谓,都是不重要的,重要的是学习方法,自行摸索的过程(不妥之处欢迎指正) 汇总:http://www.cnblogs.com/dunitian/p/4822808.html#mvc 本章Demo:https://github.com/dunitian/LoTCodeBase/blob/master/NetCode/6.网页基础/BMVC5/MVC5Base/Controllers/SessionController.cs 方法有很多,今天主要说不改代码的那两种(状

第四节:框架前期准备篇之进程外Session的两种配置方式

一. 基本介绍 1. 背景:Asp.Net默认的Session机制是进程内,存储在服务器端内存中,有这么几个缺点: ①:既然存在内存中,空间有限,不能存储大数据量信息,数据量多的话Session会被挤爆. ②:IIS只要一重启,Session就会丢失,哪怕就是改一下配置文件,IIS也会重启,此时如果客户端有用户通过浏览器正在访问该网站,如果用到Session,原Session是丢失的了,就会报“未将对象引用设置到对象的实例”类似的错误. ③:Session是依赖Cookie来保存SessionI

进程外Session

1.Session保存在SQLServer中配置方法: 1)运行.NetFramework安装目录下对应版本的aspnet_regsql.exe 来创建相关的数据库.表和存储过程等,比如: C:\Windows\Microsoft.NET\Framework\v4.0.30319>aspnet_regsql.exe -ssadd -sstype p -S 127.0.0.1 -U sa -P 123456 其中-sstype p表示数据库名固定为ASPState,-S(大写)为数据库服务器地址,

.net学习之进程外Session的配置

转载地址:http://www.cnblogs.com/rohelm/archive/2012/05/13/2498465.html 人人都知道怎么去使用session,但是初学者,尤其是自学的学生可能对于进程外的Session不甚了解,今天我就花半个小时做个简单的示范. 首先,session其虽然是基于cookie的,同时只对本次会话来产生效果,(原理很简单,就是字典内保存一个字典,外层字典的key也就是asp_netsessionId是由.NET自动分配的并保存到只对本次会话有效的cooki

配置进程外Session

配置进程外Session: (1)将服务器Session信息存储在进程外           <1> 首先,开启asp.net state 服务: 控制面板 -> 程序和功能 -> “打开或者关闭 Windows 功能”对话框 -> Internet 信息服务 -> 万维网服务 -> 应用程序开发功能 -> ASP.NET.(Control Panel -> Programs - > Programs and Features -> Tur

进程外Session 转载

进程外Session 文章来自:http://blog.csdn.net/dyllove98/article/details/8698397 三种Session: 1.InProc(进程内)-Asp.Net默认就是这种 优点:速度快 缺点:但内存小,存储有限,易爆满导致重启数据丢失 进程外:可以在IIS或ASPNET服务意外关闭时继续保持状态,注意此时存储到session中的对象必须支持序列化: 2.StateServer:使用aspnet_state.exe 2.1开启服务:我的电脑-管理-服

Net Core 使用Redis保存进程外session

Redsi下载地址:https://github.com/MSOpenTech/redis/releases . 下载后解压 找到redis.windows.conf文件, (修改密码这步骤可省略) 打开 找到requirepass 节点 ,放开注释符 “#”  ,后面的值改成自己要设置的密码 打开 cmd 窗口,使用 cd 命令切换目录到程序解压的目录或者直接到解压文件的目录下地址栏输入cmd回车 redis-server.exe redis.windows.conf 新启动一个cmd窗口 r

进程外session(session保存在sqlserver)

1.Session保存在SQLServer中配置方法 1)运行.NetFramework安装目录下对应版本的aspnet_regsql.exe 来创建相关的数据库.表和存储过程等,比如: C:\Windows\Microsoft.NET\Framework\v4.0.30319>aspnet_regsql.exe -ssadd -sstype p -S 127.0.0.1 -U sa -P 123456 其中-sstype p表示数据库名固定为ASPState,-S(大写)为数据库服务器地址,-