다음을 통해 공유


RESTful 웹 서비스 사용

웹 서비스를 애플리케이션에 통합하는 것은 일반적인 시나리오입니다. 이 문서에서는 애플리케이션에서 Xamarin.Forms RESTful 웹 서비스를 사용하는 방법을 보여 줍니다.

REST(Representational State Transfer)는 웹 서비스를 빌드하기 위한 아키텍처 스타일입니다. REST 요청은 웹 브라우저에서 웹 페이지를 검색하고 서버에 데이터를 보내는 데 사용하는 것과 동일한 HTTP 동사를 사용하여 HTTP를 통해 수행됩니다. 동사는 다음과 같습니다.

  • GET – 이 작업은 웹 서비스에서 데이터를 검색하는 데 사용합니다.
  • POST – 이 작업은 웹 서비스에서 데이터의 새 항목을 만드는 데 사용합니다.
  • PUT – 이 작업은 웹 서비스에서 데이터 항목을 업데이트하는 데 사용합니다.
  • PATCH –이 작업은 항목을 수정하는 방법에 대한 지침을 설명하는 방식으로 웹 서비스에서 데이터 항목을 업데이트하는 데 사용합니다. 이 동사는 샘플 애플리케이션에서 사용되지 않습니다.
  • DELETE – 이 작업은 웹 서비스에서 데이터 항목을 삭제하는 데 사용합니다.

REST를 준수하는 웹 서비스 API는 RESTful API라고 하며 다음을 사용하여 정의됩니다.

  • 기본 URI.
  • GET, POST, PUT, PATCH 또는 DELETE와 같은 HTTP 메서드
  • JSON(JavaScript Object Notation)과 같은 데이터에 대한 미디어 형식입니다.

RESTful 웹 서비스는 일반적으로 JSON 메시지를 사용하여 데이터를 클라이언트로 반환합니다. JSON은 압축 페이로드를 생성하는 텍스트 기반 데이터 교환 형식으로, 데이터를 보낼 때 대역폭 요구 사항이 줄어듭니다. 샘플 애플리케이션은 오픈 소스 NewtonSoft JSON.NET 라이브러리를 사용하여 메시지를 직렬화하고 역직렬화합니다.

REST의 단순성은 모바일 애플리케이션에서 웹 서비스에 액세스하기 위한 기본 방법을 만드는 데 도움이 되었습니다.

샘플 애플리케이션이 실행되면 다음 스크린샷과 같이 로컬로 호스트된 REST 서비스에 연결됩니다.

예제 애플리케이션

참고 항목

iOS 9 이상에서 ATS(App Transport Security)는 인터넷 리소스(예: 앱의 백 엔드 서버)와 앱 간에 보안 연결을 적용하여 중요한 정보의 우발적인 공개를 방지합니다. ATS는 iOS 9용으로 빌드된 앱에서 기본적으로 사용하도록 설정되므로 모든 연결에는 ATS 보안 요구 사항이 적용됩니다. 연결이 이러한 요구 사항을 충족하지 않으면 예외로 실패합니다.

인터넷 리소스에 대해 HTTPS 프로토콜 및 보안 통신을 사용할 수 없는 경우 ATS 를 옵트아웃할 수 있습니다. 이 작업은 앱의 Info.plist 파일을 업데이트하여 수행할 수 있습니다. 자세한 내용은 App Transport Security를 참조 하세요.

웹 서비스 사용

REST 서비스는 ASP.NET Core를 사용하여 작성되며 다음 작업을 제공합니다.

연산 HTTP 메서드 상대 URI 매개 변수
할 일 항목의 목록 가져오기 GET /api/todoitems/
새 할 일 항목 만들기 게시 /api/todoitems/ TodoItem 형식의 JSON
할 일 항목 업데이트 PUT /api/todoitems/ TodoItem 형식의 JSON
할 일 항목 삭제 DELETE /api/todoitems/{id}

대부분의 URI는 경로에 TodoItem ID를 포함합니다. 예를 들어 ID를 TodoItem 삭제하려면 클라이언트가 6bb8a868-dba1-4f1a-93b7-24ebce87e243DELETE 요청을 http://hostname/api/todoitems/6bb8a868-dba1-4f1a-93b7-24ebce87e243보냅니다. 샘플 애플리케이션에서 사용되는 데이터 모델에 대한 자세한 내용은 데이터 모델링을 참조하세요.

