Ajax请求ashx页面疑问

licai1210 2012-09-12 05:10:52
前台代码

<head>
<script src="../JS/jquery-1.7.2.min.js" type="text/javascript"></script>
</head>
<body>
<script type="text/javascript">
$.ajax({
type: "POST",
url: "Demo.ashx",
dataType: "text",
async: true,
cache: false,
data: { name: 'test' },
success: function(data) {
},
error: function(XMLHttpRequest, textStatus, errorThrown) {
alert('当你狂刷新页面的时候就弹出来了');
}
});
</script>
</body>
</html>

后台代码

<%@ WebHandler Language="C#" Class="Demo" %>

using System;
using System.Web;

public class Demo : IHttpHandler
{
public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/plain";
context.Response.Write("1");
}

public bool IsReusable
{
get
{
return false;
}
}
}


问题描述:我在用AJAX请求ASHX页面的时候请求有时候成功,有时候失败。同样的代码请求aspx页面或者asmx文件里面就不会出现这个问题。我想问下,这是ashx的一个bug吗?当错误出现的时候返回了12030状态码。当然去掉data属性或者把post修改为get等方式也是可以解决这个问题的。微软官网虽然有12030相关的资料,但是并没有给出解决的办法。难道是ashx本身的机制问题吗?求帮忙,谢谢!
...全文
939 26 打赏 收藏 转发到动态 举报
写回复
用AI写文章
26 条回复
切换为时间正序
请发表友善的回复…
发表回复
naijuy 2012-12-18
  • 打赏
  • 举报
回复
我试了,没弹???
st_gloden 2012-11-29
  • 打赏
  • 举报
回复
前台代码如下:
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WebForm1.aspx.cs" Inherits="CallBackAndPostBack.WebForm1" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
    <script src="Scripts/jquery-1.4.1.js" type="text/javascript"></script>
    <script type="text/javascript">
        $(function () {
            $.ajax({
                type: "POST",
                url: "Handler1.ashx",
                async: true,
                cache: false,
                data: { name:'name'},
                success: function (data) {
                    alert(data);
                },
                error: function (XMLHttpRequest, textStatus, errorThrown) {
                    alert('当你狂刷新页面的时候就弹出来了');
                }
            });

        });
     
    </script>
</head>
<body>
    <form id="form1" runat="server">
    <div>
    </div>
    </form>
</body>
</html>
后台代码如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;

namespace CallBackAndPostBack
{
    /// <summary>
    /// Summary description for Handler1
    /// </summary>
    public class Handler1 : IHttpHandler
    {

        public void ProcessRequest(HttpContext context)
        {
            context.Response.ContentType = "text/plain";
           string _name= context.Request["name"].ToString();
            context.Response.Write("Hello World"+_name);
        }

        public bool IsReusable
        {
            get
            {
                return false;
            }
        }
    }
}



这样的刷到死都不会报错呀 ,但是原因在哪里这个我还没有找出来。


licai1210 2012-09-14
  • 打赏
  • 举报
回复
大牛在哪里
  • 打赏
  • 举报
回复
经测试,错误时返回 12301 Unkonwn Undefined 坐等解释.关注一下
licai1210 2012-09-13
  • 打赏
  • 举报
