From da78a9e329e272dedb2400b79a3bdeebff387d47 Mon Sep 17 00:00:00 2001 From: Peter Bengtsson Date: Tue, 8 Dec 2020 14:42:17 -0500 Subject: initial commit --- files/ko/web/api/xmlhttprequest/index.html | 194 +++++++++++++++++++++++++++++ 1 file changed, 194 insertions(+) create mode 100644 files/ko/web/api/xmlhttprequest/index.html (limited to 'files/ko/web/api/xmlhttprequest/index.html') diff --git a/files/ko/web/api/xmlhttprequest/index.html b/files/ko/web/api/xmlhttprequest/index.html new file mode 100644 index 0000000000..43437969b0 --- /dev/null +++ b/files/ko/web/api/xmlhttprequest/index.html @@ -0,0 +1,194 @@ +--- +title: XMLHttpRequest +slug: Web/API/XMLHttpRequest +tags: + - AJAX + - API + - HTTP + - XHR + - XMLHttpRequest + - 레퍼런스 + - 웹 + - 인터페이스 + - 통신 +translation_of: Web/API/XMLHttpRequest +--- +

{{DefaultAPISidebar("XMLHttpRequest")}}
+ XMLHttpRequest(XHR) 객체는 서버와 상호작용하기 위하여 사용됩니다. 전체 페이지의 새로고침없이도 URL 로부터 데이터를 받아올 수 있습니다. 이는 웹 페이지가 사용자가 하고 있는 것을 방해하지 않으면서 페이지의 일부를 업데이트할 수 있도록 해줍니다. XMLHttpRequest 는 {{Glossary("AJAX")}} 프로그래밍에 주로 사용됩니다.

+ +

{{InheritanceDiagram(650, 150)}}

+ +

XMLHttpRequest 는 이름으로만 봐서는 XML 만 받아올 수 있을 것 같아 보이지만, 모든 종류의 데이터를 받아오는데 사용할 수 있습니다. 또한 HTTP 이외의 프로토콜도 지원합니다(file 과 ftp 포함).

+ +

통신을 통해 서버로부터 이벤트나 메시지 데이터를 받아야 한다면, {{domxref("EventSource")}} 를 통한 server-sent events 사용을 고려하세요. 완전 양방향 통신을 해야 한다면 웹 소켓이 더 나은 선택일 수 있습니다.

+ +

생성자

+ +
+
{{domxref("XMLHttpRequest.XMLHttpRequest", "XMLHttpRequest()")}}
+
생성자는 XMLHttpRequest 를 초기화합니다. 다른 모든 메소드 호출이전에 호출되어야 합니다.
+
+ +

속성

+ +

이 인터페이스는 {{domxref("XMLHttpRequestEventTarget")}} 과 {{domxref("EventTarget")}} 의 속성도 상속합니다.

+ +
+
{{domxref("XMLHttpRequest.onreadystatechange")}}
+
readyState 어트리뷰트가 변경될때마다 호출되는 {{domxref("EventHandler")}} 입니다.
+
{{domxref("XMLHttpRequest.readyState")}} {{readonlyinline}}
+
요청의 상태를 unsigned short 로 반환합니다.
+
{{domxref("XMLHttpRequest.response")}} {{readonlyinline}}
+
응답 엔티티 바디를 갖는하는 {{domxref("XMLHttpRequest.responseType")}} 의 값에 따라 {{jsxref("ArrayBuffer")}}, {{domxref("Blob")}}, {{domxref("Document")}}, JavaScript 객체, 또는 {{domxref("DOMString")}} 을 반환합니다.
+
{{domxref("XMLHttpRequest.responseText")}} {{readonlyinline}}
+
요청에 대한 응답을 텍스트로 갖는 {{domxref("DOMString")}} 을 반환합니다. 요청이 성공하지 못했거나 아직 전송되지 않았을 경우 null 을 반환합니다.
+
{{domxref("XMLHttpRequest.responseType")}}
+
응답 타입을 정의하는 열거형 값입니다.
+
{{domxref("XMLHttpRequest.responseURL")}} {{readonlyinline}}
+
응답의 연속된 URL 을 반환합니다. URL 이 null 인 경우 빈 문자열을 반환합니다.
+
{{domxref("XMLHttpRequest.responseXML")}} {{readonlyinline}}
+
요청에 대한 응답을 갖는 {{domxref("Document")}} 를 반환합니다. 요청이 성공하지 못했거나, 아직 전송되지 않았거나, XML 또는 HTML 로 파싱할 수 없는 경우 null 을 반환합니다. workers 에서는 사용이 불가합니다.
+
{{domxref("XMLHttpRequest.status")}} {{readonlyinline}}
+
요청의 응답 상태를 갖는 unsigned short 를 반환합니다.
+
{{domxref("XMLHttpRequest.statusText")}} {{readonlyinline}}
+
HTTP 서버에 의해 반환된 응답 문자열을 갖는 {{domxref("DOMString")}} 을 반환합니다. {{domxref("XMLHTTPRequest.status")}} 와는 다르게, 응답 메시지의 전체 텍스트를 갖습니다(예, "200 OK").
+
+ +
+

