webapi使用session

在 Global.asax.cs 文件中加入session支持

public override void Init()
        {
            this.PostAuthenticateRequest += (sender, e) => HttpContext.Current.SetSessionStateBehavior(SessionStateBehavior.Required);
            base.Init();
        }

然后在webapi.congfig进行详细设置

配置文件Web.config必须有的属性是

属性 选项 描述 mode 设置将Session信息存储到哪里 Off 设置为不使用Session功能 InProc 设置为将Session存储在进程内,就是ASP中的存储方式,这是默认值。 StateServer 设置为将Session存储在独立的状态服务中。 SQLServer 设置将Session存储在SQL Server中。

可选的属性是:

属性 选项 描述 cookieless 设置客户端的Session信息存储到哪里 ture 使用Cookieless模式 false 使用Cookie模式,这是默认值。 timeout 设置经过多少分钟后服务器自动放弃Session信息。默认为20分钟 stateConnectionString 设置将Session信息存储在状态服务中时使用的服务器名称和端口号,例如:"tcpip=127.0.0.1:42424”。当mode的值是StateServer是,这个属性是必需的。

sqlConnectionString 设置与SQL Server连接时的连接字符串。例如"data source=localhost;Integrated Security=SSPI;Initial Catalog=northwind"。当mode的值是SQLServer时,这个属性是必需的。 stateNetworkTimeout 设置当使用StateServer模式存储Session状态时,经过多少秒空闲后,断开Web服务器与存储状态信息的服务器的TCP/IP连接的。默认值是10秒钟。
Mode:该参数用于设置存储会话状态。状态包括Off、Inproc、StateServer和SqlServer。
    Off表示禁用会话状态
    Inproc表示工作进程自身存储会话状态
    StateServer表示将把会话信息存放在一个单独的ASP.NET状态服务中
    SqlServer表示将把会话信息存放在SQL Server数据库中。

StateConnecitonString:该参数用于设置ASP.NET应用程序存储远程会话状态的服务器名,默认名为本地。
Cookieless:当该参数值设置为True时,表示不使用Cookie会话标识客,反之设置为False时,标识启动Cookie会话状态。
SqlConnectionString:该参数用于设置SQL Server数据库连接。
Timeout:该参数用于设置会话时间,超过该期限,会自动中断会话,默认设置为20。

<sessionState mode="InProc" timeout="5"></sessionState>

具体用法

添加

HttpContext.Current.Session.Add(user, code);

获取

HttpContext.Current.Session[user] != null

清除

HttpContext.Current.Session.Remove(user);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值