回复
[Quote=引用 6 楼 的回复:]
你看看
error: function(XMLHttpRequest, textStatus, errorThrown) {
alert(XMLHttpRequest.statusText)是什么
alert(errorThrown)是什么
[/Quote]

alert(XMLHttpRequest.statusText)这里是""
alert(errorThrown)这里是unKownm
状态码是12030

可以确定的是服务器是write了数据,但是客户端没有接收到。而且在刷新的时候有时候300-500都不报错,有时候就刷新几次就报错了,网上说法是不稳定网络导致。但是为什么在aspx、asmx中不会出现这个问题,希望孟大哥指点下
孟子E章 2012-09-13
  • 打赏
  • 举报
回复
你看看
error: function(XMLHttpRequest, textStatus, errorThrown) {
alert(XMLHttpRequest.statusText)是什么
alert(errorThrown)是什么

我就是大神 2012-09-13
  • 打赏
  • 举报
回复
不明真相的群众路过
licai1210 2012-09-13
  • 打赏
  • 举报
回复
[Quote=引用 22 楼 的回复:]
如果单从异步方式来讲,肯定是不全面的,因为本身AJAX的提交可以修改同步,异步方式,而且再GET下是没有问题的

于是,我突然想到一个问题,在处理程序中没有接受Post过去的值,可能引发此问题

C# code
context.Response.ContentType = "text/plain";
string ss = context.Request.Par……
[/Quote]
先谢谢你耐心的回复,我按照你给的方法,问题还是出现了。只是可能出现的几率小了点,你刷新的不够快不够多,所以可能觉得问题没出现了

  • 打赏
  • 举报
回复
如果单从异步方式来讲,肯定是不全面的,因为本身AJAX的提交可以修改同步,异步方式,而且再GET下是没有问题的

于是,我突然想到一个问题,在处理程序中没有接受Post过去的值,可能引发此问题
context.Response.ContentType = "text/plain";
string ss = context.Request.Params["name"];//接受一下提交值
context.Response.Write("1");


LZ可以试试,应该没什么问题,但是究竟是什么原因,不明.
bo3235 2012-09-13
  • 打赏
  • 举报
回复
[Quote=引用 20 楼 的回复:]
方案1:我在问题的描述中已经提到了,你可以看下我的描述。
方案2:可能并没有从正面回答为什么的IHttpHandler接口会出现错误,因为问题是间断的出现

不过还是谢谢你.
[/Quote]


直接用 IHttpHandler,是无法判断请求来源是post还是get方式,12030错误是

No response headers received because request failed : ERROR_INTERNET_CONNECTION_ABORTED【连接退出提示】

IHttpHandler的解释为: 定义 ASP.NET 为使用自定义 HTTP 处理程序同步处理 HTTP Web 请求而实现的协定。
IHttpAsyncHandler 的解释为:定义 HTTP 异步处理程序对象必须实现的协定。

既然是同步,ajax反应有时间差,请求时候会堵塞下一个请求。从Http链接的建立到数据发送到客户端的整个过程都是连续的。

所以,快速连刷的情况下 需要实现 IHttpAsyncHandler异步接口.

以上个人理解,有不足之处还请指正。

licai1210 2012-09-13
  • 打赏
  • 举报
回复
[Quote=引用 19 楼 的回复:]
如果不报异常的方案如下


方案一:

JScript code

POST 修改成 GET



方案二:服务器端修改

实现如下的接口:
Demo : IHttpAsyncHandler

注:IHttpAsyncHandler 的方法实现后即可达到效果。


具体原理解释,还请自己去琢磨吧。
[/Quote]
方案1:我在问题的描述中已经提到了,你可以看下我的描述。
方案2:可能并没有从正面回答为什么的IHttpHandler接口会出现错误,因为问题是间断的出现

不过还是谢谢你.
bo3235 2012-09-13
  • 打赏
  • 举报
回复
如果不报异常的方案如下


方案一:

POST 修改成 GET


方案二:服务器端修改

实现如下的接口:
Demo : IHttpAsyncHandler

注:IHttpAsyncHandler 的方法实现后即可达到效果。


具体原理解释,还请自己去琢磨吧。
cloudapex 2012-09-13
  • 打赏
  • 举报
回复
是否其它地址有冲突导致的,代码没错啊
licai1210 2012-09-13
  • 打赏
  • 举报
回复
[Quote=引用 16 楼 的回复:]
这个问题很简单,应该是jquery对http的解析有问题 ashx返回的文件header部分是比较特殊的

POST -》 GET 修改后就ok了
[/Quote]
请麻烦看我的描述中已经提到了这中方法
bo3235 2012-09-13
  • 打赏
  • 举报
回复
这个问题很简单,应该是jquery对http的解析有问题 ashx返回的文件header部分是比较特殊的

POST -》 GET 修改后就ok了


licai1210 2012-09-13
  • 打赏
  • 举报
回复
[Quote=引用 14 楼 的回复:]
我当时碰到的问题跟你一样 后来就是data传值写法不一样 你可以试试先

引用 2 楼 的回复:

引用 1 楼 的回复:
JScript code

data: { "val1": v1, "val2": v2 }, //注意!!!ASHX和WebService传data格式不同!!这是WS的 data: "{val1:'" + v1 + "',val2:'" + v2 + "'}……
[/Quote]
问题依旧存在
二当家 2012-09-13
  • 打赏
  • 举报
回复
我当时碰到的问题跟你一样 后来就是data传值写法不一样 你可以试试先
[Quote=引用 2 楼 的回复:]

引用 1 楼 的回复:
JScript code

data: { "val1": v1, "val2": v2 }, //注意!!!ASHX和WebService传data格式不同!!这是WS的 data: "{val1:'" + v1 + "',val2:'" + v2 + "'}",


引号问题 你试试

谢谢你的回答,不是引号问题。你可以测试下就可以看到效果了
[/Quote]
licai1210 2012-09-13
  • 打赏
  • 举报
回复
[Quote=引用 12 楼 的回复:]
HTML code


<head>
<script src="../JS/jquery-1.7.2.min.js" type="text/javascript"></script>
</head>
<body>
<script type="text/javascript">
$.ajax({
type: "POST",
……
[/Quote]
描述里面提到过了:去掉data属性是没问题的,我现在就是想加上data属性,又不为空的情况下测试。你测试看下结果就明白了
ivmyzj 2012-09-13
  • 打赏
  • 举报
回复


<head>
<script src="../JS/jquery-1.7.2.min.js" type="text/javascript"></script>
</head>
<body>
<script type="text/javascript">
$.ajax({
type: "POST",
url: "Demo.ashx?name=test",
dataType: "text",
async: true,
cache: false,
success: function(data) {
},
error: function(XMLHttpRequest, textStatus, errorThrown) {
alert('当你狂刷新页面的时候就弹出来了');
}
});
</script>
</body>
</html>

ivmyzj 2012-09-13
  • 打赏
  • 举报
回复
快速解决方案就是用post传参~
直接用?a=1&b=2&c=3
加载更多回复(6)

62,074

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