Les méthodes du module http nodejs sont : 1. createServer(), qui peut créer une instance de serveur ; 2. Listen(), qui démarre le serveur pour écouter le port spécifié ; 3. setHeader(); ; 5. end(); 6. get(); 7. requête(), etc.
L'environnement d'exploitation de ce tutoriel : système windows7, nodejs version 12.19.0, ordinateur DELL G3.
1 Utilisation de base
1.1 Propriétés du module
1.1.1 Propriétés de la requête HTTP
en-têtes
: informations d'en-tête de la requête HTTP. headers
:HTTP请求的头信息。
url
:请求的路径。
1.2 模块方法
1.2.1 http模块的方法
createServer(callback)
:创造服务器实例。
1.2.2 服务器实例的方法
listen(port)
:启动服务器监听指定端口。
1.2.3 HTTP回应的方法
setHeader(key, value)
:指定HTTP头信息。
write(str)
:指定HTTP回应的内容。
end()
:发送HTTP回应。
1.3 处理GET请求
Http模块
主要用于搭建HTTP服务
。使用Node.js搭建HTTP服务器非常简单。
var http = require('http'); http.createServer(function (request, response){ response.writeHead(200, {'Content-Type': 'text/plain'}); response.end('Hello World\n'); }).listen(8080, "127.0.0.1"); console.log('Server running on port 8080.');
var http = require("http")
,表示加载http模块createServer方法
,创造一个服务器实例,将它赋给变量http。ceateServer方法
接受一个函数作为参数,该函数的request参数
是一个对象,表示客户端的HTTP请求response.writeHead方法
表示,服务器端回应一个HTTP头信息;response.end
方法表示,服务器端回应的具体内容,以及回应完成后关闭本次对话
listen(8080)
表示启动服务器实例,监听本机的8080端口
$ node app.js
这时命令行窗口将显示一行提示“Server running at port 8080.”
。打开浏览器,访问http://localhost:8080
,网页显示“Hello world!”
。
上面的例子是当场生成网页,也可以事前写好网页,存在文件中,然后利用fs模块读取网页文件,将其返回。
var http = require('http'); var fs = require('fs'); http.createServer(function (request, response){ fs.readFile('data.txt', function readData(err, data) { response.writeHead(200, {'Content-Type': 'text/plain'}); response.end(data); }); }).listen(8080, "127.0.0.1"); console.log('Server running on port 8080.');
下面的修改则是根据不同网址的请求,显示不同的内容,已经相当于做出一个网站的雏形了。
var http = require("http"); http.createServer(function(req, res) { // 主页 if (req.url == "/") { res.writeHead(200, { "Content-Type": "text/html" }); res.end("Welcome to the homepage!"); } // About页面 else if (req.url == "/about") { res.writeHead(200, { "Content-Type": "text/html" }); res.end("Welcome to the about page!"); } // 404错误 else { res.writeHead(404, { "Content-Type": "text/plain" }); res.end("404 error! File not found."); } }).listen(8080, "localhost");
回调函数的req(request)对象,拥有以下属性。
url
:发出请求的网址method
:HTTP请求的方法headers
:HTTP请求的所有HTTP头信息。1.4 处理POST请求
当客户端采用POST
方法发送数据时,服务器端可以对data
和end
两个事件,设立监听函数。
var http = require('http'); http.createServer(function (req, res) { var content = ""; req.on('data', function (chunk) { content += chunk; }); req.on('end', function () { res.writeHead(200, {"Content-Type": "text/plain"}); res.write("You've sent: " + content); res.end(); }); }).listen(8080);
data
事件会在数据接收过程中,每收到一段数据就触发一次,接收到的数据被传入回调函数。end
事件则是在所有数据接收完成后触发。
对上面代码稍加修改,就可以做出文件上传的功能。
"use strict"; var http = require('http'); var fs = require('fs'); var destinationFile, fileSize, uploadedBytes; http.createServer(function (request, response) { response.writeHead(200); destinationFile = fs.createWriteStream("destination.md"); request.pipe(destinationFile); fileSize = request.headers['content-length']; uploadedBytes = 0; request.on('data', function (d) { uploadedBytes += d.length; var p = (uploadedBytes / fileSize) * 100; response.write("Uploading " + parseInt(p, 0) + " %\n"); }); request.on('end', function () { response.end("File Upload Complete"); }); }).listen(3030, function () { console.log("server started"); });
2 发出请求
2.1 get()
get方法
用于发出get请求。
function getTestPersonaLoginCredentials(callback) { return http.get({ host: 'personatestuser.org', path: '/email' }, function(response) { var body = ''; response.on('data', function(d) { body += d; }); response.on('end', function() { var parsed = JSON.parse(body); callback({ email: parsed.email, password: parsed.pass }); }); }); },
2.2 request()
request方法
用于发出HTTP请求
,它的使用格式如下。
http.request(options[, callback])
request方法的options参数,可以是一个对象,也可以是一个字符串。如果是字符串,就表示这是一个URL,Node内部就会自动调用url.parse()
,处理这个参数。options对象
url
: Le chemin demandé. 🎜🎜🎜1.2 Méthodes du module 🎜🎜🎜1.2.1 Méthodes du module http 🎜🎜createServer(callback)
: Créez une instance de serveur. 🎜🎜1.2.2 Méthodes d'instance de serveur🎜🎜listen(port)
: démarrez le serveur pour écouter le port spécifié. 🎜🎜1.2.3 Méthode de réponse HTTP🎜🎜🎜🎜setHeader(key, value)
: spécifiez les informations d'en-tête HTTP. 🎜🎜🎜write(str)
: Spécifiez le contenu de la réponse HTTP. 🎜🎜🎜end()
: Envoyer une réponse HTTP. 🎜🎜🎜1.3 Traitement des requêtes GET🎜🎜🎜Le module HTTP
est principalement utilisé pour créer le service HTTP
. Construire un serveur HTTP à l'aide de Node.js est très simple. 🎜var postData = querystring.stringify({ 'msg' : 'Hello World!' }); var options = { hostname: 'www.google.com', port: 80, path: '/upload', method: 'POST', headers: { 'Content-Type': 'application/x-www-form-urlencoded', 'Content-Length': postData.length } }; var req = http.request(options, function(res) { console.log('STATUS: ' + res.statusCode); console.log('HEADERS: ' + JSON.stringify(res.headers)); res.setEncoding('utf8'); res.on('data', function (chunk) { console.log('BODY: ' + chunk); }); }); req.on('error', function(e) { console.log('problem with request: ' + e.message); }); // write data to request body req.write(postData); req.end();
var http = require("http")
signifie charger le module http🎜Ensuite, appelez la méthode createServer du module http
code>, créez une instance de serveur et affectez-la à la variable http. 🎜La méthode ceateServer
accepte une fonction en paramètre. Le paramètre de requête
de la fonction est un objet, représentant la requête HTTP du client.🎜Le Le paramètre de réponse est également un objet représentant la réponse HTTP côté serveur. La méthode response.writeHead
indique que le serveur répond avec un en-tête HTTP ; la méthode response.end
indique le contenu spécifique de la réponse du serveur, et ferme cette page. une fois la réponse terminée. conversation
🎜Le dernier listen(8080)
signifie démarrer l'instance de serveur et écouter le port 8080 local
openssl genrsa -out key.pem openssl req -new -key key.pem -out csr.pem openssl x509 -req -days 9999 -in csr.pem -signkey key.pem -out cert.pem rm csr.pem
"Serveur exécuté sur le port 8080."
. Ouvrez le navigateur et visitez http://localhost:8080
. La page Web affiche « Bonjour tout le monde ! »
. var https = require('https'); var fs = require('fs'); var options = { key: fs.readFileSync('key.pem'), cert: fs.readFileSync('cert.pem') }; var a = https.createServer(options, function (req, res) { res.writeHead(200); res.end("hello world\n"); }).listen(8000);
curl -k https://localhost:8000
url
: URL de la requête🎜method
: Méthode de requête HTTP🎜headers
: Tous Informations d'en-tête HTTP pour les requêtes HTTP. POST
pour envoyer des données, le serveur peut traiter les données
et fin
Deux événements, mise en place des fonctions d'écoute. L'événement 🎜rrreee🎜data
sera déclenché chaque fois qu'une donnée est reçue pendant le processus de réception de données, et les données reçues sont transmises à la fonction de rappel. L'événement end
est déclenché une fois la réception de toutes les données terminée. méthode get
est utilisée pour faire une requête get. 🎜rrreee🎜🎜2.2 request()🎜méthode de requête
est utilisée pour émettre une requête HTTP
, son format d'utilisation est le suivant. 🎜rrreee🎜Le paramètre options de la méthode de requête peut être un objet ou une chaîne. S'il s'agit d'une chaîne, cela signifie qu'il s'agit d'une URL, et Node appellera automatiquement url.parse()
en interne pour traiter ce paramètre. l'objet options
peut définir les propriétés suivantes🎜host
:HTTP请求所发往的域名或者IP地址,默认是localhosthostname
:该属性会被url.parse()解析,优先级高于host。port
:远程服务器的端口,默认是80。localAddress
:本地网络接口。socketPath
:Unix网络套接字,格式为host:port或者socketPath。method
:指定HTTP请求的方法,格式为字符串,默认为GET。path
:指定HTTP请求的路径,默认为根路径(/)。可以在这个属性里面,指定查询字符串,比如/index.html?page=12。如果这个属性里面包含非法字符(比如空格),就会抛出一个错误。headers
:一个对象,包含了HTTP请求的头信息。auth
:一个代表HTTP基本认证的字符串user:password。agent
:控制缓存行为,如果HTTP请求使用了agent,则HTTP请求默认为Connection: keep-alive,它的可能值如下:undefined
(默认):对当前host和port,使用全局Agent。Agent
:一个对象,会传入agent属性。false
:不缓存连接,默认HTTP请求为Connection: close。keepAlive
:一个布尔值,表示是否保留socket供未来其他请求使用,默认等于false。keepAliveMsecs
:一个整数,当使用KeepAlive的时候,设置多久发送一个TCP KeepAlive包,使得连接不要被关闭。默认等于1000,只有keepAlive设为true的时候,该设置才有意义。request
方法的callback参数
是可选的,在response事件发生时触发,而且只触发一次。http.request()
返回一个http.ClientRequest类
的实例。它是一个可写数据流,如果你想通过POST方法发送一个文件,可以将文件写入这个ClientRequest对象
。var postData = querystring.stringify({ 'msg' : 'Hello World!' }); var options = { hostname: 'www.google.com', port: 80, path: '/upload', method: 'POST', headers: { 'Content-Type': 'application/x-www-form-urlencoded', 'Content-Length': postData.length } }; var req = http.request(options, function(res) { console.log('STATUS: ' + res.statusCode); console.log('HEADERS: ' + JSON.stringify(res.headers)); res.setEncoding('utf8'); res.on('data', function (chunk) { console.log('BODY: ' + chunk); }); }); req.on('error', function(e) { console.log('problem with request: ' + e.message); }); // write data to request body req.write(postData); req.end();
注意
,上面代码中,req.end()
必须被调用,即使没有在请求体内写入任何数据,也必须调用。因为这表示已经完成HTTP请求
。
发送过程的任何错误(DNS错误、TCP错误、HTTP解析错误
),都会在request对象上触发error事件
。
3 搭建HTTPs服务器
搭建HTTPs
服务器需要有SSL
证书。对于向公众提供服务的网站,SSL证书
需要向证书颁发机构购买;对于自用的网站,可以自制。
自制SSL证书需要OpenSSL,具体命令如下。
openssl genrsa -out key.pem openssl req -new -key key.pem -out csr.pem openssl x509 -req -days 9999 -in csr.pem -signkey key.pem -out cert.pem rm csr.pem
上面的命令生成两个文件:ert.pem(证书文件)
和 key.pem(私钥文件)
。有了这两个文件,就可以运行HTTPs服务器了。Node.js
提供一个https
模块,专门用于处理加密访问。
var https = require('https'); var fs = require('fs'); var options = { key: fs.readFileSync('key.pem'), cert: fs.readFileSync('cert.pem') }; var a = https.createServer(options, function (req, res) { res.writeHead(200); res.end("hello world\n"); }).listen(8000);
上面代码显示,HTTPs服务器与HTTP服务器的最大区别,就是createServer
方法多了一个options参数
。运行以后,就可以测试是否能够正常访问。
curl -k https://localhost:8000
更多node相关知识,请访问:nodejs 教程!
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!