HTTP POST වෙබ් ඉල්ලීමක් කරන්නේ කෙසේද


1162

කැනොනිකල්
මම HTTP ඉල්ලීමක් කර ක්‍රමවේදය භාවිතා කර දත්ත කිහිපයක් එවන්නේ POST කෙසේද?

මට GETඉල්ලීමක් කළ හැකිය , නමුත් ඉල්ලීමක් කරන්නේ කෙසේදැයි මට අදහසක් නැත POST.

Answers:


2212

HTTP GETසහ POSTඉල්ලීම් ඉටු කිරීමට ක්‍රම කිහිපයක් තිබේ :


ක්‍රමය A: HttpClient (කැමති)

ලබා ගත: .NET Framework 4.5+, .NET Standard 1.1+, .NET Core 1.0+.

එය දැනට වඩාත් කැමති ප්‍රවේශය වන අතර එය අසමමුහුර්ත හා ඉහළ කාර්ය සාධනයකි. බොහෝ අවස්ථාවන්හි දී සාදන ලද අනුවාදය භාවිතා කරන්න, නමුත් ඉතා පැරණි වේදිකා සඳහා NuGet පැකේජයක් ඇත.

using System.Net.Http;

පිහිටුවීම

HttpClientඔබගේ යෙදුමේ ආයු කාලය සඳහා එකක් ක්ෂණිකව ස්ථාපනය කිරීම රෙකමදාරු කරනු ලැබේ .

private static readonly HttpClient client = new HttpClient();

පරායත්ත එන්නත් විසඳුමක් HttpClientFactoryසඳහා බලන්න .


  • POST

    var values = new Dictionary<string, string>
    {
        { "thing1", "hello" },
        { "thing2", "world" }
    };
    
    var content = new FormUrlEncodedContent(values);
    
    var response = await client.PostAsync("http://www.example.com/recepticle.aspx", content);
    
    var responseString = await response.Content.ReadAsStringAsync();
  • GET

    var responseString = await client.GetStringAsync("http://www.example.com/recepticle.aspx");

ක්රමය B: තෙවන පාර්ශවීය පුස්තකාල

රෙස්ට්ෂාර්ප්

  • POST

     var client = new RestClient("http://example.com");
     // client.Authenticator = new HttpBasicAuthenticator(username, password);
     var request = new RestRequest("resource/{id}");
     request.AddParameter("thing1", "Hello");
     request.AddParameter("thing2", "world");
     request.AddHeader("header", "value");
     request.AddFile("file", path);
     var response = client.Post(request);
     var content = response.Content; // Raw content as string
     var response2 = client.Post<Person>(request);
     var name = response2.Data.Name;

Flurl.Http

එය චතුර කථික API ක්‍රීඩා කරන නව පුස්තකාලයක් වන අතර, සහායකයින් පරීක්ෂා කිරීම, HttpClient තොප්පිය යටතේ භාවිතා කිරීම සහ අතේ ගෙන යා හැකි ය. එය NuGet හරහා ලබා ගත හැකිය .

    using Flurl.Http;

  • POST

    var responseString = await "http://www.example.com/recepticle.aspx"
        .PostUrlEncodedAsync(new { thing1 = "hello", thing2 = "world" })
        .ReceiveString();
  • GET

    var responseString = await "http://www.example.com/recepticle.aspx"
        .GetStringAsync();

ක්රමය C: HttpWebRequest (නව වැඩ සඳහා නිර්දේශ නොකරයි)

ලබා ගත: .NET Framework 1.1+, .NET Standard 2.0+, .NET Core 1.0+. .NET Core හි, එය බොහෝ දුරට අනුකූලතාව සඳහා වේ - එය ඔතා HttpClient, අඩු ක්‍රියාකාරීත්වයක් ඇති අතර නව විශේෂාංග නොලැබෙනු ඇත.

using System.Net;
using System.Text;  // For class Encoding
using System.IO;    // For StreamReader

  • POST

    var request = (HttpWebRequest)WebRequest.Create("http://www.example.com/recepticle.aspx");
    
    var postData = "thing1=" + Uri.EscapeDataString("hello");
        postData += "&thing2=" + Uri.EscapeDataString("world");
    var data = Encoding.ASCII.GetBytes(postData);
    
    request.Method = "POST";
    request.ContentType = "application/x-www-form-urlencoded";
    request.ContentLength = data.Length;
    
    using (var stream = request.GetRequestStream())
    {
        stream.Write(data, 0, data.Length);
    }
    
    var response = (HttpWebResponse)request.GetResponse();
    
    var responseString = new StreamReader(response.GetResponseStream()).ReadToEnd();
  • GET

    var request = (HttpWebRequest)WebRequest.Create("http://www.example.com/recepticle.aspx");
    
    var response = (HttpWebResponse)request.GetResponse();
    
    var responseString = new StreamReader(response.GetResponseStream()).ReadToEnd();

ක්රමය D: වෙබ් සේවාලාභියා (නව වැඩ සඳහා නිර්දේශ නොකරයි)

මෙය වටා එතීමකි HttpWebRequest. සමඟ සසඳන්නHttpClient .

: ලබා ගත .NET Framework 1.1+, NET Standard 2.0+,.NET Core 2.0+

using System.Net;
using System.Collections.Specialized;

  • POST

    using (var client = new WebClient())
    {
        var values = new NameValueCollection();
        values["thing1"] = "hello";
        values["thing2"] = "world";
    
        var response = client.UploadValues("http://www.example.com/recepticle.aspx", values);
    
        var responseString = Encoding.Default.GetString(response);
    }
  • GET

    using (var client = new WebClient())
    {
        var responseString = client.DownloadString("http://www.example.com/recepticle.aspx");
    }

