C
C
Duplicate TLS 1.2 SOAP Request that uses .NET HttpWebRequest
See more HTTP Examples
This example shows how to duplicate a SOAP request that uses .NET's HttpWebRequest and requires TLS 1.2.
string xmlRequest = "...envelope..."
System.Net.ServicePointManager.SecurityProtocol = (SecurityProtocolType)3072;
string url = "https://www3.gsis.gr/webtax2/wsgsis/RgWsPublic/RgWsPublicPort?WSDL";
HttpWebRequest req = (HttpWebRequest)WebRequest.Create(url);
req.Method = "POST";
req.ContentType = "text/xml;charset=UTF-8";
byte[] reqBytes = new System.Text.UTF8Encoding().GetBytes(xmlRequest);
req.ContentLength = reqBytes.Length;
try {
using (System.IO.Stream reqStream = req.GetRequestStream()) {
reqStream.Write(reqBytes, 0, reqBytes.Length);
reqStream.Flush();
reqStream.Close();
}
} catch (Exception ex) {
actionLogger.AddError(ex.Message, null);
actionLogger.Validate();
}
string xmlResponse = null;
using (HttpWebResponse resp = (HttpWebResponse)req.GetResponse()) {
try {
using (System.IO.StreamReader sr = new System.IO.StreamReader(resp.GetResponseStream())) {
xmlResponse = sr.ReadToEnd();
sr.Close();
}
} catch (Exception ex) {
actionLogger.AddError(ex.Message, null);
actionLogger.Validate();
} finally {
resp.Close();
}
}
Chilkat C Downloads
#include <C_CkHttp.h>
#include <C_CkHttpRequest.h>
#include <C_CkHttpResponse.h>
void ChilkatSample(void)
{
BOOL success;
HCkHttp http;
HCkHttpRequest req;
const char *xmlRequest;
HCkHttpResponse resp;
const char *xmlResponse;
success = FALSE;
// This example assumes Chilkat HTTP to have been previously unlocked.
// See Global Unlock Sample for sample code.
http = CkHttp_Create();
req = CkHttpRequest_Create();
CkHttpRequest_putHttpVerb(req,"POST");
CkHttpRequest_putContentType(req,"text/xml");
CkHttpRequest_putSendCharset(req,TRUE);
CkHttpRequest_putCharset(req,"utf-8");
CkHttpRequest_putPath(req,"/webtax2/wsgsis/RgWsPublic/RgWsPublicPort?WSDL");
xmlRequest = "...SOAP envelope...";
CkHttpRequest_LoadBodyFromString(req,xmlRequest);
CkHttp_putFollowRedirects(http,TRUE);
// Chilkat will automatically offer TLS 1.2. It is the server that
// chooses the TLS protocol version. Assuming the server wishes to use
// TLS 1.2, then that is what will be used.
resp = CkHttpResponse_Create();
success = CkHttp_HttpSReq(http,"www3.gsis.gr",443,TRUE,req,resp);
if (success == FALSE) {
printf("%s\n",CkHttp_lastErrorText(http));
CkHttp_Dispose(http);
CkHttpRequest_Dispose(req);
CkHttpResponse_Dispose(resp);
return;
}
xmlResponse = CkHttpResponse_bodyStr(resp);
printf("%s\n",xmlResponse);
CkHttp_Dispose(http);
CkHttpRequest_Dispose(req);
CkHttpResponse_Dispose(resp);
}