以下は、(実際の URL と資格情報を変更した) サンプル コードです。
ServicePointManager.ServerCertificateValidationCallback += new RemoteCertificateValidationCallback((object s, X509Certificate certificate, X509Chain chain, SslPolicyErrors sslPolicyErrors) => { return true; });
var requestUri = new Uri("https://example.com/path1/path2?var=somevar");
byte[] data = Encoding.UTF8.GetBytes("DEV72*12/27/06*TAYLOR*RICH*JOE*10/28/56*U0999495102*466666666*01*TAYLOR*TAMMY*M*10/26/52***CIGNA HMO*62308*UPIN*MEDICAL CENTER**MESSAGE*M*F*30");
HttpWebRequest request = (HttpWebRequest)WebRequest.Create(requestUri);
request.PreAuthenticate = true;
request.UseDefaultCredentials = false;
request.Credentials = new NetworkCredential("UUUSSSEEERR", "PASSWORD");
request.ContentLength = data.Length;
request.ContentType = "text/plain";
request.Method = "POST";
using (Stream stream = request.GetRequestStream())
{
stream.Write(data, 0, data.Length);
stream.Flush();
}
StreamReader streamReader = null;
string result;
try
{
streamReader = new StreamReader(request.GetResponse().GetResponseStream());
result = streamReader.ReadToEnd();
}
finally
{
streamReader.Close();
}
txtOutput.Text = result;
最初の実行時に常に悪い要求例外をスローしますが、デバッガーでカーソルを最初の行に戻すと正常に動作し、txtOutput.text で適切な応答が返され、デタッチされたアプリケーションで同じ動作が返されます。最初は例外がスローされますが、2 回目は動作しますいいです、誰かが私にいくつかの回避策を教えてくれますか、私がここで何をしているのか教えてください。.net 4.0 を使用しています。
アップデート:
たとえば、次のコードは機能していますが、これは私が探している回避策ではありません。WebException をキャッチして while ループを追加しただけで、その statusCode が 400 の場合、コードを再ループすると機能します
var requestUri = new Uri("https://example.com/path1/path2?var=somevar");
ServicePointManager.ServerCertificateValidationCallback += new RemoteCertificateValidationCallback((object s, X509Certificate certificate, X509Chain chain, SslPolicyErrors sslPolicyErrors) => { return true; });
byte[] data = Encoding.UTF8.GetBytes("DEV72*12/27/06*TAYLOR*RICH*JOE*10/28/56*U0999495102*466666666*01*TAYLOR*TAMMY*M*10/26/52***CIGNA HMO*62308*UPIN*MEDICAL CENTER**MESSAGE*M*F*30");
HttpWebRequest request = null;
int counter = 0;
do
{
request = (HttpWebRequest)WebRequest.Create(requestUri);
request.PreAuthenticate = true;
request.UseDefaultCredentials = false;
request.Credentials = new NetworkCredential("USERNAME", "password");
request.ContentLength = data.Length;
request.ContentType = "text/plain";
request.Method = "POST";
using (Stream stream = request.GetRequestStream())
{
stream.Write(data, 0, data.Length);
stream.Flush();
}
StreamReader streamReader = null;
string result = string.Empty;
try
{
streamReader = new StreamReader(request.GetResponse().GetResponseStream());
result = streamReader.ReadToEnd();
}
catch (WebException ex)
{
HttpWebResponse response = (HttpWebResponse)ex.Response;
if (response.StatusCode == HttpStatusCode.BadRequest)
{
counter++;
}
else
{
txtOutput.Text = ex.ToString();
}
}
finally
{
if(streamReader != null) streamReader.Close();
}
txtOutput.Text = result;
} while (counter == 1);