2
Lo ලොයිඩ්:HttpWebResponse response = (HttpWebResponse)HttpWReq.GetResponse();
ඉවාන් මුලව්ස්කි

2
ඔබ ASCII භාවිතා කරන්නේ ඇයි? යමෙකුට UTF-8 සමඟ xml අවශ්‍ය නම් කුමක් කළ යුතුද?
Gero

9
මැරුණු අශ්වයෙකුට පහර දීමට මම අකමැතියි, නමුත් ඔබ කළ යුත්තේresponse.Result.Content.ReadAsStringAsync()
ඩේවිඩ් එස්.

14
WebRequest සහ WebClient උරුමයක් යැයි ඔබ කීවේ ඇයි? එම්එස්ඩීඑන් ඒවා අතහැර දැමූ බවක් හෝ කිසිවක් නොකියයි. මට යමක් මග හැරී තිබේද?
හයිප්

24
Ie හීප්: ඒවා ප්‍රතික්ෂේප නොකෙරේ, වෙබ් ඉල්ලීම් ඉදිරිපත් කිරීමේ නව (බොහෝ විට වඩා හොඳ හා නම්‍යශීලී) ක්‍රම තිබේ. මගේ මතය අනුව, සරල, විවේචනාත්මක නොවන මෙහෙයුම් සඳහා, පැරණි ක්‍රම ඉතා හොඳයි - නමුත් එය ඔබට සහ ඔබට වඩාත් පහසු ඕනෑම දෙයක්.
ඉවාන් මුලව්ස්කි

390

සරල GET ඉල්ලීම

using System.Net;

...

using (var wb = new WebClient())
{
    var response = wb.DownloadString(url);
}

සරල POST ඉල්ලීම

using System.Net;
using System.Collections.Specialized;

...

using (var wb = new WebClient())
{
    var data = new NameValueCollection();
    data["username"] = "myUser";
    data["password"] = "myPassword";

    var response = wb.UploadValues(url, "POST", data);
    string responseInString = Encoding.UTF8.GetString(response);
}

18
+1 සාමාන්‍ය දේවල් සඳහා POST එවැනි කෙටි කේතයක් තිබීම සතුටක්.
user_v

3
ටිම් - ඔබ නිරාකරණය කළ නොහැකි වචනාර්ථයෙන් දකුණු ක්ලික් කළහොත්, ඔබට විසඳුම් ප්‍රකාශ එකතු කිරීමට අවශ්‍ය ක්‍රියාමාර්ග අඩංගු විසදුම් සන්දර්භය මෙනුවක් සොයාගත හැකිය. විසඳීමේ සන්දර්භය මෙනුව නොපෙන්වයි නම්, එයින් අදහස් වන්නේ ඔබ මුලින්ම යොමු එකතු කළ යුතු බවයි.
කැමරන් විල්බි

1
මම ඔබේ පිළිතුර හොඳ යැයි පිළිගත්තා එය වඩාත් සරල හා පැහැදිලි නිසා.
හූච්

13
POST ඉල්ලීම සඳහා ප්‍රතිචාර විචල්‍යය බයිට් අරාවක් බව මම එක් කිරීමට කැමැත්තෙමි. නූල් ප්‍රතිචාරය ලබා ගැනීම සඳහා ඔබ කරන්නේ Encoding.ASCII.GetString (ප්‍රතිචාරය); (System.Text භාවිතා කරමින්)
සින්ඩ්‍රේ

1
තව දුරටත්, ඔබට තරමක් සංකීර්ණ අරා $ _POST ['පරිශීලක'] ලෙස එවිය හැකිය: දත්ත ["පරිශීලක [පරිශීලක නාමය]"] = "මගේ පරිශීලක නාමය"; දත්ත ["පරිශීලක [මුරපදය]"] = "myPassword";
බිමල් පූඩෙල්

70

MSDN හි නියැදියක් ඇත.

using System;
using System.IO;
using System.Net;
using System.Text;

namespace Examples.System.Net
{
    public class WebRequestPostExample
    {
        public static void Main()
        {
            // Create a request using a URL that can receive a post. 
            WebRequest request = WebRequest.Create("http://www.contoso.com/PostAccepter.aspx");
            // Set the Method property of the request to POST.
            request.Method = "POST";
            // Create POST data and convert it to a byte array.
            string postData = "This is a test that posts this string to a Web server.";
            byte[] byteArray = Encoding.UTF8.GetBytes(postData);
            // Set the ContentType property of the WebRequest.
            request.ContentType = "application/x-www-form-urlencoded";
            // Set the ContentLength property of the WebRequest.
            request.ContentLength = byteArray.Length;
            // Get the request stream.
            Stream dataStream = request.GetRequestStream();
            // Write the data to the request stream.
            dataStream.Write(byteArray, 0, byteArray.Length);
            // Close the Stream object.
            dataStream.Close();
            // Get the response.
            WebResponse response = request.GetResponse();
            // Display the status.
            Console.WriteLine(((HttpWebResponse)response).StatusDescription);
            // Get the stream containing content returned by the server.
            dataStream = response.GetResponseStream();
            // Open the stream using a StreamReader for easy access.
            StreamReader reader = new StreamReader(dataStream);
            // Read the content.
            string responseFromServer = reader.ReadToEnd();
            // Display the content.
            Console.WriteLine(responseFromServer);
            // Clean up the streams.
            reader.Close();
            dataStream.Close();
            response.Close();
        }
    }
}

1
කිසියම් හේතුවක් නිසා මම විශාල දත්ත ප්‍රමාණයක් යවන විට එය ක්‍රියාත්මක වූයේ නැත
AnKing

28