Web API 프레임워크가 요청을 받으면 요청을 작업으로 라우팅합니다. 이러한 작업은 클래스의 공용 메서드일 TodoItemsController 뿐입니다. 프레임워크는 라우팅 미들웨어를 사용하여 들어오는 요청의 URL을 일치시키고 작업에 매핑합니다. REST API는 HTTP 동사로 작업을 나타내는 리소스 집합으로 앱의 기능을 모델을 라우팅하는 특성을 사용해야 합니다. 특성 라우팅은 특성 모음을 사용하여 작업을 경로 템플릿에 직접 매핑합니다. 특성 라우팅에 대한 자세한 내용은 REST API에 대한 특성 라우팅을 참조 하세요. ASP.NET Core를 사용하여 REST 서비스를 빌드하는 방법에 대한 자세한 내용은 네이티브 모바일 애플리케이션용 백 엔드 서비스 만들기를 참조 하세요.

클래스 HttpClient 는 HTTP를 통해 요청을 보내고 받는 데 사용됩니다. HTTP 요청을 보내고 URI 식별 리소스에서 HTTP 응답을 수신하는 기능을 제공합니다. 각 요청은 비동기 작업으로 전송됩니다. 비동기 작업에 대한 자세한 내용은 비동기 지원 개요를 참조 하세요.

이 클래스는 HttpResponseMessage HTTP 요청이 이루어진 후 웹 서비스에서 받은 HTTP 응답 메시지를 나타냅니다. 상태 코드, 헤더 및 모든 본문을 포함 하 여 응답에 대 한 정보를 포함 합니다. 합니다 HttpContent 클래스를 나타내는 HTTP 본문 및 콘텐츠 헤더와 같은 Content-TypeContent-Encoding입니다. 콘텐츠는 데이터 형식에 ReadAs 따라 메서드(예: ReadAsStringAsyncReadAsByteArrayAsync)를 사용하여 읽을 수 있습니다.

HTTPClient 개체 만들기

인스턴스는 HttpClient 다음 코드 예제와 같이 애플리케이션이 HTTP 요청을 수행해야 하는 한 개체가 유지되도록 클래스 수준에서 선언됩니다.

public class RestService : IRestService
{
  HttpClient client;
  ...

  public RestService ()
  {
    client = new HttpClient ();
    ...
  }
  ...
}

데이터 검색

HttpClient.GetAsync 메서드는 다음 코드 예제와 같이 GET 요청을 URI로 지정된 웹 서비스로 보낸 다음 웹 서비스에서 응답을 받는 데 사용됩니다.

public async Task<List<TodoItem>> RefreshDataAsync ()
{
  ...
  Uri uri = new Uri (string.Format (Constants.TodoItemsUrl, string.Empty));
  ...
  HttpResponseMessage response = await client.GetAsync (uri);
  if (response.IsSuccessStatusCode)
  {
      string content = await response.Content.ReadAsStringAsync ();
      Items = JsonSerializer.Deserialize<List<TodoItem>>(content, serializerOptions);
  }
  ...
}

REST 서비스는 속성에 HttpResponseMessage.IsSuccessStatusCode HTTP 상태 코드를 전송하여 HTTP 요청이 성공했는지 또는 실패했는지 여부를 나타냅니다. 이 작업의 경우 REST 서비스는 응답에서 HTTP 상태 코드 200(확인)을 보냅니다. 이는 요청이 성공했으며 요청된 정보가 응답에 있음을 나타냅니다.

HTTP 작업이 성공하면 응답 내용을 표시하기 위해 읽습니다. 이 속성은 HttpResponseMessage.Content HTTP 응답의 콘텐츠를 나타내며 메서드는 HttpContent.ReadAsStringAsync HTTP 콘텐츠를 문자열에 비동기적으로 씁니다. 그런 다음, 이 콘텐츠는 JSON에서 인스턴스로 ListTodoItem 역직렬화됩니다.

Warning

메서드를 ReadAsStringAsync 사용하여 큰 응답을 검색하면 성능에 부정적인 영향을 미칠 수 있습니다. 이러한 경우 응답을 완전히 버퍼링할 필요가 없도록 응답을 직접 역직렬화해야 합니다.

데이터 만들기

HttpClient.PostAsync 메서드는 다음 코드 예제와 같이 POST 요청을 URI에 지정된 웹 서비스로 보낸 다음 웹 서비스에서 응답을 수신하는 데 사용됩니다.

