프로그래밍/C#

C#에서 HttpClient를 활용한 네트워킹의 모든 것

shimdh 2025. 9. 17. 20:11
728x90

현대 애플리케이션 개발에서 네트워킹은 필수적인 요소로 자리 잡고 있습니다. 특히 C#에서는 HttpClient 클래스가 HTTP 서비스를 간단하고 효율적으로 상호작용할 수 있는 방법을 제공하여, 웹 기반 애플리케이션이나 API를 통한 데이터 교환이 필요한 시스템을 개발하는 개발자들에게 필수적인 도구로 자리 잡고 있습니다.

HttpClient 이해하기

HttpClient 클래스는 System.Net.Http 네임스페이스의 일부로, URI로 식별되는 리소스에 HTTP 요청을 보내고 응답을 받도록 설계되었습니다. 비동기 프로그래밍 패턴을 지원하여 웹 리소스와 상호작용할 때 비차단 호출을 가능하게 합니다.

HttpClient의 주요 기능

  • 비동기 작업: 비차단 I/O 작업을 허용합니다.
  • 다양한 HTTP 메서드 지원: GET, POST, PUT, DELETE 등 다양한 메서드를 지원합니다.
  • 자동 쿠키 처리: 필요에 따라 쿠키를 자동으로 관리합니다.
  • 커스터마이즈 가능한 헤더: 사용자 정의 헤더를 쉽게 추가할 수 있습니다.
728x90

기본 사용법

HttpClient를 사용하려면 먼저 인스턴스를 생성해야 합니다. 중요한 점은 HttpClient를 여러 번 인스턴스화하지 않고, 애플리케이션의 수명 주기 동안 인스턴스를 재사용하는 것이 권장된다는 것입니다.

using System;
using System.Net.Http;
using System.Threading.Tasks;

class Program
{
    static async Task Main(string[] args)
    {
        using (var client = new HttpClient())
        {
            // 기본 주소 설정 (선택 사항)
            client.BaseAddress = new Uri("https://api.example.com/");

            // GET 요청 보내기
            var response = await client.GetAsync("data");

            if (response.IsSuccessStatusCode)
            {
                var content = await response.Content.ReadAsStringAsync();
                Console.WriteLine(content);
            }
        }
    }
}

다양한 요청 유형 만들기

  1. GET 요청: 서버에서 정보를 가져옵니다.
  2. var response = await client.GetAsync("endpoint");
  3. POST 요청: 서버로 데이터를 보냅니다.
  4. var jsonContent = new StringContent("{\"name\":\"example\"}", Encoding.UTF8, "application/json"); var postResponse = await client.PostAsync("endpoint", jsonContent);
  5. PUT 요청: 서버의 기존 리소스를 업데이트합니다.
  6. var updateContent = new StringContent("{\"name\":\"updated_example\"}", Encoding.UTF8, "application/json"); var putResponse = await client.PutAsync("endpoint/1", updateContent);
  7. DELETE 요청: 서버에서 리소스를 제거합니다.
  8. var deleteResponse = await client.DeleteAsync("endpoint/1");

오류 처리

네트워크 통신을 다룰 때는 많은 요인으로 인해 실패할 수 있으므로 오류를 우아하게 처리하는 것이 중요합니다. 요청에 의해 반환된 상태 코드를 확인할 수 있습니다:

if (!response.IsSuccessStatusCode)
{
    Console.WriteLine($"데이터 가져오기 오류: {response.StatusCode}");
}

또한, 호출 주위에 try-catch 블록을 사용하는 것을 고려하십시오:

try 
{
    // 여기에 HTTP 호출...
} 
catch (HttpRequestException e) 
{
    Console.WriteLine($"요청 오류: {e.Message}");
}

모범 사례

  • HttpClient 인스턴스 재사용: TCP/IP 작동 방식으로 인해 인스턴스를 반복적으로 생성하면 소켓이 소진될 수 있습니다.
    public class ApiService 
    {
        private readonly HttpClient _httpClient;
    
        public ApiService(HttpClient httpClient) 
        {
            _httpClient = httpClient;
        }
    
        // 메서드 작성...
    }
  • 예시:
  • 취소 토큰: 사용자가 필요에 따라 긴 요청을 취소할 수 있도록 취소 토큰을 사용하십시오:
var cts = new CancellationTokenSource();
var responseTask = client.GetAsync("data", cts.Token);

// 취소하려면:
// cts.Cancel();
  • 타임아웃 설정: 요청이 무한정 대기하지 않도록 타임아웃을 설정하십시오:
client.Timeout = TimeSpan.FromSeconds(30);

HttpClient를 이해하고 활용함으로써 개발자들은 고급 C# 애플리케이션에 강력한 네트워킹 기능을 구축할 수 있으며, 네트워크를 통한 통신의 효율성과 신뢰성을 보장할 수 있습니다.

728x90