jfinal框架中ajax提交返回类型datatype不确定时。。。

原创 2015年07月08日 14:43:52

遇到的问题:
- jfinal框架下,ajax提交表单后,后台会返回不同的text信息,前台会根据这些不同的text值来做不同的处理,比如页面跳转或者alert相关信息,这时候$.ajax的dataType无疑是text;
ajax提交代码:

$(this).ajaxSubmit({
        url:'${cxt}/ab/bulkImport',
        resetForm: false,  
        dataType:  'text',
        success: function (data) { 
               if('success'==data){
                   alert("企业联系人导入成功!");
                   window.location.href='${cxt}/ab/getAddressBookAll';
               }else{
                    alert(data);
                    return false;
                  }
           },
           error: function (XMLHttpRequest, textStatus, errorThrown) {
            $.messager.confirm("操作提示", XMLHttpRequest.responseText, function (data) {
                   if (data) {
                    window.location.href='${cxt}/ab/getAddressBookAll';
                   } else {
                    window.location.href='${cxt}/ab/getAddressBookAll';
                   }
               });
        }
 });

拦截器代码:

public void intercept(ActionInvocation ai) {
        Controller controller = (Controller) ai.getController();
        if("/user".equals(ai.getControllerKey())&&"login".equals(ai.getMethodName())
        ){
            ai.invoke();
        }else{
            Admin admin = (Admin)controller.getSessionAttr("user");
            if(admin!=null){
                ai.invoke();
            }else{
                controller.render("/timeout.jsp");
           }
        }
    }
  • 但存在另外一种情况,就是后台程序处理前会有一个拦截器,用来判断当前session是否已经过期,而一旦过期,程序会跳转到一个timeout.jsp,是一个画面,这时候如果dataType仍然是text,那么页面不刷新,也不解析,则alert出来的就是整个jsp的源码了,显然是不正确的。
    timeout.jsp源码:
<%@ page language="java" contentType="text/html; charset=utf-8"
    pageEncoding="utf-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<link rel="StyleSheet"type="text/css" href="${cxt}/css/layout.css"  />
    <script type="text/javascript">
    function reset(){
        window.parent.location.href="${cxt}/login.jsp";
    }
    </script>
</head>
<body>
    <div class="timeout_text">
   您已经退出登录或者登录超时,请您重新登录。<input type="button"  class="btn_reset"  value="重新登录" onclick="reset()" />
    </div>
</body>
</html>
  • 另外整个程序又不全是ajax提交的,也有一些正常的form提交的,当是正常的form提交的情况下,拦截器却应该是render到一个jsp的。
    那么如何处理最好呢?

  • 正常的思维就是拦截能够区别是form提交还是ajax提交,然后如果是ajax提交,则返回给前台一个text值,如果是form提交,则直接 render到timeout.jsp。

  • 这样,只要再ajax提交中增加一个else if判断,如果是session超时返回则直接跳转到timeout.jsp。
  • 如此便解决了问题。
    ajax提交代码:
$(this).ajaxSubmit({
        url:'${cxt}/ab/bulkImport',
        resetForm: false,  
        dataType:  'text',
        success: function (data) { 
               if('success'==data){
                   alert("企业联系人导入成功!");
                   window.location.href='${cxt}/ab/getAddressBookAll';
               //添加session超时分支
               }else if ('timeout'==data) {
                   window.location.href='${cxt}/timeout.jsp';
               }else{
                    alert(data);
                    return false;
                }
           },
           error: function (XMLHttpRequest, textStatus, errorThrown) {
            $.messager.confirm("操作提示", XMLHttpRequest.responseText, function (data) {
                   if (data) {
                    window.location.href='${cxt}/ab/getAddressBookAll';
                   } else {
                    window.location.href='${cxt}/ab/getAddressBookAll';
                   }
               });
        }
 });

拦截器代码:

public void intercept(ActionInvocation ai) {
        Controller controller = (Controller) ai.getController();
        if("/user".equals(ai.getControllerKey())&&"login".equals(ai.getMethodName())
        ){
            ai.invoke();
        }else{
            Admin admin = (Admin)controller.getSessionAttr("user");
            if(admin!=null){
                ai.invoke();
            }else{
                //取得请求类型
                String requestType = controller.getRequest().getHeader("X-Requested-With");
                //如果是ajax提交,则返回text文本:timeout
                if("XMLHttpRequest".equals(requestType)){
                    controller.renderText("timeout");
                //如果是form提交,则返回jsp
                }else{
                    controller.render("/timeout.jsp");
                } 
           }
        }
    }

Jfinal框架搭建JSP项目Demo

  • 2015年04月21日 17:42
  • 6.86MB
  • 下载

使用JFinal框架中Validator

Validator是JFinal框架中的校验组件,在Validator类中提供了我们常用的校验方法,而Validator本身实现了Interceptor接口,所以Validator也相当于一个拦截器,...

jfinal框架的使用

  • 2016年04月20日 11:38
  • 4.8MB
  • 下载

jfinal框架问题小结

jfinal框架问题小结  问题1:页面访问404报错 原因:1访问路径不对,或者是路径配置不对 解决方法:1检查配置文件配置的路径是否正确,同时检查配置文件配置的方法里面渲染的页面名字是否...

jfinal框架

  • 2017年06月07日 17:33
  • 2.33MB
  • 下载

jfinal框架搭建

  • 2017年03月22日 10:34
  • 15.71MB
  • 下载

Jfinal框架下结合ajaxFileupload实现多文件上传

距离写代码时间有点长了,没有及时总结,现在忘得差不多了。不过大概思路还在,也是有点参考价值的! demo下载 思路: 由于jfinal框架自身的问题,在实现多文件上传时很难获取所有文件的...
  • JodenHe
  • JodenHe
  • 2017年02月09日 11:37
  • 12391

Jfinal框架

  • 2014年11月24日 13:55
  • 5.41MB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:jfinal框架中ajax提交返回类型datatype不确定时。。。
举报原因:
原因补充:

(最多只允许输入30个字)