This article will introduce you to the Node.js http module and introduce the createServer and listen methods. I hope it will be helpful to you!
http module
Use Node.js to create Web services, mainly relying on the built-in http
module. The classic express.js and koa.js frameworks are all encapsulated to varying degrees with the http
module as the core.
Creating the simplest web service only requires a few lines of code. Create a new index.js
file and enter the following content:
// 1.导入 http 模块 const http = require('http'); // 2. 调用 createServer 方法创建服务 const server = http.createServer((request, response) => { // 3.响应给浏览器的内容 response.end('Hello, World'); }); // 4.执行 listen 方法,启动服务 server.listen(3000, () => { console.log('服务器启动成功:http://localhost:3000') })
Then open the command line tool and use the node
command to execute the file:
node index.js
The command line tool will print:
服务器启动成功:http://localhost:3000
Then open the browser and visit http://localhost:3000, you will see the following content:
At this point, a web service is created with just 6 lines of code. [Related tutorial recommendations: nodejs video tutorial, Programming teaching]
createServer method
As you can see, the core method of creating a Web service iscreateServer
method.
It receives a callback function, and the callback parameter receives two parameters, which are:
- request object: represents the HTTP request object, which contains the client’s request The information carried
- response object: represents the HTTP response object, used toset the response information to the client
This callback function is the processing http request, the main place to set the http response. Therefore, writing a web service actually means constantly processing the request and response content in this function. This is also determined by the request-response model based on the HTTP protocol itself. Of course, in actual development, we definitely cannot write in such a mixed manner. We all use frameworks, which will have very reasonable middleware mechanisms and layering.
listen method
We all know that the TCP protocol is the underlying protocol of the HTTP protocol, and all HTTP request data is transmitted using TCP. To send an HTTP request, a TCP connection must be established first.
The same is true for creating HTTP services in Node. After the createServer
method is executed, an instance of the Server
class will be created. The Server
class inherits from # in another built-in module net
##Server class, it has a
listen method. Below are the relevant type declarations to understand the relationship.
// net 模块 class Server extends EventEmitter { /** * 启动服务器监听连接。此 Server 可以是 TCP 或 IPC 服务器,具体取决于它所监听的内容。 */ // 有若干重载,这是最常使用的一种方法 listen(port?: number, hostname?: string, listeningListener?: () => void): this; listen(port?: number, listeningListener?: () => void): this; } // http 模块 import { Server as NetServer } from 'node:net'; function createServer< Request extends typeof IncomingMessage = typeof IncomingMessage, Response extends typeof ServerResponse = typeof ServerResponse, >(requestListener?: RequestListener<Request, Response>): Server<Request, Response>; class Server< Request extends typeof IncomingMessage = typeof IncomingMessage, Response extends typeof ServerResponse = typeof ServerResponse, > extends NetServer {}So after creating the service through the
createServer method,
call the listen method to start the service and listen for the connection
.
server.listen(3000, () => { console.log('服务器启动成功:http://localhost:3000') })If the service fails to start, such as when the port is occupied, An error will be reported directly in the console, and the subsequent callback function will no longer be executed. Introducing two other overloads, which are not used much. One is
without specifying the port number. At this time, the operating system will randomly assign an available port number. After the service is started successfully, you can obtain the assigned port number through the server.address().port property:
server.listen(() => { const port = server.address().port console.log(port) console.log('服务器启动成功:http://localhost:', port) })Try it:
specify the host name to be monitored.
Whenhost is not specified, the default is
0.0.0.0 (IPv4) or
:: (IPv6),
supports network Access all hosts in .
locolhost or
127.0.0.1, you can only access it from your own host.
server.listen(3000, 'localhost', () => { console.log('服务器启动成功:http://localhost:', port) })SummaryWe have introduced the basic usage of the
http module, mainly using
createServer to create services, and then calling
listen Method to start the service and listen for connections.
createServer The callback function is received to process a specific request. Writing web services mainly uses the two parameters of the callback function,
request and
response, which will be introduced in detail later. .
nodejs tutorial!
The above is the detailed content of Node http module learning: talk about basic usage. For more information, please follow other related articles on the PHP Chinese website!

JavaScript is widely used in websites, mobile applications, desktop applications and server-side programming. 1) In website development, JavaScript operates DOM together with HTML and CSS to achieve dynamic effects and supports frameworks such as jQuery and React. 2) Through ReactNative and Ionic, JavaScript is used to develop cross-platform mobile applications. 3) The Electron framework enables JavaScript to build desktop applications. 4) Node.js allows JavaScript to run on the server side and supports high concurrent requests.

Python is more suitable for data science and automation, while JavaScript is more suitable for front-end and full-stack development. 1. Python performs well in data science and machine learning, using libraries such as NumPy and Pandas for data processing and modeling. 2. Python is concise and efficient in automation and scripting. 3. JavaScript is indispensable in front-end development and is used to build dynamic web pages and single-page applications. 4. JavaScript plays a role in back-end development through Node.js and supports full-stack development.

C and C play a vital role in the JavaScript engine, mainly used to implement interpreters and JIT compilers. 1) C is used to parse JavaScript source code and generate an abstract syntax tree. 2) C is responsible for generating and executing bytecode. 3) C implements the JIT compiler, optimizes and compiles hot-spot code at runtime, and significantly improves the execution efficiency of JavaScript.

JavaScript's application in the real world includes front-end and back-end development. 1) Display front-end applications by building a TODO list application, involving DOM operations and event processing. 2) Build RESTfulAPI through Node.js and Express to demonstrate back-end applications.

The main uses of JavaScript in web development include client interaction, form verification and asynchronous communication. 1) Dynamic content update and user interaction through DOM operations; 2) Client verification is carried out before the user submits data to improve the user experience; 3) Refreshless communication with the server is achieved through AJAX technology.

Understanding how JavaScript engine works internally is important to developers because it helps write more efficient code and understand performance bottlenecks and optimization strategies. 1) The engine's workflow includes three stages: parsing, compiling and execution; 2) During the execution process, the engine will perform dynamic optimization, such as inline cache and hidden classes; 3) Best practices include avoiding global variables, optimizing loops, using const and lets, and avoiding excessive use of closures.

Python is more suitable for beginners, with a smooth learning curve and concise syntax; JavaScript is suitable for front-end development, with a steep learning curve and flexible syntax. 1. Python syntax is intuitive and suitable for data science and back-end development. 2. JavaScript is flexible and widely used in front-end and server-side programming.

Python and JavaScript have their own advantages and disadvantages in terms of community, libraries and resources. 1) The Python community is friendly and suitable for beginners, but the front-end development resources are not as rich as JavaScript. 2) Python is powerful in data science and machine learning libraries, while JavaScript is better in front-end development libraries and frameworks. 3) Both have rich learning resources, but Python is suitable for starting with official documents, while JavaScript is better with MDNWebDocs. The choice should be based on project needs and personal interests.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment

WebStorm Mac version
Useful JavaScript development tools

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

Notepad++7.3.1
Easy-to-use and free code editor