1)SessionValidateFilter统一验证session是否超时
2)SessionValidateFilter中判断请求是否为ajax请求
3)ajax请求session超时返回一个json {"statusCode":"301", "message":"Session Timeout! Please re-sign in!"}
4)dwz js框架根据statusCode==301,处理是跳转到登陆页面或者弹出登录dialog
java服务器端处理:
SessionValidateFilter中修改:
- if("XMLHttpRequest".equalsIgnoreCase(request.getHeader("X-Requested-With"))||request.getParameter("ajax")!=null){
- PrintWriterout=response.getWriter();
- out.println({"statusCode":"301","message":"SessionTimeout!Pleasere-signin!"});
- }else{
- response.sendRedirect(response.encodeRedirectURL(this.loginUrl+java.net.URLEncoder.encode(backToUrl,"UTF-8")));
- }
js客户端处理:
session超时跳转到登陆页面还是弹出登录dialog,在DWZ UI初始化时设置:
- <scripttype="text/javascript">
- $(function(){
- DWZ.init("dwz.frag.xml",{
- //loginUrl:"loginsub.html",loginTitle:"登录",//弹出登录对话框
- loginUrl:"login.html",//跳到登录页面
- statusCode:{ok:200,error:300,timeout:301},//【可选】
- pageInfo:{pageNum:"pageNum",numPerPage:"numPerPage",orderField:"orderField",orderDirection:"orderDirection"},//【可选】
- debug:false,//调试模式【true|false】
- callback:function(){
- initEnv();
- $("#themeList").theme({themeBase:"themes"});
- }
- });
- });
- </script>
ajax load页面碎片处理:
ajax请求统一使用dwz的loadUrl()方法,不能使用jquery自带的load().
当客户端调用loadUrl()并且session超时了,跳转到登陆页面或者弹出登录dialog。
session超时弹出登录dialog注意事项:
用一个带屏蔽层的dialog覆盖的整个浏览器.这时浏览器窗口内容不能变,只是上面加了一个登录框和一个背景层。
当用户输入username and password登录成功后,去掉登录框和背景层.这时用户可以继续操作.
登录失败alert出错信息,浏览器窗口内容还是不变.
参考dwz.core.js代码片段
- loadUrl:function(url,data,callback){
- var$this=$(this);
- $.ajax({
- type:'POST',
- url:url,
- cache:false,
- data:data,
- success:function(response){
- varjson=DWZ.jsonEval(response);
- if(json.statusCode==DWZ.statusCode.timeout){
- alertMsg.error(DWZ.msg("sessionTimout"),{okCall:function(){
- DWZ.loadLogin();
- }});
- }if(json.statusCode==DWZ.statusCode.error){
- if(json.message)alertMsg.error(json.message);
- }else{
- $this.html(response).initUI();
- if($.isFunction(callback))callback(response);
- }
- },
- error:DWZ.ajaxError
- });
- }
ajax post 表单数据处理:
当客户端ajax提交表单超原理同ajax load
参考dwz.core.js代码片段
- ajaxDone:function(json){
- if(json.statusCode==DWZ.statusCode.error){
- if(json.message&&alertMsg)alertMsg.error(json.message);
- }elseif(json.statusCode==DWZ.statusCode.timeout){
- if(json.message&&alertMsg)alertMsg.error(json.message,{okCall:DWZ.loadLogin});
- elseDWZ.loadLogin();
- }else{
- if(json.message&&alertMsg)alertMsg.correct(json.message);
- };
- }
注意事项:
ajax请求session超时服务器端返回一个json就可以了,其他的就交给dwz js框架来处理,服务器端只要做到ajax请求session超时返回如下json就可以了:
- {"statusCode":"301","message":"SessionTimeout!Pleasere-signin!"}
-
分享到:
相关推荐
Ajax请求session超时处理流程 java服务器端处理: SessionValidateFilter中修改: if (ServerInfo.isAjax(request)) { request.setAttribute("statusCode", 301); request.setAttribute("message", "Session ...
dwz框架实现拦截器 session超时跳转登陆页面 DWZ框架 struts2拦截器 session超时
dwz_jui 1.6.1版本;dwz_jui 最新版本;dwz_jui 1.6.1版本;dwz_jui 最新版本;
dwz开源文件,可以与相应网站对应学习。http://jui.org/
DWZ-JUI 文档和代码
dwz_jui-1.5.0-20150337前端框架
jui 富文本框架使用
史上最全的dwz demo,各种小列子欢迎下载!!!!!!!!
dwzteam_dwz_jui_maste
本资源不含源码 只有数据 详细使用方法 http://blog.csdn.net/kingdtl/article/details/9096361
DWZ富客户端框架(jQuery RIA framework),是中国人自己开发的基于jQuery实现的Ajax RIA开源框架。 DWZ富客户端框架设计目标是简单实用、扩展方便、快速开发、RIA思路、轻量级。
dwzteam-dwz_jui-master.zip
基于jquery的easyui和dwz_jui两套管理界面模板,仅限学习使用
dwz框架 asp.net mvc3;dwz框架 asp.net mvc3;dwz框架 asp.net mvc3
DWZ富客户端框架(jQuery RIA framework), 是中国人自己开发的基于jQuery实现的Ajax RIA开源框架. DWZ基于jQuery可以非常方便的定制特定需求的UI组件, 并以jQuery插件的形式发布.
软件简介:CMSHead是基于ThinkPHP和DWZ(jUI)最新版开发的免费开源的PHPCMS。他目前最大的亮点是插件分享机制(类似于discuz论坛的插件分享)。任何人均可基于CMSHead做一些开发,并且将开发的作品,甚至模板分享给...
dwz - 简单实用国产jQuery UI框架 - DWZ富客户端框架(jUI)
DWZ框架会找到当前请求结果中的那些特别的class和attribute, 并自动关联上相应的js处理事件和效果。 DWZ基于jQuery,可以非常方便的定制特定需求的UI组件, 并以jQuery插件的形式发布出来,如有需要也可做定制化...
dwz框架的文档教程,一步步教你学习使用dwz,一个很优秀的框架,一本很实用的书!
dwz官方例子 开发环境: 1) 数据库:mysql 请修改 src/hibernate_mysql.cfg.xml这个文件的数据库连接 创建数据库dwz4j 导入测试数据:db/dwz4j.sql mysql -u root -p dwz4j < dwz4j.... session超时,弹出登入对话框