노트: HTTP/2 명세(8.1.2.4 Response Pseudo-Header Fields)에 따르면, HTTP/2 는 HTTP/1.1 상태 라인에 포함된 버전이나 원인 문구를 전달하는 방법을 정의하지 않습니다.

+
+ +
+
{{domxref("XMLHttpRequest.timeout")}}
+
요청이 자동으로 종료될때까지 걸린 시간을 밀리초 단위로 나타내는 unsigned long 입니다.
+
{{domxref("XMLHttpRequestEventTarget.ontimeout")}}
+
요청 시간 초과때마다 호출되는 {{domxref("EventHandler")}} 입니다. {{gecko_minversion_inline("12.0")}}
+
{{domxref("XMLHttpRequest.upload")}} {{readonlyinline}}
+
업로드 과정을 나타내는 {{domxref("XMLHttpRequestUpload")}} 입니다.
+
{{domxref("XMLHttpRequest.withCredentials")}}
+
사이트 간 Access-Control 요청이 쿠키나 인증 헤더와 같은 자격 증명을 사용해야하는지 여부를 나타내는 {{domxref("Boolean")}} 입니다.
+
+ +

비표준 속성

+ +
+
{{domxref("XMLHttpRequest.channel")}}{{ReadOnlyInline}}
+
{{Interface("nsIChannel")}} 입니다. 요청을 수행할 때 객체에 의해 사용된 채널입니다.
+
{{domxref("XMLHttpRequest.mozAnon")}}{{ReadOnlyInline}}
+
Boolean 입니다. true 일 경우, 요청이 쿠키나 인증 헤더 없이 전송됩니다.
+
{{domxref("XMLHttpRequest.mozSystem")}}{{ReadOnlyInline}}
+
Boolean 입니다. true 일 경우, 요청에대해 동일 출처 정책(same origin policy)이 강제되지 않습니다.
+
{{domxref("XMLHttpRequest.mozBackgroundRequest")}}
+
 Boolean 입니다. 객체가 백그라운드 서비스 요청을 나타내는지 여부를 표시합니다.
+
{{domxref("XMLHttpRequest.mozResponseArrayBuffer")}}{{gecko_minversion_inline("2.0")}} {{obsolete_inline("6")}} {{ReadOnlyInline}}
+
{{jsxref("ArrayBuffer")}}. 요청에 대한 응답입니다. 타입이 지정된 JavaScript 배열입니다.
+
{{domxref("XMLHttpRequest.multipart")}}{{obsolete_inline("22")}}
+
This Gecko-only feature, a boolean, was removed in Firefox/Gecko 22.
+ 대신 Server-Sent Events, 웹 소켓, 또는 프로그레스 이벤트의 responseText 를 사용하시기 바랍니다.
+
+ +

이벤트 핸들러

+ +

XMLHttpRequest 인스턴스의 속성으로써 onreadystatechange 는 모든 브라우저에서 지원됩니다.

+ +

그 이후, 많은 부가적인 이벤트 핸들러가 다양한 브라우저에서 구현되었습니다(onloadonerroronprogress, 등등.). XMLHttpRequest 사용하기 글을 확인하세요.

+ +

Firefox 를 포함해, 더 최신 브라우저는 on* 속성을 핸들러 함수로 설정하는것 뿐만 아니라 표준 {{domxref("EventTarget.addEventListener", "addEventListener()")}} API 를 통해 XMLHttpRequest 이벤트 리스닝도 지원합니다.

+ +

메소드

