HTTP 요청 함수 설명 및 활용 예제

이 문서에서는 HTTP 요청을 생성하고 전송하는 함수에 대해 설명합니다. HTTP 요청은 RESTful API를 사용할 때 HTTP 헤더를 통한 인증 등 다양한 용도로 사용될 수 있습니다.

함수 설명

함수: http_request

이 함수는 일반적인 HTTP 요청을 생성하고 전송합니다. 다음과 같은 매개변수가 필요합니다:

  • URL: 요청할 웹 주소입니다.
  • 요청 방법: "GET", "HEAD", "POST", "PUT", "DELETE", "TRACE", "OPTIONS" 또는 "CONNECT" 중 하나입니다.
  • 헤더 맵: HTTP 헤더를 포함하는 키/값 쌍의 DS 맵입니다. 헤더 필드와 필요한 데이터는 문자열 형식으로 제공되며, 콜론(:)은 포함되지 않아야 합니다.
  • 선택적 요청 본문: 데이터 문자열(빈 문자열 ""도 가능) 또는 이진 데이터용 버퍼입니다.

이 함수는 비동기 요청 ID를 반환하며, 이 ID는 콜백을 식별하는 데 사용됩니다.

비동기 콜백

이 함수는 비동기 HTTP 이벤트에 의해 수신되는 "콜백"을 생성합니다. 이 경우, 요청 함수와 관련된 DS 맵이 생성되어 특별한 변수 async_load에 저장됩니다. 이 DS 맵에는 다음과 같은 두 개의 키가 포함됩니다:

  • "id": 함수에서 반환된 ID입니다. 여러 개의 HTTP 요청을 보낼 경우, 어떤 요청에 대한 응답인지 확인하기 위해 이 값을 사용합니다.
  • "response_headers": 값이 0 이상인 경우, HTTP 요청에 대한 응답으로 반환된 HTTP 헤더를 포함하는 DS 맵을 보유합니다.

함수 구문

http_request(url, method, header_map, body);

매개변수 설명

매개변수 타입 설명
url String 정보를 얻고자 하는 서버의 웹 주소입니다.
method String 요청 방법 (일반적으로 "GET" 또는 "POST", 모든 방법 지원)
header_map DS Map 필수 헤더 필드가 포함된 DS 맵
body String 또는 Buffer 헤더 다음에 전송될 데이터 (이진 버퍼 핸들 가능)

반환값

  • 비동기 요청 ID (문제가 발생하면 -1)

활용 예제

아래는 HTTP 요청을 생성하고 전송하는 예제 코드입니다.

var _headers = ds_map_create();
ds_map_add(_headers, "Authorization", "Basic eW95b19hZG1pbjpjNG5lZmllbGQ=");
ds_map_add(_headers, "Content-Type", "application/x-www-form-urlencoded");
ds_map_add(_headers, "Cookie", "request_method=GET; _InAppPurchases_session=69bb6ef6eec2b");

var _data = "utf8=%E2%9C%93&authenticity_token=kPmS14DcYcuKgMFZUsN3XFfj3mhs%3D&product%5Bname%5D=CatchTheHaggis&product%5Bproduct_id%5D=http_test&commit=Create+Product";

request_id = http_request("http://225.0.0.97:3000/products", "POST", _headers, _data);

ds_map_destroy(_headers);

위 코드는 요청에 필요한 HTTP 헤더를 포함하는 DS 맵을 생성하고, POST 요청에 사용할 데이터 문자열을 생성합니다. 마지막으로, 함수를 호출하고 그 ID 값을 request_id 변수에 저장하여 HTTP 비동기 이벤트에서 확인할 수 있도록 합니다.

추가적인 활용 예제는 다음과 같습니다:

// GET 요청 예제
var _get_headers = ds_map_create();
ds_map_add(_get_headers, "Accept", "application/json");

var get_request_id = http_request("http://example.com/api/data", "GET", _get_headers, "");

ds_map_destroy(_get_headers);

// PUT 요청 예제
var _put_headers = ds_map_create();
ds_map_add(_put_headers, "Authorization", "Bearer your_token_here");
ds_map_add(_put_headers, "Content-Type", "application/json");

var put_data = "{\"name\":\"New Item\",\"price\":100}";
var put_request_id = http_request("http://example.com/api/items/1", "PUT", _put_headers, put_data);

ds_map_destroy(_put_headers);

이 예제들은 GET 및 PUT 요청을 수행하는 방법을 보여줍니다. 각 요청에 대해 필요한 헤더를 설정하고, 요청 본문을 정의한 후, http_request 함수를 호출합니다.

Read more

기술 문서 해설 및 활용 예제

이 문서는 특정 기술에 대한 설명과 활용 방법을 다룹니다. 아래에서 내용을 쉽게 이해할 수 있도록 해설하고, 다양한 활용 및 응용 예제를 추가로 제공합니다. 기술 개요 이 기술은 게임 개발에서 자주 사용되는 기능으로, 특정 작업을 자동화하거나 효율적으로 처리하는 데 도움을 줍니다. 주로 게임의 로직을 구성하거나 사용자 인터페이스를 제어하는 데 사용됩니다. 주요

By 이재협/실장/시스템개발실/PHYSIA

키워드 설명서

이 문서는 특정 키워드에 대한 설명과 사용법을 제공합니다. 문법 (arguments); 인수 인수 이름 유형 설명 argument_name 인수에 대한 설명을 여기에 작성합니다. 반환값 (선택적 설명) 예제 code_example() { // 여기에 코드 예제를 설명합니다. } 코드 예제 설명 위의 코드 예제는 특정 기능을 수행하는 함수의 기본 구조를 보여줍니다. 이 함수는 인수를 받아들이고, 특정

By 이재협/실장/시스템개발실/PHYSIA

GameMaker 환경 설정 및 기능

이 문서에서는 GameMaker의 환경 설정 및 다양한 IDE 기능에 대한 정보를 제공합니다. 다음은 주요 항목들입니다: IDE 환경 설정 IDE(통합 개발 환경) 설정은 GameMaker의 전반적인 사용 경험을 조정하는 데 도움을 줍니다. 여기서 사용자는 개인의 필요에 맞게 다양한 옵션을 설정할 수 있습니다. 주요 설정 항목 설정 항목 설명 테마 IDE의 색상

By 이재협/실장/시스템개발실/PHYSIA

GameMaker IDE 설명서

GameMaker IDE는 게임을 만들고 소프트웨어에서 제공하는 모든 기능을 활용하는 주요 인터페이스입니다. 이 프로그램은 시작 화면부터 게임을 만들기 위해 사용하는 모든 편집기 창까지 포함되며, 매뉴얼과 다양한 튜토리얼에서 IDE라고 언급됩니다. IDE의 구성 요소 다음 섹션에서는 IDE에 대한 정보를 다룹니다: 1. 설정 및 기능 IDE의 설정 및 기능은 사용자가 게임 개발을 보다 효율적으로

By 이재협/실장/시스템개발실/PHYSIA