`
endual
  • 浏览: 3544647 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

Ajax请求session超时处理流程(DWZ)

    博客分类:
  • java
 
阅读更多
  • 回复:2 浏览:3274 2011-04-12 16:47 来自 zhanghuihua
     

    DWZ-Java框架Ajax请求session超时处理思路:
        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) {
    PrintWriter out
    = response.getWriter();
    out.println({"statusCode":"301", "message":"Session Timeout! Please re-sign in!"});
    } else {
    response.sendRedirect(response.encodeRedirectURL(
    this.loginUrl + java.net.URLEncoder.encode(backToUrl, "UTF-8")));
    }



    -------------------------------------------------------------------

    js客户端处理:

    session超时跳转到登陆页面还是弹出登录dialog,在DWZ UI初始化时设置:

     

    <script type="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){
    var json = 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});
    else DWZ.loadLogin();
    }
    else {
    if(json.message && alertMsg) alertMsg.correct(json.message);
    };
    }

     


    -------------------------------------------------------------------

    注意事项:
        ajax请求session超时服务器端返回一个json就可以了,其他的就交给dwz js框架来处理,服务器端只要做到ajax请求session超时返回如下json就可以了:

    {"statusCode":"301", "message":"Session Timeout! Please re-sign in!"}
  • coreahan
    2013-05-20 20:13 coreahan
    SessionValidateFilter中修改: 这个在哪里啊?
    回复 第1楼 回到顶楼
  • 依旧丶
    2013-08-12 16:29 依旧丶
    服务端:SessionValidateFilter在哪?自己创建一个过滤器吗?request.getHeader 引用的是哪个包呢?为什么不把整个类贴出来?求解啊!
分享到:
评论

相关推荐

    Ajax请求session超时处理流程

    Ajax请求session超时处理流程 java服务器端处理: SessionValidateFilter中修改: if (ServerInfo.isAjax(request)) { request.setAttribute("statusCode", 301); request.setAttribute("message", "Session ...

    dwz框架实现拦截器 session超时跳转登陆页面

    dwz框架实现拦截器 session超时跳转登陆页面 DWZ框架 struts2拦截器 session超时

    DWZ帮助文档 PDF版

    6. Ajax表单处理:DWZ框架中的Ajax表单处理功能包括了普通表单提交、文件上传表单提交、表单查询等功能,简化了表单数据的处理流程。 7. 异步请求处理:DWZ中的dwz.ajax.js组件用于处理Ajax请求,提供了一套简洁的...

    dwz官方例子

    dwz官方例子 开发环境: 1) 数据库:mysql 请修改 src/hibernate_mysql.cfg.xml这个文件的数据库连接 创建数据库dwz4j 导入测试数据:db/dwz4j.sql mysql -u root -p dwz4j &lt; dwz4j.... session超时,弹出登入对话框

    dwz最完整demo

    8. **AJAX加载与缓存**:对页面和数据进行智能缓存,减少网络请求,提高页面响应速度。 9. **Mobile适配**:DWZ也考虑到了移动设备的适配,部分组件和布局支持响应式设计,能够适应不同屏幕尺寸。 在“dwz-demo”...

    dwz与thinkphp结合项目

    通过Ajax请求,前端可以发送数据到后台的控制器,控制器处理后返回结果,更新表格或者提示用户。这种异步交互方式极大地提高了用户的操作效率。 权限管理是企业级应用中的核心部分。DWZ提供了角色权限分配和菜单...

    dwz demo按列

    - **RESTful API**:后端可以提供RESTful服务,供前端DWZ进行Ajax请求,实现数据的获取和提交。 - **数据访问层**:结合Hibernate或MyBatis等持久层框架,处理数据库操作,如CRUD(创建、读取、更新、删除)。 3....

    dwz框架官网实例

    DWZ内置了Ajax处理机制,使得页面无需刷新即可进行数据交互,提高了用户体验。通过AJAX请求,可以轻松实现数据的异步加载、分页、排序等功能。 4. **页面布局** 页面布局是DWZ的一个强项,它支持流式、固定、...

    Spring MVC 3 结合DWZ 框架编写拦截器判断session是否过期

    在本文中,我们将深入探讨如何在Spring MVC 3框架中结合DWZ(Dynamic Web Zone)前端框架,利用拦截器(Interceptor)来判断用户的session是否已经过期。这有助于提高应用程序的安全性和用户体验,防止用户在未登录...

    dwz 解决200错误自定义的函数使用

    `error`属性定义了当AJAX请求出错时的处理函数`DWZ.ajaxError`,这是DWZ框架的一部分,用于统一处理网络请求错误。 ### 三、示例代码分析 在提供的部分代码中,可以看到一个包含`resultId`和`msgId`元素的`form`。...

    dwz.rar_dwz_dwz struts

    4. 用户通过DWZ组件与页面互动,触发AJAX请求,这些请求被Struts拦截并转发到相应的Action。 5. Struts将处理结果返回给DWZ,更新前端展示。 总之,这个“dwz.rar_dwz_dwz struts”压缩包可能包含了一个使用DWZ和...

    DWZ中文开发手册

    DWZ框架内置了对AJAX请求的全面支持,包括表单查询、数据提交以及服务器响应处理。通过使用`dwz.ajax.js`等模块,开发者可以轻松地发送异步请求,处理JSON响应,并更新DOM元素,而无需深入了解底层通信机制。 #### ...

    DWZ文件+文档

    DWZ富客户端框架(jQuery RIA framework), 是中国人自己开发的基于jQuery实现的Ajax RIA开源框架. DWZ富客户端框架设计目标是简单实用、扩展方便、快速开发、RIA思路、轻量级 DWZ框架支持用html扩展的方式来代替...

    dwz学习实例

    DWZ集成了丰富的UI组件、强大的Ajax交互、高效的页面跳转控制和完善的表单处理等功能,使得开发者可以快速地构建出功能齐全、用户体验良好的Web应用程序。 在“dwz学习实例”中,我们可以通过一系列实际操作来深入...

    dwz-demo-1.1.6RC1.zip_DEMO_dwz php_dwz-demo_dwz-ria_php dwz

    5. **学习和实践**:对于初学者来说,通过"dwz-demo"提供的示例,可以学习到如何组织项目结构,如何调用dwz的函数,以及如何处理PHP后端请求,这对于快速掌握dwz框架非常有帮助。 综上,"dwz-demo-1.1.6RC1.zip"是...

    DWZ——国内一款开源框架(JUI)

    - `dwz.ajax.js`:处理Ajax请求的模块。 - `dwz.alertMsg.js`:消息提示组件。 - `dwz.jDialog.js`:对话框组件。 - `dwz.accordion.js`:Accordion组件脚本。 - `dwz.navTab.js`:导航标签页组件。 - `dwz.tree.js`...

    ajax自动刷新页面

    2. **JavaScript事件处理**:在自动刷新页面的应用中,通常会利用JavaScript的定时器(setTimeout或setInterval)来定期触发Ajax请求。当页面加载后,设置一个定时器,每隔一段时间就发送Ajax请求,获取服务器的最新...

    dwz4j-springmvc

    5. **AJAX与JSON**:DWZ通常会结合AJAX技术进行异步数据交互,因此需要了解JSON格式的数据交换以及如何在后台处理AJAX请求。 6. **JSP或HTML模板**:DWZ与SpringMVC结合后,开发者可能会使用JSP作为视图层,需要...

    DWZ+java的简单应用

    在实现过程中,前端发送AJAX请求到后台,后台处理请求后返回JSON数据,前端再利用这些数据动态更新DOM,实现无刷新的用户体验。例如,当用户点击“新增”按钮时,DWZ的JavaScript代码会创建一个弹出窗口并加载表单,...

Global site tag (gtag.js) - Google Analytics