+ +
+
{{domxref("XMLHttpRequest.abort()")}}
+
이미 전송된 요청을 중지합니다.
+
{{domxref("XMLHttpRequest.getAllResponseHeaders()")}}
+
모든 응답 헤더를 {{Glossary("CRLF")}} 로 구분한 문자열로 반환합니다. 응답을 받지 않은 경우 null 입니다.
+
{{domxref("XMLHttpRequest.getResponseHeader()")}}
+
지정한 헤더의 텍스트를 갖는 문자열을 반환합니다. 응답을 아직 받지 못했거나 응답에 헤더가 존재하지 않을 경우 null 입니다.
+
{{domxref("XMLHttpRequest.open()")}}
+
요청을 초기화합니다. 이 메소드는 네이티브 코드로부터의 요청을 초기화하기 위해 JavaScript 코드에 의해 사용됩니다. 대신 openRequest() 를 사용하세요.
+
{{domxref("XMLHttpRequest.overrideMimeType()")}}
+
서버에의해 반환된 MIME 타입을 오버라이드합니다.
+
{{domxref("XMLHttpRequest.send()")}}
+
요청을 보냅니다. 요청이 비동기인 경우(기본값), 이 메소드는 요청이 보내진 즉시 반환합니다.
+
{{domxref("XMLHttpRequest.setRequestHeader()")}}
+
HTTP 요청 헤더의 값을 설정합니다. open() 후, send() 전에 setRequestHeader() 를 호출해야합니다.
+
+ +

비표준 메소드

+ +
+
{{domxref("XMLHttpRequest.init()")}}
+
C++ 코드에서 사용할 객체를 초기화합니다.
+
+ +
+

주의: 이 메소드는 JavaScript 에서 호출되면 안 됩니다.

+
+ +
+
{{domxref("XMLHttpRequest.openRequest()")}}
+
요청을 초기화합니다. 이 메소드는 JavaScript 코부로부터의 요청을 초기화하기위해 네이티브 코드에서 사용됩니다. 대신 open() 을 사용하세요. open() 에 대한 문서를 확인하세요.
+
{{domxref("XMLHttpRequest.sendAsBinary()")}}{{deprecated_inline()}}
+
바이너리 데이터를 보내는 send() 메소드의 다른 방식입니다.
+
+ +

Events

+ +
+
{{domxref("XMLHttpRequest/abort_event", "abort")}}
+
예를 들어 프로그램이 {{domxref("XMLHttpRequest.abort()")}}를 호출해서 요청이 중단되면 발생한다.{{domxref("XMLHttpRequestEventTarget/onabort", "onabort")}} 속성을 통해서도 가능하다.
+
{{domxref("XMLHttpRequest/error_event", "error")}}
+
요청에 에러가 생기면 발생한다.{{domxref("XMLHttpRequestEventTarget/onerror", "onerror")}} 속성을 통해서도 가능하다.
+
{{domxref("XMLHttpRequest/load_event", "load")}}
+
{{domxref("XMLHttpRequest")}} 처리 과정이 성공적으로 완료되면 발생한다.{{domxref("XMLHttpRequestEventTarget/onload", "onload")}} 속성을 통해서도 가능하다.
+
{{domxref("XMLHttpRequest/loadend_event", "loadend")}}
+
요청이 성공이든 ({{domxref("XMLHttpRequest/load_event", "load")}} 다음) 실패든 ({{domxref("XMLHttpRequest/abort_event", "abort")}} 또는 {{domxref("XMLHttpRequest/error_event", "error")}} 다음) 완료되면 발생한다.
+ {{domxref("XMLHttpRequestEventTarget/onloadend", "onloadend")}} 속성을 통해서도 가능하다.
+
{{domxref("XMLHttpRequest/loadstart_event", "loadstart")}}
+
요청이 데이터를 받기 시작하면 발생한다.
+ {{domxref("XMLHttpRequestEventTarget/onloadstart", "onloadstart")}} 속성을 통해서도 가능하다.
+
{{domxref("XMLHttpRequest/progress_event", "progress")}}
+
요청이 데이터를 받는 동안 주기적으로 발생한다.
+ {{domxref("XMLHttpRequestEventTarget/onprogress", "onprogress")}} 속성을 통해서도 가능하다.
+
+ +

명세

+ + + + + + + + + + + + + + + + +
명세상태코멘트
{{SpecName('XMLHttpRequest')}}{{Spec2('XMLHttpRequest')}}Live standard, latest version
+ +

브라우저 호환성

+ + + +

{{Compat("api.XMLHttpRequest")}}

+ +

함께 보기

+ + -- cgit v1.2.3-54-g00ecf