一尘不染

如果未收到请求响应,该怎么办?我正在重试

ajax

我提出的问题可能更多是与浏览器相关的问题,但是当我冒险构建Web应用程序时,我也想找到答案。

在我的客户端代码中,我正在$.ajax打电话。该帖子可能需要一段时间才能回复。我看到的是经过一定时间后再次发送请求。

我以为是我的$.ajax电话再次发送了,但是无论我在服务器上看到多少次POST请求,我都只会看到beforeSend一次回调。我相当确定我的代码不会多次发送,因此我认为浏览器会重试吗?

我知道我的服务器在运行Wireshark时收到的请求要多于一次,并且可以多次看到发布请求。所以我的假设是这与HTTP有关吗?即,如果在一定时间内未收到响应,则重新发送请求?

这是我下面的通话示例。

$.ajax({
                    async: false,
                    type: 'POST',
                    url: '<%= url_for('importDevice') %>',
                    data: { device: val },
                    retryLimit: 0,
                    //callback
                    success: function(data) {
                    alert('calling import');
                    if ( data == 'nomaster')
                    {
                            // Display a warning  toast, with a title
                            toastr.warning('You must set the Master Key first!', 'Warning');
                            $.ismasterset = false;
                            //reset the form contents after added
                    } else
                    {
                            $("div#content").html(data);
                    }
                    },
                     beforeSend: function(){
                    alert('in before send');
                    }
            });

这是所有相关的代码,没有使用’retryLimit’,我只是没有从代码中删除它,是的,在我将其放入之前就存在问题。

使用客户端和服务器的输出进行编辑。

好的,我安装了“用于Firefox的Live Http标头”。

在“生成器”标签中,我看到一个电话

'#request# POST http://testhost/importdevice'

我没有POST在“标题”部分看到,也许那是因为没有回应?

在我的网络服务器中,虽然我看到2个电话间隔约22秒。

[Sun Jan 13 03:08:45 2013] [debug] POST /importdevice (Mozilla/5.0 (Macintosh; Intel Mac OS X 10.8; rv:17.0) Gecko/20100101 Firefox/17.0).

[Sun Jan 13 03:09:07 2013] [debug] POST /importdevice (Mozilla/5.0 (Macintosh; Intel Mac OS X 10.8; rv:17.0) Gecko/20100101 Firefox/17.0).

我也可以在Wireshark中看到这些相同的呼叫…

这就是为什么我要问这是否是正常行为,如果响应没有返回,则尝试重新发送请求,其方式类似于TCP握手和SYN重传。

新更新

它与我的Ajax调用似乎没有任何关系。如果我创建一个带有简单HREF的按钮。

<a href="/importdevice?device=serverA" class="btn btn-success">TestDirect</a>

然后,在我的“ Live HTTP标头”输出中,我得到了一个实例。

#request# GET http://172.16.118.15/importdevice?device=serverA

但是我的服务器日志再次出现。

[Sun Jan 13 03:20:25 2013] [debug] GET /importdevice (Mozilla/5.0 (Macintosh; Intel Mac OS  X 10.8; rv:17.0) Gecko/20100101 Firefox/17.0).
[Sun Jan 13 03:20:48 2013] [debug] GET /importdevice (Mozilla/5.0 (Macintosh; Intel Mac OS X 10.8; rv:17.0) Gecko/20100101 Firefox/17.0).

在服务器上的Wireshark中,我看到它的次数也增加了两倍……正如预期的那样,我的服务器代码也被调用了两次……这确实让我感到困惑。


阅读 511

收藏
2020-07-26

共1个答案

一尘不染

查看此博客文章,它解释了正在发生的事情:http :
//geek.starbean.net/ ?p=
393

根据HTTP / 1.1 RFC8.2.4

如果HTTP / 1.1客户端发送的请求包含请求主体,但不包含带有“
100-continue”期望的Expect请求标头字段,并且客户端未直接连接到HTTP /
1.1源服务器,并且如果客户端在收到来自服务器的任何状态之前看到连接已关闭,则客户端应重试该请求。

确保您设计的Web应用程序可以承受这些额外的请求。而且,如果您希望ajax请求仅执行一次操作(例如,向数据库写入内容),则需要将请求设计为幂等。

另外,这也突出显示了GET和POST操作之间的区别:http
:
//www.cs.tut.fi/~jkorpela/forms/methods.html

作为一般的设计实践: -GET操作应 设计为幂等的 -POST操作应用于写入数据库等。

2020-07-26