在node中,代理用於從原始伺服器中獲取內容,客戶端向代理髮送一個請求並指定目標,也就是原始伺服器,然後代理程式向原始伺服器轉交請求並將獲得的內容傳回給客戶端。
本文操作環境:Windows10系統、nodejs 12.19.0版、Dell G3電腦。
正向代理
#正向代理,也就是傳說中的代理,他的工作原理就像一個跳板,簡單的說,我是一個用戶,我訪問不了某網站,但是我能訪問一個代理服務器這個代理服務器呢,他能訪問那個我不能訪問的網站於是我先連上代理服務器,告訴他我需要那個無法訪問網站的內容代理伺服器去取回,然後返回給我。
從網站的角度,只在代理伺服器來取內容的時候有一次記錄有時候並不知道是用戶的請求,也隱藏了用戶的資料,這取決於代理告不告訴網站。
結論就是 正向代理 是位於客戶端和原始伺服器(origin server)之間的伺服器,為了從原始伺服器取得內容,客戶端向代理程式傳送一個請求並指定目標(原始伺服器),然後代理向原始伺服器轉交請求並將獲得的內容傳回給客戶端。客戶端必須要進行一些特別的設定才能使用正向代理。
反向代理的概念
繼續範例:例使用者造訪 http://ooxx.me/readme 但ooxx.me上並不存在readme頁面他是偷偷從另外一台伺服器上取回,然後作為自己的內容吐給用戶,但用戶並不知情這很正常,用戶一般都很笨。
這裡所提到的 ooxx.me 這個網域對應的伺服器就設定了反向代理功能。結論就是 反向代理正好相反,對於客戶端而言它就像是原始伺服器,並且客戶端不需要進行任何特別的設定。客戶端向反向代理 的命名空間(name-space)中的內容發送普通請求,接著反向代理將判斷向何處(原始伺服器)轉交請求,並將獲得的內容傳回給客戶端,就像這些內容 原本就是它自己的一樣。
兩者差異
從用途 上來講
正向代理程式的典型用途是為在防火牆內的區域網路用戶端提供存取Internet的途徑。正向代理還可以使用緩衝特性減少網路使用率。反向代理的典型用途是將 防火牆後面的伺服器提供給Internet用戶存取。反向代理還可以為後端的多台伺服器提供負載平衡,或為後端較慢的伺服器提供緩衝服務。另外,反向代理還可以啟用高階URL策略和管理技術,讓處於不同web伺服器系統的web頁面同時存在於同一個URL空間下。
從安全性 來講:
正向代理程式允許客戶端透過它存取任意網站並且隱藏客戶端自身,因此你必須採取安全措施以確保僅為經過授權的客戶端提供服務。反向代理對外都是透明的,訪客並不知道自己造訪的是一個代理。
推薦學習:《nodejs影片教學》
以上是node代理有什麼用的詳細內容。更多資訊請關注PHP中文網其他相關文章!