进程外Session | 状态服务器Session 和 数据库Session的设置

介绍

我们知道,当浏览器关闭,或者网站重启的时候,会话就结束了。即Seesion就丢失了。(当Web.config配置文件改动,哪怕什么内容都不加,仅仅往配置文件中加一个空格都是改we.config变配置文件,改变配置文件网站就会重启。网站重启进程内的Session就会丢失,而进程外的Seeion不会丢失)

注意:我们知道Cookie与Session的关系。 Cookie里保存的是SessionID  保存SessionID的这个Cookie是一个会话Cookie,会话Cookie一般就保存在本地浏览器进程的内存当中,只要当浏览器关闭,Cookie就消失了。

所有当浏览器关闭的时候,Cookie中保存的SessionID就消失了。而服务器里对应的Session还是存在的。

但是当浏览器没有关闭,。但是网站重启的情况下,即服务端的Session消失了(但是浏览器端Cookie里保存的SeesinID还在)

当一个网站的访问量很大的时候,很容易就将服务端的Session充爆了(因为Sssion只占用那么一小块内存)当Session被充爆后,它就会重启Session池。重启Session池的后果就是所有的Session全部丢失。 所有当浏览器带着一个保存了SessionID的Cookie请求服务器的时候,服务器端又找不到对应的Session,就会报错【“/”应用程序中的服务器错误。未将对象引用设置到对象的实例。】

所以,为了防止,服务端Seesion被充爆,导致Session丢失。我们就想到将Session保存到网站的进程之外。于是就有了出网站进程内的Session外的另外两种Session.

进程外Session分为以下两种:

1,状态服务器Session  (比网站进程内的Session慢一点。但是比占用的内存比进程内的Seesion大一点。比数据库Session快很多,但是毕竟是内存,所以也是容易被充爆的)

2,数据库Session  (磁盘读写比内存速度慢,需要频繁打开ADO.NET的连接速度也慢,好处是空间无限大,所以比较稳定,推荐使用)

状态服务器Session的配置

首先开启一个ASP.NET 状态设置的服务

即:在 “我的电脑” 鼠标右键--->管理--->服务和应用程序----> 服务--->ASP.NET状态服务(或者ASP.NET State Service)--->点击右键选择“启动”

启动ASP.NET状态服务后,然后再Web.config配置文件中添加这个节点内容






    
      
      
      
             
    
      

这样进程外Session就配置好了

怎么测试是否已经配置好了呢?

下面有一个关于用户登陆的例子: ---------------------------------下面我们来看看这个例子:

进程外Session | 状态服务器Session 和 数据库Session的设置_第1张图片

Login.aspx文件

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Login.aspx.cs" Inherits="进程外Session.Login" %>






    


    

Login.aspx.cs文件

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;

namespace 进程外Session
{
    public partial class Login : System.Web.UI.Page
    {
        protected void Page_Load(object sender, EventArgs e)
        {
            if(Request.HttpMethod.ToLower()=="post")
            {
                string userName = this.txtUserName.Text.Trim();
                string password = this.txtPassword.Text.Trim();
                if (userName == "abc" && password == "123456")
                {
                    Session["userName"] = userName;
                    Response.Redirect("News.aspx");
                }
                else
                {
                    Response.Write("");
                }
            }           
        }
    }
}


登陆成功跳转的页面:News.aspx页面

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="News.aspx.cs" Inherits="进程外Session.News" %>






    


    
欢迎:<%=Session["userName"].ToString() %> 登陆。


Web.config 文件






    
      
      
      
             
    
      


首先我们来浏览一下这个Login.aspx这个网页

在Login.aspx文件上右键点击在浏览器中查看

进程外Session | 状态服务器Session 和 数据库Session的设置_第2张图片

进程外Session | 状态服务器Session 和 数据库Session的设置_第3张图片

点击“提交”  

进程外Session | 状态服务器Session 和 数据库Session的设置_第4张图片


此时已经证明Session已经保存好了的。但是我们怎么证明这个Session是进程外的Session还是进程内的Session呢?

我们知道,当浏览器关闭,或者网站重启的时候,会话就结束了。即Seesion就丢失了。(当Web.config配置文件改动,哪怕什么内容都不加,仅仅往配置文件中加一个空格都是改we.config变配置文件,改变配置文件网站就会重启。网站重启Session就会丢失)