public async Task SaveTodoItemAsync (TodoItem item, bool isNewItem = false)
{
  Uri uri = new Uri (string.Format (Constants.TodoItemsUrl, string.Empty));

  ...
  string json = JsonSerializer.Serialize<TodoItem>(item, serializerOptions);
  StringContent content = new StringContent (json, Encoding.UTF8, "application/json");

  HttpResponseMessage response = null;
  if (isNewItem)
  {
    response = await client.PostAsync (uri, content);
  }
  ...

  if (response.IsSuccessStatusCode)
  {
    Debug.WriteLine (@"\tTodoItem successfully saved.");
  }
  ...
}

인스턴스는 TodoItem 웹 서비스로 보내기 위해 JSON 페이로드로 직렬화됩니다. 그런 다음 이 페이로드는 메서드를 사용하여 요청하기 전에 웹 서비스로 전송될 HTTP 콘텐츠의 본문에 PostAsync 포함됩니다.

REST 서비스는 속성에 HttpResponseMessage.IsSuccessStatusCode HTTP 상태 코드를 전송하여 HTTP 요청이 성공했는지 또는 실패했는지 여부를 나타냅니다. 이 작업에 대한 일반적인 응답은 다음과 같습니다.

  • 201(CREATED) – 요청으로 인해 응답을 보내기 전에 새 리소스가 생성되었습니다.
  • 400(BAD REQUEST) – 서버에서 요청을 인식할 수 없습니다.
  • 409(충돌) – 서버의 충돌로 인해 요청을 수행할 수 없습니다.

데이터 업데이트

HttpClient.PutAsync 메서드는 다음 코드 예제와 같이 PUT 요청을 URI에서 지정한 웹 서비스로 보낸 다음 웹 서비스에서 응답을 수신하는 데 사용됩니다.

public async Task SaveTodoItemAsync (TodoItem item, bool isNewItem = false)
{
  ...
  response = await client.PutAsync (uri, content);
  ...
}

메서드의 PutAsync 작업은 웹 서비스에서 데이터를 만드는 데 사용되는 메서드와 동일합니다 PostAsync . 그러나 웹 서비스에서 전송할 수 있는 응답은 다릅니다.

REST 서비스는 속성에 HttpResponseMessage.IsSuccessStatusCode HTTP 상태 코드를 전송하여 HTTP 요청이 성공했는지 또는 실패했는지 여부를 나타냅니다. 이 작업에 대한 일반적인 응답은 다음과 같습니다.

  • 204(콘텐츠 없음) – 요청이 성공적으로 처리되었으며 응답이 의도적으로 비어 있습니다.
  • 400(BAD REQUEST) – 서버에서 요청을 인식할 수 없습니다.
  • 404(찾을 수 없음) – 요청된 리소스가 서버에 없습니다.

데이터 삭제

HttpClient.DeleteAsync 메서드는 다음 코드 예제와 같이 DELETE 요청을 URI에서 지정한 웹 서비스로 보낸 다음 웹 서비스에서 응답을 받는 데 사용됩니다.

public async Task DeleteTodoItemAsync (string id)
{
  Uri uri = new Uri (string.Format (Constants.TodoItemsUrl, id));
  ...
  HttpResponseMessage response = await client.DeleteAsync (uri);
  if (response.IsSuccessStatusCode)
  {
    Debug.WriteLine (@"\tTodoItem successfully deleted.");
  }
  ...
}

REST 서비스는 속성에 HttpResponseMessage.IsSuccessStatusCode HTTP 상태 코드를 전송하여 HTTP 요청이 성공했는지 또는 실패했는지 여부를 나타냅니다. 이 작업에 대한 일반적인 응답은 다음과 같습니다.

  • 204(콘텐츠 없음) – 요청이 성공적으로 처리되었으며 응답이 의도적으로 비어 있습니다.
  • 400(BAD REQUEST) – 서버에서 요청을 인식할 수 없습니다.
  • 404(찾을 수 없음) – 요청된 리소스가 서버에 없습니다.

로컬 개발

ASP.NET Core Web API와 같은 프레임워크를 사용하여 REST 웹 서비스를 로컬로 개발하는 경우 동시에 웹 서비스 및 모바일 앱을 디버그할 수 있습니다. 이 시나리오에서는 iOS 시뮬레이터 및 Android 에뮬레이터에 대해 텍스트 지우기 HTTP 트래픽을 사용하도록 설정해야 합니다. 통신을 허용하는 프로젝트 구성에 대한 자세한 내용은 로컬 웹 서비스에 대한 커넥트 참조하세요.