利用遠端 SSH 伺服器架設 SOCKS 代理伺服器(Proxy Server)保護網路傳輸內容

有時候在咖啡廳或者旅館使用免費的無線網路時,不免會擔心有心人士從中攔截網路通訊竊取帳號密碼,而這種受害案例並非少見,就連哈佛商業評論都曾刊登 別再使用公共 Wi-Fi 了 “Why You Really Need to Stop Using Public Wi-Fi” 警告我們使用公共 Wi-Fi 的風險。

但現今很多 APP、系統軟體都需要連網才能使用,在沒有其他可受信任的網路可供連線的情況下,還是得硬著頭皮使用可能不安全的網路。

不過,還是有方法可以保護我們的網路傳輸內容!

本文環境

  • macOS 10.14.2

Virtual Private Server (VPS)

如果你跟我ㄧ樣平常都有租用 VPS 的話,就能夠在遠端 VPS 架設 SSH 伺服器,然後利用 SSH 提供的 port forwarding 功能,將你目前正在使用的電腦網路通訊導向到遠端的 SSH 伺服器,交由遠端的 SSH 伺服器代替你跟外界溝通,溝通完之後再透過你與遠端的 SSH 伺服器之間的加密連線回傳通訊內容給你,使得網路傳輸內容就算遭到竊聽攔截,也難以被有心人士破譯。

以下羅列一些知名的 VPS 服務提供商,如果有租用的需求可以考慮:

設定 SOCKS 代理伺服器

macOS 設定 SOCKS 代理伺服器的方法很簡單:

1
「系統偏好設定」 > 「網路」> 選擇「已連線」網路 > 「進階」 > 「代理伺服器」

如上圖輸入 localhost1337 之後,再打開終端機(Terminal)輸入以下指令建立 localhost:1337 (也就是本機 1337 port )與遠端 SSH 伺服器間的連線:

1
$ ssh -D 1337 -q -C -N -f your_username@your_vps_ip_address

-D 1337 指的是將通往 1337 port 的連線轉往 SSH 伺服器

-q Quiet mode, 將 warning 等訊息隱藏

-C 壓縮所有資料

-N 不執行任何遠端指令(remote command),通常 port forwarding 都會使用 -N

-f 在背景執行連線

順利將 SOCKS 代理伺服器執行之後,可以打開瀏覽器到 What Is My IP? 查看 IP 位址是不是已經換成遠端 SSH 伺服器的 IP ,如果是的話,就代表成功囉!

以上就是如何利用 SSH Port Forwarding 架設 SOCKS 代理伺服器保護網路傳輸內容的教學!

讓我們一起 Stay Safe!

References

https://www.hbrtaiwan.com/article_content_AR0007147.html