මෙය JSON ආකෘතියෙන් දත්ත යැවීම / ලැබීම පිළිබඳ සම්පූර්ණ ක්‍රියාකාරී උදාහරණයකි, මම විෂුවල් ස්ටුඩියෝ 2013 එක්ස්ප්‍රස් සංස්කරණය භාවිතා කළෙමි :

using System;
using System.Collections.Generic;
using System.Data;
using System.Data.OleDb;
using System.IO;
using System.Linq;
using System.Net.Http;
using System.Text;
using System.Threading.Tasks;
using System.Web.Script.Serialization;

namespace ConsoleApplication1
{
    class Customer
    {
        public string Name { get; set; }
        public string Address { get; set; }
        public string Phone { get; set; }
    }

    public class Program
    {
        private static readonly HttpClient _Client = new HttpClient();
        private static JavaScriptSerializer _Serializer = new JavaScriptSerializer();

        static void Main(string[] args)
        {
            Run().Wait();
        }

        static async Task Run()
        {
            string url = "http://www.example.com/api/Customer";
            Customer cust = new Customer() { Name = "Example Customer", Address = "Some example address", Phone = "Some phone number" };
            var json = _Serializer.Serialize(cust);
            var response = await Request(HttpMethod.Post, url, json, new Dictionary<string, string>());
            string responseText = await response.Content.ReadAsStringAsync();

            List<YourCustomClassModel> serializedResult = _Serializer.Deserialize<List<YourCustomClassModel>>(responseText);

            Console.WriteLine(responseText);
            Console.ReadLine();
        }

        /// <summary>
        /// Makes an async HTTP Request
        /// </summary>
        /// <param name="pMethod">Those methods you know: GET, POST, HEAD, etc...</param>
        /// <param name="pUrl">Very predictable...</param>
        /// <param name="pJsonContent">String data to POST on the server</param>
        /// <param name="pHeaders">If you use some kind of Authorization you should use this</param>
        /// <returns></returns>
        static async Task<HttpResponseMessage> Request(HttpMethod pMethod, string pUrl, string pJsonContent, Dictionary<string, string> pHeaders)
        {
            var httpRequestMessage = new HttpRequestMessage();
            httpRequestMessage.Method = pMethod;
            httpRequestMessage.RequestUri = new Uri(pUrl);
            foreach (var head in pHeaders)
            {
                httpRequestMessage.Headers.Add(head.Key, head.Value);
            }
            switch (pMethod.Method)
            {
                case "POST":
                    HttpContent httpContent = new StringContent(pJsonContent, Encoding.UTF8, "application/json");
                    httpRequestMessage.Content = httpContent;
                    break;

            }

            return await _Client.SendAsync(httpRequestMessage);
        }
    }
}

9

