页面提交过期问题

J2EE 码拜 10年前 (2015-04-21) 976次浏览 0个评论
 

 如果一个页面写了一半 ,走开后1小时再继续写,提交时发现账户session过期问题,那不是很恼火。请问大家的解决方案是什么?

1.永不过期  不安全
2 每个输入框都有检测session 事件 太麻烦

还有什么解决方案呢

页面提交过期问题
开发时,把session过期时间调长些呀!
页面提交过期问题
引用 1 楼 longtian1213 的回复:

开发时,把session过期时间调长些呀!

过期时间 1小时,他3个小时后继续填 也不行。

页面提交过期问题
引用 2 楼 qq573616 的回复:
Quote: 引用 1 楼 longtian1213 的回复:

开发时,把session过期时间调长些呀!

过期时间 1小时,他3个小时后继续填 也不行。

用cookie吧,或者URL重写!

页面提交过期问题
40分
方案1:检查AJAX返回的返回的内容是否有<html>标签 
在web系统中,当session过期时,当用户有操作的时候,此时系统一般会返回登陆界面。 
让用户重新输入用户名和密码。当session过期的时候,AJAX请求返回的内容应该是登陆界面的页面 
内容(即登陆界面的页面的html代码)。通过判断返回内容是否用<html>来判断session是否过期。 
var result=request.responseText;/* ajax返回的内容*/ 
if(result.indexOf(“”<HTML>””)>-1){/*返回内容中有html标签*/} 
或者 
var r=/<html>/ig; 
if(r.test(result)){/*返回内容中有html标签*/} 
通过上面的方法可以判断session是否过期,然后根据具体的业务进行异常处理。 
方案2:返回的结果中有session是否过期的标志。也有人称为true/false模式 
此解决方案一般结合json使用。 
如返回的结果是: 
var res={ 
“result”:true,/*session没有过期,false(session过期)*/ 
“data” :””/*其它数据*/ 

if(res[“result”]) 

/*session没有过期*/ 
}else{ 
/*session过期*/ 

方案3:利用时间戳 
在页面上搞个全局变量 
var startDate; /*ajax最近一次访问服务器的时间,Date类型*/ 
if(new Date().getTime()-startDate.getTime()<30*60*1000) 

/*假设session过期的时间30分钟*/ 
/*session没有过期*/ 
}else{ 
/*session过期*/ 

哈哈!Do not trust the client 
方案4:延长session过期时间 
此方案有性能问题 
4.1:延长session过期时间 
4.2:client轮循server。(AJAX轮循server或client,server保持长连接)

CodeBye 版权所有丨如未注明 , 均为原创丨本网站采用BY-NC-SA协议进行授权 , 转载请注明页面提交过期问题
喜欢 (0)
[1034331897@qq.com]
分享 (0)

文章评论已关闭!