Basit Bir Rest Api Client Geliştirelim 8

2023-05-12

Bu noktada, geliştirmemiz gereken bir diğer önemli konu da güvenlikle ilgili olabilir. Özellikle, API çağrıları genellikle belirli bir kimlik doğrulama yöntemi gerektirir. Bunu sağlamak için, HTTP istemcimizi çok kullanılan iki kimlik doğrulama yöntemiyle, yani Basic Authentication ve Bearer (Token) Authentication ile uyumlu hale getirebiliriz.

Bu amaçla, istemcimize iki yeni metot ekleyelim:

public void SetBasicAuthentication(string username, string password)
{
    var basicAuthValue = Convert.ToBase64String(Encoding.UTF8.GetBytes($"{username}:{password}"));
    SetDefaultHeader("Authorization", $"Basic {basicAuthValue}");
}

public void SetBearerToken(string token)
{
    SetDefaultHeader("Authorization", $"Bearer {token}");
}

Bu metodlar, Authorization başlığını ayarlar, böylece her HTTP talebi kimlik doğrulama bilgilerini içerir. SetBasicAuthentication metodu, kullanıcı adı ve parola kullanarak Basic Authentication ayarlar. SetBearerToken metodu ise bir Bearer Token ayarlar.

Bu özellikler, HTTP istemcimizin çeşitli kimlik doğrulama yöntemlerini desteklemesini sağlar, böylece daha geniş bir dizi API ile çalışabilir.

Bir sonraki adım olarak HTTP yanıtlarının daha kapsamlı bir şekilde işlenmesi olabilir. Bu, yanıtların HTTP durum kodlarına ve içerik türlerine göre farklı şekillerde işlenmesini içerir. Örneğin, bir yanıt 404 Not Found durum kodunu içeriyorsa, bu durumu belirli bir şekilde işlemek isteyebiliriz. Ayrıca, bir yanıtın içeriği belirli bir MIME türüne (örneğin, “application/json” veya “text/plain”) sahipse, bu içeriği belirli bir şekilde işlemek isteyebiliriz.

Bu tür bir işlevselliği desteklemek için, SendRequestAsync metodunu genişletebiliriz:

public async Task<T> SendRequestAsync<T>(string uri, HttpMethod method, object content = null, Dictionary<string, string> headers = null, TimeSpan? timeout = null) where T : class
{
    return await HandleExceptions(async () =>
    {
        var request = CreateRequest(uri, method, content, headers, timeout);

        var policyWrap = Policy.WrapAsync(_policyRegistry.Get<IAsyncPolicy<HttpResponseMessage>>("RetryPolicy"),
                                          _policyRegistry.Get<IAsyncPolicy<HttpResponseMessage>>("CachePolicy"));

        var response = await policyWrap.ExecuteAsync(async () => await _client.SendAsync(request));

        var responseBody = await response.Content.ReadAsStringAsync();

        if (!response.IsSuccessStatusCode)
        {
            _logger.LogWarning($"Received HTTP {response.StatusCode} for {method} request to {uri}. Response body: {responseBody}");

            if (response.StatusCode == System.Net.HttpStatusCode.NotFound)
            {
                // Handle 404 status code
                _logger.LogError($"The requested resource at {uri} was not found.");
            }

            throw new HttpRequestException($"Request to {uri} failed with status code {response.StatusCode}. Response body: {responseBody}");
        }

        // Handle responses according to their MIME type
        if (response.Content.Headers.ContentType.MediaType == "application/json")
        {
            return JsonConvert.DeserializeObject<T>(responseBody);
        }
        else if (response.Content.Headers.ContentType.MediaType == "text/plain")
        {
            return responseBody as T;
        }
        else
        {
            throw new NotSupportedException($"Unsupported content type: {response.Content.Headers.ContentType.MediaType}");
        }
    });
}

Bu yeni kod parçacığı, 404 Not Found durum kodunu ve “application/json” ve “text/plain” MIME türlerini özel olarak ele alır.



Bu gibi daha fazla gönderi...

SemaphoreSlim Sınıfı: C#'ta Çoklu Görevlere Dayalı Programlama

2023-06-10 | #net #semaphoreslim

Genel Bakış SemaphoreSlim sınıfı, bir veya daha fazla threadin aynı anda belirli bir kaynağı veya işlemi kullanmasını kontrol etmek için C# ‘ta kullanılan bir yapıdır. SemaphoreSlim, aynı anda kaynağa erişebilecek thread sayısını sınırlar. SemaphoreSlim kullanımı, genellikle çok threadli uygulamalarda deadlock durumlarını önlemek ve belirli bir kaynağın aynı anda yalnızca bir veya daha fazla thread tarafından kullanılmasını sağlamak için kullanılır. SemaphoreSlim Kullanımı SemaphoreSlim sınıfı, aşağıdaki gibi kullanılır: SemaphoreSlim semaphoreSlim = new SemaphoreSlim(1, 1); Burada ilk parametre, aynı anda kaç threadin kaynağı kullanabileceğini belirler.

Devamı 


Basit Bir Rest Api Client Geliştirelim 9

2023-05-14 | #diy-rest-api-client #do-it-yourself #net #rest-api

HTTP isteklerini izlemek ve teşhis etmek için daha fazla yetenek ekleyerek, kütüphanemizi daha da geliştirebiliriz. Bu amaçla, isteklerin ve yanıtların bazı temel bilgilerini loga kaydeden bir middleware ekleyelim. Bu özellik, HTTP isteklerinin ve yanıtlarının kaydını tutmak için HttpClient‘in DelegatingHandler sınıfını kullanır. Bu, bir HTTP isteği gönderildiğinde ve bir yanıt alındığında çalışan bir kod parçasıdır. Bu durumda, HTTP isteklerinin ve yanıtlarının bazı temel bilgilerini loga kaydeder. Aşağıda, bu özelliği eklemek için gereken kod parçacığı bulunmaktadır:

Devamı 


Basit Bir Rest Api Client Geliştirelim 7

2023-05-12 | #diy-rest-api-client #do-it-yourself #net #rest-api

Birkaç özelleştirilebilir başlık ayarlama yeteneği ekleyelim. Bu özellik, belirli bir istek için özel HTTP başlıkları ayarlamayı kolaylaştıracaktır. using Newtonsoft.Json; using Polly; using Polly.Caching; using Polly.Caching.Memory; using Polly.Registry; using System; using System.Collections.Generic; using System.Net.Http; using System.Text; using System.Threading.Tasks; using Microsoft.Extensions.Logging; public class MyHttpClient : IDisposable { private readonly HttpClient _client; private readonly IPolicyRegistry<string> _policyRegistry; private readonly ILogger<MyHttpClient> _logger; public MyHttpClient(HttpClient client, IPolicyRegistry<string> policyRegistry, ILogger<MyHttpClient> logger, string baseAddress, TimeSpan? timeout = null, HttpMessageHandler handler = null) { _client = handler == null ?

Devamı 