මෙහි හොඳ පිළිතුරු කිහිපයක් තිබේ. ඔබේ ශීර්ෂයන් WebClient () සමඟ සැකසීමට මට වෙනත් ක්‍රමයක් පළ කිරීමට ඉඩ දෙන්න. API යතුරක් සකසන්නේ කෙසේද යන්නත් මම ඔබට පෙන්වන්නම්.

        var client = new WebClient();
        string credentials = Convert.ToBase64String(Encoding.ASCII.GetBytes(userName + ":" + passWord));
        client.Headers[HttpRequestHeader.Authorization] = $"Basic {credentials}";
        //If you have your data stored in an object serialize it into json to pass to the webclient with Newtonsoft's JsonConvert
        var encodedJson = JsonConvert.SerializeObject(newAccount);

        client.Headers.Add($"x-api-key:{ApiKey}");
        client.Headers.Add("Content-Type:application/json");
        try
        {
            var response = client.UploadString($"{apiurl}", encodedJson);
            //if you have a model to deserialize the json into Newtonsoft will help bind the data to the model, this is an extremely useful trick for GET calls when you have a lot of data, you can strongly type a model and dump it into an instance of that class.
            Response response1 = JsonConvert.DeserializeObject<Response>(response);

ප්‍රයෝජනවත්, ස්තූතියි. BTW ශීර්ෂ-ගුණාංග සැකසීම සඳහා ඉහත තාක්‍ෂණය පැරණි (අතහැර දැමූ?), HttpWebRequest ප්‍රවේශය සඳහා ද ක්‍රියා කරන බව පෙනේ. උදා: myReq.Headers [HttpRequestHeader.Authorization] = $ "මූලික {අක්තපත්‍ර}";
Zeek2

7

මෙම විසඳුම සම්මත .NET ඇමතුම් හැර අන් කිසිවක් භාවිතා නොකරයි.

පරීක්ෂා කර ඇත:

  • ව්යවසාය WPF යෙදුමක භාවිතා වේ. UI අවහිර කිරීමෙන් වළක්වා ගැනීමට අසින්ක් / බලා සිටීම භාවිතා කරයි.
  • .NET 4.5+ සමඟ අනුකූල වේ.
  • පරාමිතීන් නොමැතිව පරීක්ෂා කර ඇත (තිරය පිටුපස "GET" අවශ්‍ය වේ).
  • පරාමිතීන් සමඟ පරීක්ෂා කර ඇත (තිරය පිටුපස "POST" අවශ්‍ය වේ).
  • ගූගල් වැනි සම්මත වෙබ් පිටුවක් සමඟ පරීක්ෂා කර ඇත.
  • අභ්‍යන්තර ජාවා පදනම් කරගත් වෙබ් සේවාවක් සමඟ පරීක්ෂා කර ඇත.

යොමුව:

// Add a Reference to the assembly System.Web

කේතය:

using System;
using System.Collections.Generic;
using System.Collections.Specialized;
using System.Net;
using System.Net.Http;
using System.Threading.Tasks;
using System.Web;

private async Task<WebResponse> CallUri(string url, TimeSpan timeout)
{
    var uri = new Uri(url);
    NameValueCollection rawParameters = HttpUtility.ParseQueryString(uri.Query);
    var parameters = new Dictionary<string, string>();
    foreach (string p in rawParameters.Keys)
    {
        parameters[p] = rawParameters[p];
    }

    var client = new HttpClient { Timeout = timeout };
    HttpResponseMessage response;
    if (parameters.Count == 0)
    {
        response = await client.GetAsync(url);
    }
    else
    {
        var content = new FormUrlEncodedContent(parameters);
        string urlMinusParameters = uri.OriginalString.Split('?')[0]; // Parameters always follow the '?' symbol.
        response = await client.PostAsync(urlMinusParameters, content);
    }
    var responseString = await response.Content.ReadAsStringAsync();

    return new WebResponse(response.StatusCode, responseString);
}

private class WebResponse
{
    public WebResponse(HttpStatusCode httpStatusCode, string response)
    {
        this.HttpStatusCode = httpStatusCode;
        this.Response = response;
    }
    public HttpStatusCode HttpStatusCode { get; }
    public string Response { get; }
}

පරාමිතීන් නොමැතිව ඇමතීමට (තිරය පිටුපස "GET" භාවිතා කරයි):

 var timeout = TimeSpan.FromSeconds(300);
 WebResponse response = await this.CallUri("http://www.google.com/", timeout);
 if (response.HttpStatusCode == HttpStatusCode.OK)
 {
     Console.Write(response.Response); // Print HTML.
 }

පරාමිතීන් සමඟ ඇමතීමට (තිරය පිටුපස "POST" භාවිතා කරයි):

 var timeout = TimeSpan.FromSeconds(300);
 WebResponse response = await this.CallUri("http://example.com/path/to/page?name=ferret&color=purple", timeout);
 if (response.HttpStatusCode == HttpStatusCode.OK)
 {
     Console.Write(response.Response); // Print HTML.
 }

7

මම මෙතෙක් සොයාගෙන ඇති සරල (එක්-ලයිනර්, දෝෂ පරීක්ෂා කිරීමක් නැත, ප්‍රතිචාරයක් සඳහා රැඳී නොසිටින්න) විසඳුම:

(new WebClient()).UploadStringAsync(new Uri(Address), dataString);‏

ප්‍රවේශමෙන් භාවිතා කරන්න!


5
එය තරමක් නරක ය. කිසිදු ආකාරයක දෝෂ හැසිරවීමක් නොමැති නිසා එය නිදොස් කිරීම වේදනාවකි. මීට අමතරව මෙම ප්‍රශ්නයට දැනටමත් හොඳ පිළිතුරක් ඇත.
හූච්

1
Answ අනෙක් අය මේ ආකාරයේ පිළිතුරු ගැන උනන්දු විය හැකිය, එය හොඳම පිළිතුර නොවුනත්.
Mitulát bti

එකඟ විය, මෙය ප්‍රයෝජනවත් වන එකම සන්දර්භය වන්නේ කේත ගොල්ෆ් කිරීම සහ C #; හි ගොල්ෆ් කරන්නේ කවුද යන්නයි)
Extragorey

මම මෙම පිළිතුර ලිව්වේ http මත පදනම් වූ ල ging ු-සටහන් විසඳුමක් සොයමින්, තවත් සමහර අයට ඒ හා සමානවම ප්‍රයෝජනවත් වේ යැයි මම සිතමි.
ඔහාඩ් කොහෙන්

5

Windows.Web.Http නාම අවකාශය භාවිතා කරන විට , FormUrlEncodedContent වෙනුවට POST සඳහා අපි ලියන්නේ HttpFormUrlEncodedContent. එසේම ප්‍රතිචාරය වන්නේ HttpResponseMessage වර්ගයයි. ඉතිරිය ඉවාන් මුලව්ස්කි ලියා ඇති ආකාරයට ය.


5

ඔබ චතුර කථික API එකකට කැමති නම් ඔබට Tiny.RestClient භාවිතා කළ හැකිය . එය නුජෙට් හි ඇත .

var client = new TinyRestClient(new HttpClient(), "http://MyAPI.com/api");
// POST
var city = new City() { Name = "Paris", Country = "France" };
// With content
var response = await client.PostRequest("City", city)
                           .ExecuteAsync<bool>();

2

මෙය මුළුමනින්ම සුළු දෙයක් නොවන්නේ ඇයි? ඉල්ලීම සිදු කිරීම විශේෂයෙන් ප්‍රති results ල සමඟ කටයුතු නොකරන අතර සමහර .NET දෝෂ ද ඊට සම්බන්ධ බව පෙනේ - HttpClient හි දෝෂය බලන්න . GetAsync විසින් වෙබ්එක්සෙප්ෂන් විසි කළ යුතු අතර, කාර්ය සාධක අවලංගු නොවේ

මම මෙම කේතය සමඟ අවසන් කළෙමි:

static async Task<(bool Success, WebExceptionStatus WebExceptionStatus, HttpStatusCode? HttpStatusCode, string ResponseAsString)> HttpRequestAsync(HttpClient httpClient, string url, string postBuffer = null, CancellationTokenSource cts = null) {
    try {
        HttpResponseMessage resp = null;

        if (postBuffer is null) {
            resp = cts is null ? await httpClient.GetAsync(url) : await httpClient.GetAsync(url, cts.Token);

        } else {
            using (var httpContent = new StringContent(postBuffer)) {
                resp = cts is null ? await httpClient.PostAsync(url, httpContent) : await httpClient.PostAsync(url, httpContent, cts.Token);
            }
        }

        var respString = await resp.Content.ReadAsStringAsync();
        return (resp.IsSuccessStatusCode, WebExceptionStatus.Success, resp.StatusCode, respString);

    } catch (WebException ex) {
        WebExceptionStatus status = ex.Status;
        if (status == WebExceptionStatus.ProtocolError) {
            // Get HttpWebResponse so that you can check the HTTP status code.
            using (HttpWebResponse httpResponse = (HttpWebResponse)ex.Response) {
                return (false, status, httpResponse.StatusCode, httpResponse.StatusDescription);
            }
        } else {
            return (false, status, null, ex.ToString()); 
        }

    } catch (TaskCanceledException ex) {
        if (cts is object && ex.CancellationToken == cts.Token) {
            // a real cancellation, triggered by the caller
            return (false, WebExceptionStatus.RequestCanceled, null, ex.ToString());
        } else {
            // a web request timeout (possibly other things!?)
            return (false, WebExceptionStatus.Timeout, null, ex.ToString());
        }

    } catch (Exception ex) {
        return (false, WebExceptionStatus.UnknownError, null, ex.ToString());
    }
}

මෙම නම් ලබා ගන්න හෝ තැපැල් රඳා පවතී කරන්නේ postBufferශූන්ය හෝ නොවේ

සාර්ථකත්වය සත්‍ය නම් ප්‍රතිචාරය ලැබෙනු ඇත ResponseAsString

සාර්ථකත්වය බොරු නම් ඔබ පරීක්ෂා කළ හැක WebExceptionStatus, HttpStatusCodeසහ ResponseAsStringවැරදි ගොස් දේ දකින්න උත්සාහ කරන්න.


0

.Net core හි ඔබට පහත කේතය සමඟ පශ්චාත් ඇමතුමක් ලබා ගත හැකිය, මෙහිදී මම මෙම කේතයට අමතර විශේෂාංග කිහිපයක් එකතු කළ අතර එමඟින් ඔබේ කේතය ප්‍රොක්සියකට පිටුපසින් සහ ජාල අක්තපත්‍ර සමඟ ක්‍රියා කිරීමට හැකි වේ. ඔබේ පණිවිඩය. මෙය සියල්ල පැහැදිලි කර කේතීකරණයේදී ඔබට උපකාරී වනු ඇතැයි මම බලාපොරොත්තු වෙමි.

HttpClient client = GetHttpClient(_config);

        if (headers != null)
        {
            foreach (var header in headers)
            {
                client.DefaultRequestHeaders.TryAddWithoutValidation(header.Key, header.Value);
            }
        }

        client.BaseAddress = new Uri(baseAddress);

        Encoding encoding = Encoding.UTF8;


        var result = await client.PostAsync(url, new StringContent(body, encoding, "application/json")).ConfigureAwait(false);
        if (result.IsSuccessStatusCode)
        {
            return new RequestResponse { severity = "Success", httpResponse = result.Content.ReadAsStringAsync().Result, StatusCode = result.StatusCode };
        }
        else
        {
            return new RequestResponse { severity = "failure", httpResponse = result.Content.ReadAsStringAsync().Result, StatusCode = result.StatusCode };
        }


 public HttpClient GetHttpClient(IConfiguration _config)
        {
            bool ProxyEnable = Convert.ToBoolean(_config["GlobalSettings:ProxyEnable"]);

            HttpClient client = null;
            if (!ProxyEnable)
            {
                client = new HttpClient();
            }
            else
            {
                string ProxyURL = _config["GlobalSettings:ProxyURL"];
                string ProxyUserName = _config["GlobalSettings:ProxyUserName"];
                string ProxyPassword = _config["GlobalSettings:ProxyPassword"];
                string[] ExceptionURL = _config["GlobalSettings:ExceptionURL"].Split(';');
                bool BypassProxyOnLocal = Convert.ToBoolean(_config["GlobalSettings:BypassProxyOnLocal"]);
                bool UseDefaultCredentials = Convert.ToBoolean(_config["GlobalSettings:UseDefaultCredentials"]);

                WebProxy proxy = new WebProxy
                {
                    Address = new Uri(ProxyURL),
                    BypassProxyOnLocal = BypassProxyOnLocal,
                    UseDefaultCredentials = UseDefaultCredentials,
                    BypassList = ExceptionURL,
                    Credentials = new NetworkCredential(ProxyUserName, ProxyPassword)

                };

                HttpClientHandler handler = new HttpClientHandler { Proxy = proxy };
                client = new HttpClient(handler,true);
            }
            return client;
        }

0

HTTP POST ඉල්ලීමක් කිරීමට මම .NET 4.8 හි භාවිතා කරන දේ මෙන්න. මෙම කේතය සමඟ කෙනෙකුට එකවර POST ඉල්ලීම් අසමමුහුර්තව යැවිය හැකිය. සෑම ඉල්ලීමක් අවසානයේම සිදුවීමක් මතු වේ. සියලු ඉල්ලීම් අවසානයේ තවත් සිදුවීමක් මතු වේ.

එක් සීනුව මූලික පන්තියයි:

Imports System.ComponentModel
Imports System.Text.RegularExpressions
Imports System.Timers
Imports System.Windows.Forms
Imports AeonLabs
Imports AeonLabs.Environment
Imports Newtonsoft.Json

Public Class HttpDataCore
    Public Property url As String
    Public Property state As New environmentVarsCore
    Public Property errorMessage As String = ""
    Public Property statusMessage As String
    Public Property threadCount As Integer = 25
    Public Property numberOfRetryAttempts = 5
    Public Property queue As List(Of _queue_data_struct)
    Public Property queueBWorker As Integer() ' has the size of threadCount
    Public Property queueLock As New Object
    Public Property retryAttempts As New _retry_attempts
    Public Property dataStatistics As List(Of _data_statistics)
    Public Property loadingCounter As Integer
    Public Property CompletionPercentage As Integer ' value range 0-100
    Public Property IsBusy As Boolean

    Public Structure _queue_data_struct
        Dim vars As Dictionary(Of String, String)
        Dim filenameOrSavePath As String                  ' full address file name or full adress folder path
        Dim misc As Dictionary(Of String, String)
        Dim status As Integer                             ' -1 - completed; 0- not sent yet; 1-already sent / processing 
    End Structure
    Public Structure _retry_attempts
        Dim counter As Integer
        Dim pattern As Integer
        Dim previousPattern As Integer
        Dim errorMessage As String
    End Structure
    Public Structure _data_statistics
        Dim filesize As Double
        Dim bytesSentReceived As Double
        Dim speed As Double
    End Structure

    Public WithEvents RestartQueueTimer As New Timers.Timer
    Public bwDataRequest() As BackgroundWorker

    Public Event requestCompleted(sender As Object, requestData As String) 'TODO add misc vars

    Private sendToQueue As Boolean
    Public Sub New(ByVal Optional _state As environmentVarsCore = Nothing, ByVal Optional _url As String = "")
        queue = New List(Of _queue_data_struct)
        dataStatistics = New List(Of _data_statistics)
        loadingCounter = 0
        sendToQueue = False
        If _state IsNot Nothing AndAlso _url.Equals("") Then
            url = _state.ServerBaseAddr & _state.ApiServerAddrPath
        ElseIf Not _url.Equals("") Then
            url = _url
        Else
            Throw New System.Exception("Initialization err: state and url cannot be both null at same time")
        End If

        If _state IsNot Nothing Then
            state = _state
        End If

    End Sub
    Public Sub loadQueue(ByVal vars As Dictionary(Of String, String), ByVal Optional misc As Dictionary(Of String, String) = Nothing, ByVal Optional filenameOrSavePath As String = Nothing)
        Dim queueItem As New _queue_data_struct
        queueItem.vars = New Dictionary(Of String, String)
        queueItem.misc = New Dictionary(Of String, String)

        queueItem.vars = vars
        queueItem.status = 0
        queueItem.misc = misc
        queueItem.filenameOrSavePath = filenameOrSavePath
        queue.Add(queueItem)
    End Sub

    Public Sub clearQueue()
        loadingCounter = 0
        queue = New List(Of _queue_data_struct)
    End Sub
    Public Sub startRequest()
        If bwDataRequest(0) Is Nothing Then
            Throw New Exception("You need to call initialze first")
            Exit Sub
        End If

        'startSendQueue()
        IsBusy = True

        AddHandler RestartQueueTimer.Elapsed, New ElapsedEventHandler(AddressOf QueueTimerTick)
        With RestartQueueTimer
            .Enabled = True
            .Interval = 500
            .Start()
        End With
    End Sub

    Private Sub QueueTimerTick(ByVal sender As Object, ByVal e As ElapsedEventArgs)
        If QueuesToComplete(queue).Equals(0) And QueuesToSend(queue).Equals(0) Then
            RestartQueueTimer.Stop()
            queue = New List(Of _queue_data_struct)
            RaiseEvent requestCompleted(Me, Nothing)
            IsBusy = False
            Exit Sub
        End If

        If retryAttempts.counter >= numberOfRetryAttempts Then 'ToDo a retry number of attempts before quits
            Threading.Thread.CurrentThread.CurrentUICulture = Globalization.CultureInfo.GetCultureInfo(state.currentLang)
            Dim MsgBox As messageBoxForm
            MsgBox = New messageBoxForm(retryAttempts.errorMessage & ". " & My.Resources.strings.tryAgain & " ?", My.Resources.strings.question, MessageBoxButtons.YesNo, MessageBoxIcon.Question)
            If MsgBox.ShowDialog() = DialogResult.Yes Then
                Dim retry As _retry_attempts
                With retry
                    .counter = 0
                    .previousPattern = -1
                    .pattern = 0
                    .errorMessage = ""
                End With
                retryAttempts = retry
                startSendQueue()
            Else
                RestartQueueTimer.Stop()
                queue = New List(Of _queue_data_struct)
                RaiseEvent requestCompleted(Me, Nothing)
                IsBusy = False
                Exit Sub
            End If
            Exit Sub
        ElseIf Not sendToQueue And QueuesToSend(queue) > 0 Then
            startSendQueue()
        End If
    End Sub

    Private Sub startSendQueue()
        sendToQueue = True
        While QueuesToSend(queue) > 0
            For shtIndex = 0 To threadCount
                For i = 0 To queue.Count - 1
                    If Not bwDataRequest(shtIndex).IsBusy Then
                        SyncLock queueLock
                            If queue.ElementAt(i).status.Equals(0) Then
                                Dim data As New _queue_data_struct
                                data.vars = queue.ElementAt(i).vars
                                data.status = 1
                                data.misc = queue.ElementAt(i).misc
                                data.filenameOrSavePath = queue.ElementAt(i).filenameOrSavePath
                                queue(i) = data
                                queueBWorker(shtIndex) = i
                                dataStatistics(shtIndex) = (New _data_statistics)

                                bwDataRequest(shtIndex).RunWorkerAsync(queue(i))
                                Threading.Thread.Sleep(50)
                            End If
                        End SyncLock
                    End If
                Next i
            Next shtIndex
        End While
        sendToQueue = False
    End Sub

    Public Function QueuesToSend(queue As List(Of _queue_data_struct)) As Integer
        Dim counter As Integer = 0
        For i = 0 To queue.Count - 1
            If queue(i).status.Equals(0) Then
                counter += 1
            End If
        Next i
        Return counter
    End Function
    Public Function QueuesToComplete(queue As List(Of _queue_data_struct)) As Integer
        Dim counter As Integer = 0
        For i = 0 To queue.Count - 1
            If queue(i).status.Equals(1) Then
                counter += 1
            End If
        Next i
        Return counter
    End Function
    Public Function QueuesMultiHash(queue As List(Of _queue_data_struct)) As Integer
        Dim counter As Integer = 0
        For i = 0 To queue.Count - 1
            If queue(i).status.Equals(1) Then
                counter += i
            End If
        Next i
        Return counter
    End Function

    Public Function IsBase64String(ByVal s As String) As Boolean
        s = s.Trim()
        Return (s.Length Mod 4 = 0) AndAlso Regex.IsMatch(s, "^[a-zA-Z0-9\+/]*={0,3}$", RegexOptions.None)
    End Function

    '+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
    Public Function ConvertDataToArray(key As String, fields As String(), response As String) As Dictionary(Of String, List(Of String))
        If GetMessage(response).Equals("1001") Then
            Threading.Thread.CurrentThread.CurrentUICulture = Globalization.CultureInfo.GetCultureInfo(state.currentLang)
            errorMessage = "{'error':true,'message':'" & My.Resources.strings.errorNoRecordsFound & "'}"
            Return Nothing
        End If
        Try
            Dim jsonResult = JsonConvert.DeserializeObject(Of Dictionary(Of String, Object))(response)
            If jsonResult.ContainsKey(key) Then
                If Not jsonResult.Item(key).item(0).Count.Equals(fields.Length) Then
                    Threading.Thread.CurrentThread.CurrentUICulture = Globalization.CultureInfo.GetCultureInfo(state.currentLang)
                    errorMessage = "{'error':true,'message':'" & My.Resources.strings.JsonFieldsMismatch & ". table(" & key & "'}"
                    Return Nothing
                Else
                    Dim results = New Dictionary(Of String, List(Of String))
                    For k = 0 To fields.Length - 1
                        Dim fieldValues As List(Of String) = New List(Of String)
                        For i = 0 To jsonResult.Item(key).Count - 1
                            fieldValues.Add(jsonResult.Item(key).item(i).item(k).ToString)
                        Next i
                        results.Add(fields(k), fieldValues)

                    Next k
                    Return results
                End If
            Else
                Threading.Thread.CurrentThread.CurrentUICulture = Globalization.CultureInfo.GetCultureInfo(state.currentLang)
                errorMessage = "{'error':true,'message':'" & My.Resources.strings.JsonkeyNotFound & " (" & key & "'}"
                Return Nothing
            End If
        Catch ex As Exception
            errorMessage = "{'error':true,'message':'" & ex.ToString & "'}"
            errorMessage = ex.ToString
            Return Nothing
        End Try
    End Function
End Class

මෙම AeonLabs.Envorimentඑකතුවක් හෝ ක්ෂේත්ර සහ ගුණ සමග පන්තිය යි.

POST ඉල්ලීමක් කිරීම සඳහා එක් සීනුවකි:

Imports System.ComponentModel
Imports System.IO
Imports System.Net
Imports System.Text
Imports System.Web
Imports System.Web.Script.Serialization
Imports System.Windows.Forms
Imports AeonLabs.Environment
Imports AeonLabs.Security

Public Class HttpDataPostData
    Inherits HttpDataCore

    Public Event updateProgress(sender As Object, misc As Dictionary(Of String, String))
    Public Event dataArrived(sender As Object, requestData As String, misc As Dictionary(Of String, String))

    Public Sub New(ByVal Optional _state As environmentVarsCore = Nothing, ByVal Optional _url As String = "")
        MyBase.New(_state, _url)
    End Sub
    Public Sub initialize(ByVal Optional _threadCount As Integer = 0)
        If Not _threadCount.Equals(0) Then
            threadCount = _threadCount
        End If

        ReDim bwDataRequest(threadCount)
        ReDim queueBWorker(threadCount)

        For shtIndex = 0 To threadCount
            dataStatistics.Add(New _data_statistics)

            bwDataRequest(shtIndex) = New System.ComponentModel.BackgroundWorker
            bwDataRequest(shtIndex).WorkerReportsProgress = True
            bwDataRequest(shtIndex).WorkerSupportsCancellation = True

            AddHandler bwDataRequest(shtIndex).DoWork, AddressOf bwDataRequest_DoWork
            AddHandler bwDataRequest(shtIndex).RunWorkerCompleted, AddressOf bwDataRequest_RunWorkerCompleted
        Next shtIndex
        Dim retry As _retry_attempts
        With retry
            .counter = 0
            .previousPattern = -1
            .pattern = 0
            .errorMessage = ""
        End With
        retryAttempts = retry
    End Sub

    Private Sub bwDataRequest_DoWork(ByVal sender As System.Object, ByVal e As System.ComponentModel.DoWorkEventArgs)

        ' Find out the Index of the bWorker that called this DoWork (could be cleaner, I know)
        Dim Y As Integer
        Dim Index As Integer = Nothing
        For Y = 0 To UBound(bwDataRequest)
            If sender.Equals(bwDataRequest(Y)) Then
                Index = Y
                Exit For
            End If
        Next Y

        Dim queue As _queue_data_struct
        queue = e.Argument

        Dim vars As New Dictionary(Of String, String)
        vars = queue.vars

        'TODO translation need to be local
        If Not System.Net.NetworkInformation.NetworkInterface.GetIsNetworkAvailable() Then
            Threading.Thread.CurrentThread.CurrentUICulture = System.Globalization.CultureInfo.GetCultureInfo(state.currentLang)
            e.Result = "{'error':true,'message':'" & My.Resources.strings.errorNoNetwork & "'}"
            Exit Sub
        End If
        If vars Is Nothing Then
            e.Result = "{'error':true,'message':'missconfiguration vars'}"
            Exit Sub
        End If

        If Not vars.ContainsKey("id") Then
            vars.Add("id", state.userId)
        End If
        If Not vars.ContainsKey("pid") Then
            Dim appId As New FingerPrint
            vars.Add("pid", appId.Value)
        End If
        If Not vars.ContainsKey("language") Then
            vars.Add("language", state.currentLang)
        End If
        If Not vars.ContainsKey("origin") Then
            vars.Add("origin", state.softwareAccessMode)
        End If

        Dim serializer As New JavaScriptSerializer()
        Dim json As String = serializer.Serialize(vars)
        Dim encryption As New AesCipher(state)
        Dim encrypted As String = HttpUtility.UrlEncode(encryption.encrypt(json))
        Dim PostData = "origin=" & state.softwareAccessMode & "&data=" & encrypted
        Dim request As WebRequest = WebRequest.Create(url)
        Dim responseFromServer As String = ""
        Dim decrypted As String = ""

        request.Method = "POST"
        Dim byteArray As Byte() = Encoding.UTF8.GetBytes(PostData)
        request.ContentType = "application/x-www-form-urlencoded"
        request.Headers.Add("Authorization", state.ApiHttpHeaderToken & "-" & state.softwareAccessMode)
        request.ContentLength = byteArray.Length
        Try
            Dim dataStream As Stream = request.GetRequestStream()
            dataStream.Write(byteArray, 0, byteArray.Length)
            dataStream.Close()
            Dim response As HttpWebResponse = CType(request.GetResponse(), HttpWebResponse)
            dataStream = response.GetResponseStream()
            Dim reader As New StreamReader(dataStream)
            responseFromServer = reader.ReadToEnd()
            reader.Close()
            dataStream.Close()
            response.Close()

            If response.StatusCode = HttpStatusCode.Accepted Or response.StatusCode = 200 Then
                If IsBase64String(responseFromServer) And Not responseFromServer.Equals("") Then
                    decrypted = encryption.decrypt((responseFromServer)).Replace("\'", "'")
                Else
                    Threading.Thread.CurrentThread.CurrentUICulture = System.Globalization.CultureInfo.GetCultureInfo(state.currentLang)
                    decrypted = "{'error':true,'encrypted':false,'message':'" & My.Resources.strings.contactingCommServer & " |" & responseFromServer & "|'}"
                End If
            Else
                Threading.Thread.CurrentThread.CurrentUICulture = System.Globalization.CultureInfo.GetCultureInfo(state.currentLang)
                decrypted = "{'error':true,'message':'" & My.Resources.strings.contactingCommServer & " (" & response.StatusCode & ")', 'statuscode':'" & response.StatusCode & "'}"
            End If
        Catch ex As Exception
            Threading.Thread.CurrentThread.CurrentUICulture = System.Globalization.CultureInfo.GetCultureInfo(state.currentLang)
            decrypted = "{'error':true,'message':'" & My.Resources.strings.contactingCommServer & " (" & ex.Message.ToString.Replace("'", "\'") & ")'}"
        End Try

        e.Result = decrypted.Replace("\'", "'")
    End Sub

    Private Sub bwDataRequest_RunWorkerCompleted(ByVal sender As Object, ByVal e As System.ComponentModel.RunWorkerCompletedEventArgs)
        ' Find out the Index of the bWorker that called this DoWork (could be cleaner, I know)
        Dim Y As Integer
        Dim Index As Integer = Nothing
        Dim data As New _queue_data_struct

        For Y = 0 To UBound(bwDataRequest)
            If sender.Equals(bwDataRequest(Y)) Then
                Index = Y
                Exit For
            End If
        Next Y

        If IsResponseOk(e.Result, "statuscode") Then
            data = New _queue_data_struct
            data = queue(queueBWorker(Index))
            data.status = 0 're queue the file
            SyncLock queueLock
                queue(queueBWorker(Index)) = data
            End SyncLock
            Dim errorMsg As String = GetMessage(e.Result)
            Dim retry As _retry_attempts
            With retry
                .counter = retryAttempts.counter
                .previousPattern = retryAttempts.previousPattern
                .pattern = retryAttempts.pattern
                .errorMessage = retryAttempts.errorMessage
            End With
            retry.errorMessage = If(retryAttempts.errorMessage.IndexOf(errorMsg) > -1, retryAttempts.errorMessage, retryAttempts.errorMessage & System.Environment.NewLine & errorMsg)

            retry.pattern = QueuesMultiHash(queue)
            If retry.previousPattern.Equals(retry.pattern) Then
                retry.counter += 1
            Else
                retry.counter = 1
                retry.previousPattern = retryAttempts.pattern
            End If

            retryAttempts = retry
            Exit Sub
        End If

        data = New _queue_data_struct
        data = queue(queueBWorker(Index))
        data.status = -1 'completed sucessfully status
        SyncLock queueLock
            queue(queueBWorker(Index)) = data
        End SyncLock

        loadingCounter += 1
        CompletionPercentage = (loadingCounter / queue.Count) * 100
        statusMessage = "Loading data from the cloud ..."
        RaiseEvent updateProgress(Me, queue(queueBWorker(Index)).misc)
        RaiseEvent dataArrived(Me, e.Result, queue(queueBWorker(Index)).misc)
    End Sub
End Class

Aoenlabs.Security යනු සම්මත සංකේතාංකන ඇල්ගොරිතම භාවිතා කරමින් POST දත්ත සංකේතනය කර යැවීමේ පන්තියකි

By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.