• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >AJAX > ajax提交 session失效

ajax提交 session失效

作者:wangchunmeix的专栏 字体:[增加 减小] 来源:互联网 时间:2017-08-21

wangchunmeix的专栏通过本文主要向大家介绍了ajax session超时等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

function  turndown(){

art.dialog.open("regist/toturndown",{

width: 400,
height: 320,
title: "驳回申请",
lock: true,
drag: false,

   ok: function (iframeWin, topWin) {

                         var paramObj = new Object();
    paramObj.source_code = source_code;
    paramObj.verify_status = "03";
    paramObj.reject_reason = reject_reason;
    $.ajax({
type : 'post',
url : 'regist/savecheck',
data : paramObj,
dataType : 'json',
cache : false,
success : function(result) {
if (JSON.parse(result).success== true) {
alertBox({content: "驳回申请成功", width: 320, height: 120, lock: true, drag: false, ok: function(){
location.href="<%=basePath%>regist/verifycheck"; 
}});
   
} else {
alertBox({content: "驳回申请失败", width: 320, height: 120, lock: true, drag: false, ok: true});
}  
},
error:function(){
alertBox({content: "请求服务器失败", width: 320, height: 120, lock: true, drag: false, ok: true});
}
}) --%>
   },
   cancel: true
});   
}

}

 

以上是我的代码,

错误现象:当调用方法的turndown(),dialog弹出框的页面没有加载出来,直接跳转登录页面(因为后台校验了session是否为空,判断超时),而当dialog.open调用到后台的时候session已经超时了(不是很懂,还没执行到ajax提交就产生session超时,而事实证明确实是$.ajax引起的。)

解决办法:先是按照我的怀疑去定位代码,即使没有弹出框,直接使用ajax请求就会出现session超时,所以我判断和ajax有关,然后我百度查询换成ajax的原生写法,代码如下

art.dialog.open("regist/toturndown",{
width: 400,
height: 320,
title: "驳回申请",
lock: true,
drag: false,
   ok: function (iframeWin, topWin) {
    //获取驳回原因
    var reject_reason = iframeWin.document.getElementById('reject_reason').value; 
    if(reject_reason==null || reject_reason==""){
    alertBox({content: "请填写驳回原因", width: 320, height: 120, lock: true, drag: false, ok: true});
       return false;
    }
    var req = createXMLHTTPRequest();  
       if(req){  
           req.open("POST", "regist/savecheck", true);  
           req.setRequestHeader("Content-Type","application/x-www-form-urlencoded; charset=gbk;");     
           req.send("source_code="+source_code+"&verify_status=03&reject_reason="+reject_reason);  
           req.onreadystatechange = function(){  
               if(req.readyState == 4){  
                   if(req.status == 200){  
                       var result=req.responseText;
                       data=eval(result);
                       if (JSON.parse(data).success== true) {
alertBox({content: "驳回申请成功", width: 320, height: 120, lock: true, drag: false, ok: function(){
location.href="<%=basePath%>regist/verifycheck"; 
}});
   
} else {
alertBox({content: "驳回申请失败", width: 320, height: 120, lock: true, drag: false, ok: true});
} 
                   }else{  
                    alertBox({content: "请求服务器失败", width: 320, height: 120, lock: true, drag: false, ok: true});
                   }  
               }  
           }  
       }  
    <%--
    var paramObj = new Object();
    paramObj.source_code = source_code;
    paramObj.verify_status = "03";
    paramObj.reject_reason = reject_reason;
    $.ajax({
type : 'post',
url : 'regist/savecheck',
data : paramObj,
dataType : 'json',
cache : false,
success : function(result) {
if (JSON.parse(result).success== true) {
alertBox({content: "驳回申请成功", width: 320, height: 120, lock: true, drag: false, ok: function(){
location.href="<%=basePath%>regist/verifycheck"; 
}});
   
} else {
alertBox({content: "驳回申请失败", width: 320, height: 120, lock: true, drag: false, ok: true});
}  
},
error:function(){
alertBox({content: "请求服务器失败", width: 320, height: 120, lock: true, drag: false, ok: true});
}
}) --%>
   },
   cancel: true
});   
}

 

然后就不会出现session超时,特别提示 req.setRequestHeader("Content-Type","application/x-www-form-urlencoded; charset=gbk;");     (我尝试注解掉,但是报错,所以这这句话是重点。)

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

相关文章

  • 2017-05-11javascript ajax类AJAXRequest2007-12-31 更新
  • 2017-05-11$.ajax传JSON数据到后台的注意事项小结
  • 2017-05-11ajax实现的提交文章前进行敏感词审核的代码
  • 2017-05-11Jquery具体实例介绍AJAX何时用,AJAX应该在什么地方用
  • 2017-05-11使用Jquery+Ajax+Json如何实现分页显示附JAVA+JQuery实现异步分页
  • 2017-05-11springmvc 发送ajax出现中文乱码的解决方法汇总
  • 2017-05-11用javascript实现页面无刷新更新数据
  • 2017-05-11AJAX实现瀑布流布局
  • 2017-05-11Ajax验证用户名实例代码
  • 2017-05-11ajax的 responseXML返回接受 asp

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • 一个方便AJAX开发的通用类
    • Ajax教程实例详解
    • Ajax校验是否重复的实现代码
    • Ajax获得站点文件内容实例
    • jquery1.8版本使用ajax实现微信调用出现的问题分析及解决办法
    • Ajax和$.ajax使用实例详解(推荐)
    • AJAXRequest v0.2
    • 完美解决ajax跨域请求下parsererror的错误
    • 国内首发 -- ajax完整功能框架
    • PPJOKE 0.1 (网页嵌入聊天)提供下载

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有