• 软件测试技术
  • 软件测试博客
  • 软件测试视频
  • 开源软件测试技术
  • 软件测试论坛
  • 软件测试沙龙
  • 软件测试资料下载
  • 软件测试杂志
  • 软件测试人才招聘
    暂时没有公告

字号: | 推荐给好友 上一篇 | 下一篇

为ServerXMLHTTP对象的HTTP请求设置超时时间

发布: 2007-7-01 21:48 | 作者: admin | 来源: | 查看: 19次 | 进入软件测试论坛讨论

领测软件测试网

ServerXMLHTTP对象的HTTP请求设置超时时间

Article last modified on 2002-3-2

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

The information in this article applies to:

  - Microsoft XML 3.0

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

如果用ServerXMLHTTP(SXH)对象向另一个ASP页面或者Inte.net资源发起HTTP请求,建议设置一下超时限制。

既可以异步提交这种HTTP请求,也可以通过同步操作时调用setTimeouts方法做到这一点。

setTimeouts的各项参数为:

HRESULT setTimeouts (long resolveTimeout, long connectTimeout,

long sendTimeout, long receiveTimeout)

这些参数分别指定了解析DNS名字、建立socket连接、发送Request Data和接收Response Data的超时时间。

    如果不指定超时,那么假如客户端同步发送数据给服务器,而服务器却挂起了这个请求,这样,要么客户端等待5分钟后发生send超时,要么等待一小时后发生receive超时。在这段时间内,客户端表现为Hang。

经常会被问的一个问题是,我如何把这种超时失败同其他错误区分开来?

是这个样子,如果有一个时间超时的错误发生,就会引发一个COM异常:

0x80072ee2 "The operation timed out"

 

附录A中给出一个简单的VB DEMO。如果服务器的RS.asp中执行一句话:Sleep(15000),肯定会send超时,于是异常就被捕获到了。这时的对话框如下所示:

-2147012894就是0x80072EE2的错误。

 

SXH的open方法其实并不作任何network I/O,它只是初始化一下SXH对象的一些内部状态。所有“Real”的工作是在send方法中作的(如果这次的请求是同步的),setTimeouts中设置的超时值也将应用在这里。

send方法解析DNS名字,同服务器建立连接,发送request,等待reponse和读response data入内存。每个超时可能会被应用好多次。比如,如果response较大,SXH将需要调用多次Winsock receive来load response,这时receive超时将被应用到每一个Winsock receive调用上。

附录A:

   #If Win32 Then

      Declare Function GetTickCount Lib "kernel32" () As Long

   #Else

      Declare Function GetTickCount Lib "User" () As Long

   #End If

 

Private Sub Command1_Click()

    On Error Resume Next

    Dim objClient As MSXML2.ServerXMLHTTP

    Dim lngStartTime As Long

    Dim lngFinnishTime As Long

    Dim lngOpenTime As Long

    Dim lngSendTime As Long

    Dim lngRespTime As Long

    Dim strMessage As String

   

    Set objClient = New MSXML2.ServerXMLHTTP

   

    txtOpen.Text = ""

    txtSend.Text = ""

    txtResponse.Text = ""

 

    objClient.setTimeouts 650, 650, 650, 650

 

    lngStartTime = GetTickCount()

   objClient.open "GET", "http://localhost:80/asp/rs.asp", False

   

    ´ no failure here - the operation succeeds in 0 ms

    lngFinnishTime = GetTickCount()

    lngOpenTime = lngFinnishTime - lngStartTime

    strMessage = CStr(lngOpenTime)

   

    If Err.Number <> 0 Then

        strMessage = strMessage & ": " & Err.Description

        Err.Clear

    End If

   

    txtOpen.Text = strMessage

    lngStartTime = GetTickCount()

   

    objClient.send ´ this is the operation that times out.

   

    lngFinnishTime = GetTickCount()

    lngSendTime = lngFinnishTime - lngStartTime

    strMessage = CStr(lngSendTime)

   

    If Err.Number <> 0 Then

        strMessage = strMessage & ":ErrNumber-" & _

                     Err.Number & "|ErrDescription-" & Err.Description

        Err.Clear

    End If

   

    txtSend.Text = strMessage

    ´ this value is set to 672ms appended to a timeout error message

    ´ example: "672: The operation timed out"

   

   

    Dim respDom As MSXML2.DOMDocument

    lngStartTime = GetTickCount()

   

    Set respDom = objClient.responseXML

   ´ no failure here - the operation succeeds in 0 ms

    lngFinnishTime = GetTickCount()

    lngRespTime = lngFinnishTime - lngStartTime

    strMessage = CStr(lngRespTime)

    If Err.Number <> 0 Then

        strMessage = strMessage & ": " & Err.Description

        Err.Clear

    End If

    txtResponse.Text = strMessage

    Set objClient = Nothing

    Exit Sub

ERR_HANDLER:

    MsgBox Err.Description

 

End Sub

附录B:下面我们给出常见的SXH对象的错误码及其解释: 0x80004005  Unspecified error0x8000FFFF  Unexpected error0x80070008  Out of memory0x8007000E  Out of memory
0x80072ee1  Cannot create any more ServerXMLHTTP objects (cannot exceed 5460 concurrent objects per process)0x80072ee2  The operation timed out0x80072ee4  internal error0x80072ee5  The URL is invalid0x80072ee7  The server name or address could not be resolved0x80072eee  incorrect password0x80072eef  authentication failure (credentials not accepted)0x80072efd  A connection with the server could not be established0x80072efe  connection aborted0x80072eff  connection reset0x80072f05  The date in the certificate is invalid or has expired0x80072f06  The host name in the certificate is invalid or does not match0x80072f07  A redirect request will change a non-secure to a secure connection0x80072f08  A redirect request will change a secure to a non-secure connection0x80072f0c  A certificate is required to complete client authentication0x80072f0d  The certificate authority is invalid or incorrect0x80072f0e  Client authentication has not been correctly installed0x80072f76  The requested header was not found0x80072f78  The server returned an invalid or unrecognized response0x80072f7a  The request for a HTTP header is invalid0x80072f7c  The HTTP redirect request failed0x80072f7d  An error occurred in the secure channel support0x80072f80  The HTTP request was not redirected0x80072f82  A cookie from the server has been declined acceptance0x80072f88  The HTTP redirect request must be confirmed by the user

0x80072f89  The server certificate was invalid

 


延伸阅读

文章来源于领测软件测试网 https://www.ltesting.net/


关于领测软件测试网 | 领测软件测试网合作伙伴 | 广告服务 | 投稿指南 | 联系我们 | 网站地图 | 友情链接
版权所有(C) 2003-2010 TestAge(领测软件测试网)|领测国际科技(北京)有限公司|软件测试工程师培训网 All Rights Reserved
北京市海淀区中关村南大街9号北京理工科技大厦1402室 京ICP备2023014753号-2
技术支持和业务联系:info@testage.com.cn 电话:010-51297073

软件测试 | 领测国际ISTQBISTQB官网TMMiTMMi认证国际软件测试工程师认证领测软件测试网