视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
php session 不稳定怎么办
2020-11-02 18:26:49 责编:小采
文档

php session不稳定的解决办法:首先在配置文件中设置sessionState节点;然后把类设为可序列化的类;最后启动“asp.net state service”即可。

推荐:《PHP视频教程》

解决session不稳定的问题

公司的系统一直以来都会出现session突然丢失的情况,昨天想了一个法子,但行不通,今天上午通过搜索资料解决了它。

昨天我是想通过新建一个数据表来存储用户登录的信息,但是,要标记一个用户的时候,想用IP来标记,觉得不太现实,因为有时候对的IP地址是一样的,于是想用MAC地址来解决,对过sendarp的方法可以得到指定IP的MAC,但是这也仅仅适用于局域网,非局域网是无法实现的,于是这种思路到此宣告破产。除非在客户端通过js去获取再发送到服务端,但考虑到不用客户端cookiess的话每次都要查很麻烦,于是放弃。

今天在网上发现,可以在配置文件中设置sessionState节点:

 <sessionState mode="Off|InProc|StateServer|SQLServer"
 cookieless="true|false"
 timeout="number of minutes"
 stateConnectionString="tcpip=server:port"
 sqlConnectionString="sql connection string"
 stateNetworkTimeout="number of seconds"/>

必须有的属性是

属性 选项 描述 
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秒钟。

然后,启动asp.net state service。

注意要把类设为可序列化的类!才可以加到session中。

 System.Web.SessionState.HttpSessionState session = HttpContext.Current.Session;
 session.Add("user", obj);
 HttpContext.Current.Session.Add("user", obj);
 if (obj.USER_DIST_ID == "0000")
 {
 HttpContext.Current.Session.Add("sDistID", obj.USER_DIST_ID);
 }
 System.Web.Security.FormsAuthentication.SetAuthCookie(obj.USER_ID , false);
 。。

下载本文
显示全文
专题