찾다
웹 프론트엔드JS 튜토리얼NodeJS 연구 노트 Http module_node.js

1, 오프닝 분석

우선 모든 사람이 "Http"라는 개념을 잘 알고 있어야 합니다. 이는 특정 언어를 기반으로 하는 것이 아닙니다. 언어마다 구현 세부 사항이 다르지만 동일합니다. 아이디어는 동일합니다.

호스트 운영 환경으로서 NodeJS는 JavaScript를 호스트 언어로 사용하며, 구현을 위한 자체 표준도 가지고 있습니다. 이번 글에서는 "Http 모듈"에 대해 함께 알아 보겠습니다. 하지만 전제로

공식 홈페이지에서 제공하는 API를 먼저 읽어보시고 사전 이해를 하시면 훨씬 더 편리할 것 같습니다.

코드 복사 코드는 다음과 같습니다.

HTTP
    http.STATUS_CODES
    http.createServer([requestListener])
    http.createClient([포트], [호스트])
    클래스: http.Server
    사건 : '요청'
    사건: '연결'
    사건: '닫기'
    이벤트: 'checkContinue'
    사건: '연결'
    이벤트: '업그레이드'
    이벤트: 'clientError'
    server.listen(포트, [호스트 이름], [백로그], [콜백])
    server.listen(경로, [콜백])
    server.listen(handle, [콜백])
    server.close([콜백])
    server.maxHeadersCount
    server.setTimeout(msecs, 콜백)
    서버.타임아웃
    클래스: http.ServerResponse
        사건: '닫기'
        response.writeContinue()
        response.writeHead(statusCode, [reasonPhrase], [헤더])
        response.setTimeout(msecs, 콜백)
        응답.상태코드
        response.setHeader(이름, 값)
        response.headers보냄
        응답.sendDate
        response.getHeader(이름)
        response.removeHeader(이름)
        response.write(청크, [인코딩])
        response.addTrailers(헤더)
        response.end([데이터], [인코딩])
        http.request(옵션, 콜백)
        http.get(옵션, 콜백)
    클래스: http.Agent
        새 에이전트([옵션])
        에이전트.maxSocket
        에이전트.maxFreeSocket
        에이전트.소켓
        에이전트.프리소켓
        에이전트.요청
        에이전트.파괴()
        에이전트.getName(옵션)
        http.globalAgent
    클래스: http.ClientRequest
        이벤트 '응답'
        이벤트: '소켓'
        사건: '연결'
        이벤트: '업그레이드'
        이벤트: '계속'
        request.write(청크, [인코딩])
        request.end([데이터], [인코딩])
        요청.중단()
        request.setTimeout(timeout, [콜백])
        request.setNoDelay([noDelay])
        request.setSocketKeepAlive([활성화], [initialDelay])
    http.IncomingMessage
        사건: '닫기'
        message.http버전
        메시지.헤더
        message.rawHeaders
        메시지.트레일러
        message.raw트레일러
        message.setTimeout(msecs, 콜백)
        메시지.방법
        메시지.url
        메시지.상태코드
        메시지.소켓

让我们先从一个简单例子开始, 创建一个叫server.js의 文件, 并写入以下代码:

复主代码 代码如下:

var http = require('http') ;
var 서버 = http.createServer(function(req,res){
res.writeHeader(200,{
'Content-Type' : 'text/plain;charset=utf-8' // charset=utf-8 추가
}) ;
res.end("안녕하세요 빅베어!") ;
}) ;
server.listen(8888) ;
console.log("포트 8888에서 실행되는 http 서버 ...") ;

(node ​​​​server.js) 결과는 다음과 같습니다.

2. 상세 분석 예시

이 작은 예를 자세히 살펴보세요.

(1행): "require"를 통해 NodeJS와 함께 제공되는 "http" 모듈을 도입하고 이를 http 변수에 할당합니다.

(2줄): http 모듈에서 제공하는 함수인 "createServer"를 호출합니다. 이 함수는 새로운 웹 서버 객체를 반환합니다.

 "requestListener" 매개변수는 "요청" 이벤트의 청취 대기열에 자동으로 추가되는 함수입니다.

요청이 들어오면 Event-Loop는 리스너 콜백 함수를 실행 큐에 넣고 노드의 모든 코드를 하나씩 실행 큐에서 꺼내어 실행합니다.

이러한 실행은 모두 작업 스레드에서 수행됩니다(이벤트 루프 자체는 독립적인 스레드에 있다고 간주할 수 있습니다. 우리는 일반적으로 이 스레드를 언급하지 않지만 노드를 단일 스레드 실행 환경이라고 부릅니다),

모든 콜백은 작업자 스레드에서 실행됩니다.