注意:我们知道Cookie与Session的关系。 Cookie里保存的是SessionID  保存SessionID的这个Cookie是一个会话Cookie,会话Cookie一般就保存在本地浏览器进程的内存当中,只要当浏览器关闭,Cookie就消失了。

所有当浏览器关闭的时候,Cookie中保存的SessionID就消失了。而服务器里对应的Session还是存在的。

但是当浏览器没有关闭,。但是网站重启的情况下,即服务端的Session消失了,但是浏览器端Cookie里保存的SeesinID还在

当一个网站的访问量很大的时候,很容易就将服务端的Session充爆了(因为Sssion只占用那么一小块内存)当Session被充爆后,它就会重启Session池。重启Session池的后果就是所有的Session全部丢失。 所有当浏览器带着一个保存了SessionID的Cookie请求服务器的时候,服务器端又找不到对于的Session,就会报错““/”应用程序中的服务器错误。未将对象引用设置到对象的实例。”

所以,为了防止,服务端Seesion被充爆,导致Session丢失。我们就想到将Session保存到网站的进程之外。于是就有了出网站进程内的Session外的另外两种Session.

1,状态服务器Session

2,数据库Session


好了。当我们点击提交,页面跳转到Naws.aspx页面,页面成功显示了Session["userName"] 里保存的这个数据 abc

这个网页我们别关闭,我们现在来改动一下Web.config,给Web.config配置文件随便加一个空格,目的是重启网站,然后点击保存 。保存这个Web.config配置文件。

此时,我们再来刷新一下这个 刚刚跳转过来的 http://localhost:39756/News.aspx 页面 。我们会发现网站重启了。但是这个进程外的Seesion并没有消失,数据还在。

这就说明这个Session是保存在进程外的。

如果你不信,可以将配置文件中的这段   注释掉试试!

数据库Session的配置

怎么将Session记录到数据库中呢? 其实微软已经为我们设置好了。只要我们简单的配置一下就行了。 当然也要在 “我的电脑” 鼠标右键--->管理--->服务和应用程序----> 服务--->ASP.NET状态服务(或者ASP.NET State Service)--->点击右键选择“启动”(杨中科说数据库Session的配置不需要启动ASP.NET状态服务器,我本人没测试过,暂时屏蔽这段话,老杨最大嘛)

首先。我们进入C盘下的 Windows文件夹 下的Microsoft.Net文件夹下的Framework文件夹下的v4.0.30319文件夹下:找到aspnet_regsql 文件。

具体的路径是: C:\Windows\Microsoft.NET\Framework\v4.0.30319

然后:快捷键win+R调出cmd 命令窗口

在cmd中进入C:\Windows\Microsoft.NET\Framework\v4.0.30319文件夹下

即:在cmd 命令中输入:cd C:\Windows\Microsoft.NET\Framework\v4.0.30319

进程外Session | 状态服务器Session 和 数据库Session的设置_第5张图片

然后执行 aspnet_regsql.exe -U sa -P 123456 -ssadd -sstype c -d sales

解释一下 aspnet_regsql.exe表示执行这个文件 ,-U 表示SqlServer的登陆用户名是sa  ,-P 表示登陆密码是123456   最后面的sales 是数据库名,即:你要将Session保存到哪个数据库下。

进程外Session | 状态服务器Session 和 数据库Session的设置_第6张图片

点击回车键后,直到执行完毕

进程外Session | 状态服务器Session 和 数据库Session的设置_第7张图片


以上运行完毕后,我们打开SqlServer ,找到sales数据库。我们发现下面给我们自动生成了两个表
进程外Session | 状态服务器Session 和 数据库Session的设置_第8张图片
我们在来配置Web.config配置文件





    
      
      
      
      

      
      
      
    
            

然后我们浏览上面那个登陆的例子的Login.aspx文件
填上用户名:abc 密码:123456 后,就跳转到了http://localhost:39756/News.aspx 文件
进程外Session | 状态服务器Session 和 数据库Session的设置_第9张图片
此时证明Session["userName"] 的值abc已经写入Session了。
我们在打开SqlServer  在sales 数据库下找到ASPStateTempSessions 表
查询所有数据
进程外Session | 状态服务器Session 和 数据库Session的设置_第10张图片

发现Session已经写入到数据库表中了。


你可能感兴趣的:(C#,ASP.NET)