DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> 8 行 Node.js 代碼實現代理服務器
8 行 Node.js 代碼實現代理服務器
編輯:關於JavaScript     

接觸 Node.js 已有多年,一直喜歡它的單線程模型和異步IO特性,以及 JavaScript 語言本身的靈活性。同時,JavaScript 前後端通吃,在全棧開發領域具有獨特的優勢。今天就來看看作為服務端語言的 JavaScript,完成一個簡單的代理服務器功能是多麼容易。

簡單地說,代理服務器就是代理用戶訪問目標站點的中介服務器。作為前端開發人員,代理的常見用途是跨域訪問後台 API。當然,還可以用來科學上網。今天要分享的代碼,就是跟科學上網有關。

話不多說,先上 code:

var express = require('express');
var request = require('request');
var app = express();
app.use('/', function(req, res) {
 var url = 'https://www.baidu.com/' + req.url;
 req.pipe(request(url)).pipe(res);
});
app.listen(process.env.PORT || 3000); 

不到 10 行的代碼,就實現了簡單的代理服務器功能。是不是很神奇?

熟悉 Node.js 的話應該很容易看明白這幾行代碼。首先加載 express 模塊,這個是創建 HTTP 服務器的一個流行框架。然後是 request,它封裝了 HTTP 請求的各種方法,讓發起請求變得非常容易。接下來實例化一個 express 對象,設置訪問路由。最後監聽 3000 端口。

先看效果。保存上述代碼到文件 proxy.js,在文件所在路徑執行:

node proxy.js

用浏覽器打開http://localhost:3000/

關鍵代碼在路由處理方法內。

req.pipe(request(url)).pipe(res);

這個 pipe 方法很神奇,正如它的名字(管道)一樣,它把浏覽器的請求數據傳給 request 客戶端,然後將目標服務器的響應數據傳回浏覽器。這代碼太TM簡潔了!

那麼,怎麼實現科學上網呢?對,把代碼放到沒有網絡封鎖的服務器上運行,就OK了。比如,這個 任度搜 www.rendoso.com 背後就是 Google 代理。

歡迎拍(da)磚(shang)。

以上就是本文的全部內容,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,同時也希望多多支持!

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved