zoukankan      html  css  js  c++  java
  • C# 操作超时正常还是错

    net(客户端)调用IIS(服务端)出现503后,就报操作超时错误

    问题描述:
    服务端环境:
    IIS

    客户端环境:
    windowsxp + iis + .net

    调用时出现如下错误:
    System.Net.WebException: 远程服务器返回错误: (503) 服务器不可用。
       在 System.Net.HttpWebRequest.GetResponse()
       在 TestWebRequest.WebMessage.SendRequest(Byte[] data, String urlStr)

    接着就出现如下错误:

    System.Net.WebException: 操作超时
       在 System.Net.HttpWebRequest.GetRequestStream()

    最后一直是这个错误

    System.Net.WebException: 操作超时
       在 System.Net.HttpWebRequest.GetRequestStream()

     当服务器恢复正常时,访问已经是200时,这个线程还是返回操作超时,经过N多测试,最后如下一行完美解决:

    myRequest.ServicePoint.Expect100Continue = false;

     修改后的方法为:


     1 public byte[] SendRequest(byte[] data, string urlStr)
     2        {
     3            try
     4            {
     5                Stream streamSend = null;
     6                HttpWebRequest myRequest = (HttpWebRequest)WebRequest.Create(urlStr);
     7                myRequest.Method = "POST";
     8                myRequest.ContentType = "text/xml";
     9                myRequest.Accept = "*/*";
    10                myRequest.Timeout = 2000;
    11                myRequest.UserAgent = "Mozilla-Firefox-Spider(Wenanry)";
    12                myRequest.ContentLength = data.Length;
    13                //这个在Post的时候,一定要加上,如果服务器返回错误,他还会继续再去请求,不会使用之前的错误数据,做返回数据
    14                myRequest.ServicePoint.Expect100Continue = false;
    15
    16                HttpRequestCachePolicy noCachePolicy = new HttpRequestCachePolicy(HttpRequestCacheLevel.NoCacheNoStore);
    17                myRequest.CachePolicy = noCachePolicy;
    18
    19                try
    20                {
    21                    streamSend = myRequest.GetRequestStream();
    22                    streamSend.Write(data, 0, data.Length);
    23                    streamSend.Close();
    24                }

    25                catch (WebException wex)
    26                {
    27                    log.Debug("WebException=" + wex.ToString() + ",wex.Status=" + wex.Status);
    28                    if (streamSend != null)
    29                        streamSend.Close();
    30                    streamSend = null;
    31                    myRequest = null;
    32                    return null;
    33                }

    34                catch (Exception ex)
    35                {
    36                    log.Debug("GetRequestStream=" + ex.ToString());
    37                    if (streamSend != null)
    38                        streamSend.Close();
    39                    myRequest = null;
    40                    return null;
    41                }

    42
    43                byte[] byteArr = new byte[256];
    44                Stream streamRequest = null;
    45                try
    46                {
    47                    streamRequest = myRequest.GetResponse().GetResponseStream();
    48                }

    49                catch (Exception httpex)
    50                {
    51                    log.Debug("SendRequest=" + httpex.ToString());
    52                    if (streamRequest != null)
    53                        streamRequest.Close();
    54                    myRequest = null;
    55                    return null;
    56                }

    57                Bytes bytes = new Bytes();
    58                int count = streamRequest.Read(byteArr, 0256);
    59                while (count > 0)
    60                {
    61                    bytes.writeByteArr(Bytes.byteSub(byteArr, 0, count));
    62                    count = streamRequest.Read(byteArr, 0256);
    63                }

    64                streamRequest.Close();
    65                return bytes.getByte;
    66            }

    67            catch (Exception eee)
    68            {
    69                log.Debug("eee=" + eee.ToString() + eee.Source + eee.StackTrace);
    70            }

    71            return null;
    72        }

    太晚了,睡觉。 

  • 相关阅读:
    【唯星宠物】——CSS/BootStrap/Jquery爬坑之响应式首页
    【可用性评估】——手机输入法可用性评估·论文
    一个简单示例看懂.Net 并行编程
    CentOS 7.1上安装.Net Core
    用 QGIS 画矢量交通路线图
    工作流服务实战
    JVM调优总结
    内存调优
    ConcurrentHashMap原理分析
    Mac上安装go环境
  • 原文地址:https://www.cnblogs.com/wangchuang/p/3664131.html
Copyright © 2011-2022 走看看