두 개의 매개변수(요청, 응답)를 제공하는 콜백 함수 "requestListener"를 다시 살펴보겠습니다.

요청이 수신될 때마다 실행됩니다. 각 연결에는 여러 요청이 있을 수 있습니다(연결 유지 연결에서).

"요청"은 http.IncomingMessage의 인스턴스입니다. "응답"은 http.ServerResponse의 인스턴스입니다.

http 요청 개체는 읽기 가능한 스트림이고, http 응답 개체는 쓰기 가능한 스트림입니다.

"IncomingMessage" 객체는 http.Server 또는 http.ClientRequest에 의해 생성됩니다.

그리고 각각 "요청" 및 "응답" 이벤트에 첫 번째 매개변수로 전달되었습니다.

응답 상태, 헤더 및 데이터에 액세스하는 데에도 사용할 수 있습니다.

 "Stream" 인터페이스와 다음과 같은 추가 이벤트, 메서드 및 속성을 구현합니다. (자세한 내용은 API를 참조하세요)

(3줄): "writeHeader", "response.writeHead()" 함수를 사용하여 Http 상태 200과 Http 헤더의 콘텐츠 유형을 보냅니다.

요청에 응답 헤더를 응답합니다. "statusCode"는 404와 같은 3자리 HTTP 상태 코드입니다. 마지막 매개변수인 "headers"는 응답 헤더의 내용입니다.

예를 들어주세요:

코드 복사 코드는 다음과 같습니다.

var body = 'hello world' ;
response.writeHead(200, {
'콘텐츠 길이': body.length,
'콘텐츠 유형': '텍스트/일반'
}) ;

참고: Content-Length는 문자가 아닌 바이트 단위로 계산됩니다.

이전 예의 이유는 "Hello World!" 문자열에 단일 바이트 문자만 포함되어 있기 때문입니다.

본문에 멀티바이트 인코딩 문자가 포함된 경우 Buffer.byteLength()를 사용하여 멀티바이트 문자 인코딩의 경우 문자열의 바이트 수를 결정해야 합니다.

Node는 Content-Lenth 속성이 전송된 본문 길이와 일치하는지 확인하지 않는다는 점을 추가로 설명해야 합니다.

statusCode는 3자리 HTTP 상태 코드입니다(예: "404"). 여기서 이야기하고 싶은 것은 모든 표준 "Http" 응답 상태 코드에 대한 컬렉션과 간단한 설명을 포함하는 "http.STATUS_CODES"입니다.

다음은 소스코드 참조입니다.

코드 복사 코드는 다음과 같습니다.

var STATUS_CODES = 내보내기.STATUS_CODES = {
  100 : '계속',
  101 : '스위칭 프로토콜',
  102 : '처리 중',                 // RFC 2518, RFC 4918에 의해 폐기됨
  200 : '알았어',
  201 : '생성됨',
  202 : '승인',
  203 : '신뢰할 수 없는 정보',
  204 : '내용 없음',
  205 : '콘텐츠 재설정',
  206 : '일부 내용',
  207 : '다중 상태',               // RFC 4918
  300 : '객관식',
  301 : '영구이동',
  302 : '임시 이동',
  303 : '기타보기',
  304 : '수정되지 않음',
  305 : '프록시 사용',
  307 : '임시 리디렉션',
  400 : '잘못된 요청',
  401 : '승인되지 않음',
  402 : '결제 필요',
  403 : '금지',
  404 : '찾을 수 없음',
  405 : '허용되지 않는 메소드',
  406 : '허용되지 않음',
  407 : '프록시 인증 필요',
  408 : '요청 시간 초과',
  409 : '갈등',
  410 : '가네',
  411 : '필요한 길이',
  412 : '전제조건 실패',
  413 : '요청 엔터티가 너무 큼',
  414 : '요청-URI가 너무 큼',
  415 : '지원되지 않는 미디어 유형',
  416 : '요청한 범위가 만족스럽지 않음',
  417 : '기대 실패',
  418 : '나는 찻주전자입니다',              // RFC 2324
  422 : '처리할 수 없는 엔터티',       // RFC 4918
  423 : '잠김',                     // RFC 4918
  424 : '실패한 종속성',          // RFC 4918
  425 : '순서가 지정되지 않은 컬렉션',       // RFC 4918
  426 : '업그레이드 필요',           // RFC 2817
  500 : '내부 서버 오류',
  501 : '구현되지 않음',
  502 : '나쁜 관문',
  503 : '서비스를 이용할 수 없습니다.',
  504 : '게이트웨이 시간 초과',
  505 : 'HTTP 버전은 지원되지 않습니다.',
  506 : 'Variant Also Negotiates',    // RFC 2295
  507 : '저장 공간 부족',       // RFC 4918
  509 : '대역폭 제한이 초과되었습니다.',
  510 : '확장되지 않음'                // RFC 2774
};

