2009-11-29 64 views
0

我有以下的功能,使用HTTPS请求意外EOF

public WebResponse SendXmlPost(string url, string xml) 
{ 
    HttpWebRequest request = (HttpWebRequest)WebRequest.Create(url); 
    request.KeepAlive = false; 
    request.ProtocolVersion = HttpVersion.Version11; 
    request.Method = "POST"; 

    if (this.UseBasicAuthentication) 
    { 
     string usernamePassword = this.Login + ":" + this.Password; 
     request.Headers.Add("Authorization", "Basic " + Convert.ToBase64String(new ASCIIEncoding().GetBytes(usernamePassword))); 
     NetworkCredential cred = new NetworkCredential(this.Login, this.Password); 
     request.Credentials = cred; 
    } 

    if (this.desactivateCertificateChecking) 
    { 
     System.Net.ServicePointManager.ServerCertificateValidationCallback += delegate(object sender, X509Certificate certificate, X509Chain chain, SslPolicyErrors sslPolicyErrors) 
     { 
      return true; 
     }; 
    } 

    byte[] postBytes = Encoding.UTF8.GetBytes(xml); 

    request.ContentType = "text/xml"; 
    request.ContentLength = postBytes.Length; 
    Stream requestStream = request.GetRequestStream(); //error occurs here 

    requestStream.Write(postBytes, 0, postBytes.Length); 
    requestStream.Close(); 

    WebResponse response = request.GetResponse(); 

    return response; 
} 

发送XML当我调用此方法,我已经和“意外EOF”异常:

System.Net.FixedSizeReader.ReadPacket(Byte[] buffer, Int32 offset, Int32 count) +7067555 
    System.Net.Security.SslState.StartReadFrame(Byte[] buffer, Int32 readBytes, AsyncProtocolRequest asyncRequest) +116 
    System.Net.Security.SslState.StartReceiveBlob(Byte[] buffer, AsyncProtocolRequest asyncRequest) +123 
    System.Net.Security.SslState.ForceAuthentication(Boolean receiveFirst, Byte[] buffer, AsyncProtocolRequest asyncRequest) +7243141 
    System.Net.Security.SslState.ProcessAuthentication(LazyAsyncResult lazyResult) +217 
    System.Threading.ExecutionContext.runTryCode(Object userData) +376 

任何线索?

谢谢

回答

0

我认为你的问题是UTF8编码。默认情况下,UTF-8编码添加BOM(ByteOrderMark),并且ContentLength与正在传输的数据不同步。尝试创建一个没有BOM的UTF8编码(使用另一个过载),它应该解决这个问题。

此外,我不会自己添加基本身份验证标头。我只需在请求中设置crdentials,并让HttpWebRequest为我执行身份验证。