节选自,Nodejs源码 ”http.js“ 143行开始。

其实从客户端应答结果也不难看出:

 

(6행):”response.end”------当所有响应报头및报文被发送完成时这个方法将信发送给服务器。服务器会认为这个消息完成了。

  每次响应完成 之后必须调用该方法。如果指定了参数 “data” ,就相当于先调用  “response.write(data, encoding) ” 之后再调用 “response.end()” 。

(8행):"server.listen(8888)" ------ 服务器用指定的句柄接受连接,绑定은특별히결정적인端口。

이제 더 이상 사용할 수 없습니다.的开发NodeJS应사용。

삼,实例

# 🎜>

这是一个"POST"请求的例子:

复主代码 代码如下:

http.createServer(함수(요청, 응답) {
var 본문 = [];
console.log(request.method) ;
console.log(request.headers) ;
Request.on('데이터', 함수(청크) {
            body.push(청크);
}) ;
Request.on('end', function () {
​​​​본체 = Buffer.concat(body);
console.log(body.toString()) ;
});
}).listen(8888) ;

다음은 완전한 "Http" 요청 데이터 내용입니다.

코드 복사 코드는 다음과 같습니다.

POST/HTTP/1.1
사용자 에이전트: 컬/7.26.0
호스트: 로컬호스트
수락: */*
내용 길이: 11
콘텐츠 유형: application/x-www-form-urlencoded
안녕하세요

넷, 요약

(1), "Http"의 개념을 이해합니다.
(2) "Http" 관련 API를 능숙하게 사용할 수 있어야 합니다.
(3) "POST, GET" 간의 처리 내용 등 세부 사항에 주의하십시오.
(4) "requestListener"에 대한 이해.
(5)는 개념을 강조합니다. http 요청 개체는 읽기 가능한 스트림이고 http 응답 개체는 쓰기 가능한 스트림입니다.

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
Vercel是什么?怎么部署Node服务?Vercel是什么?怎么部署Node服务?May 07, 2022 pm 09:34 PM

Vercel是什么?本篇文章带大家了解一下Vercel,并介绍一下在Vercel中部署 Node 服务的方法,希望对大家有所帮助!

node.js gm是什么node.js gm是什么Jul 12, 2022 pm 06:28 PM

gm是基于node.js的图片处理插件,它封装了图片处理工具GraphicsMagick(GM)和ImageMagick(IM),可使用spawn的方式调用。gm插件不是node默认安装的,需执行“npm install gm -S”进行安装才可使用。

火了!新的JavaScript运行时:Bun,性能完爆Node火了!新的JavaScript运行时:Bun,性能完爆NodeJul 15, 2022 pm 02:03 PM

今天跟大家介绍一个最新开源的 javaScript 运行时:Bun.js。比 Node.js 快三倍,新 JavaScript 运行时 Bun 火了!

聊聊Node.js中的多进程和多线程聊聊Node.js中的多进程和多线程Jul 25, 2022 pm 07:45 PM

大家都知道 Node.js 是单线程的,却不知它也提供了多进(线)程模块来加速处理一些特殊任务,本文便带领大家了解下 Node.js 的多进(线)程,希望对大家有所帮助!

nodejs中lts是什么意思nodejs中lts是什么意思Jun 29, 2022 pm 03:30 PM

在nodejs中,lts是长期支持的意思,是“Long Time Support”的缩写;Node有奇数版本和偶数版本两条发布流程线,当一个奇数版本发布后,最近的一个偶数版本会立即进入LTS维护计划,一直持续18个月,在之后会有12个月的延长维护期,lts期间可以支持“bug fix”变更。

node爬取数据实例:聊聊怎么抓取小说章节node爬取数据实例:聊聊怎么抓取小说章节May 02, 2022 am 10:00 AM

node怎么爬取数据?下面本篇文章给大家分享一个node爬虫实例,聊聊利用node抓取小说章节的方法,希望对大家有所帮助!

深入浅析Nodejs中的net模块深入浅析Nodejs中的net模块Apr 11, 2022 pm 08:40 PM

本篇文章带大家带大家了解一下Nodejs中的net模块,希望对大家有所帮助!

怎么获取Node性能监控指标?获取方法分享怎么获取Node性能监控指标?获取方法分享Apr 19, 2022 pm 09:25 PM

怎么获取Node性能监控指标?本篇文章来和大家聊聊Node性能监控指标获取方法,希望对大家有所帮助!

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

PhpStorm 맥 버전

PhpStorm 맥 버전

최신(2018.2.1) 전문 PHP 통합 개발 도구

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.