隨著互聯(lián)網(wǎng)的發(fā)展,無論是web服務(wù)還是移動APP越來越多的都集成了第三方支付(支付寶、微信、銀聯(lián))。通常作為服務(wù)提供方,支付成功以后都會有一個后端回調(diào)URL來通知是否調(diào)用者是否支付成功,這個URL必須是公網(wǎng)環(huán)境,并且可以被訪問到。然而在實際開發(fā)測試環(huán)境中,我們一般都是在內(nèi)網(wǎng)開發(fā),所以說對于支付測試是一件比較麻煩的事情。
創(chuàng)新互聯(lián)是一家專注于網(wǎng)站設(shè)計、成都網(wǎng)站制作與策劃設(shè)計,松北網(wǎng)站建設(shè)哪家好?創(chuàng)新互聯(lián)做網(wǎng)站,專注于網(wǎng)站建設(shè)十余年,網(wǎng)設(shè)計領(lǐng)域的專業(yè)建站公司;建站業(yè)務(wù)涵蓋:松北等地區(qū)。松北做網(wǎng)站價格咨詢:18982081108內(nèi)網(wǎng)穿透這時候,我們就需要內(nèi)網(wǎng)穿透服務(wù)來解決第三方服務(wù)無法回調(diào)的問題了,下面我們來稍微盤點那些流行的內(nèi)網(wǎng)穿透技術(shù)。
Ngrokngrok 是一個反向代理,通過在公共的端點和本地運行的 Web 服務(wù)器之間建立一個安全的通道。ngrok 可捕獲和分析所有通道上的流量,便于后期分析和重放(百度百科)。
優(yōu)點:使用方便,Docker容器化,配置簡單,各平臺支持,也可以自己搭建服務(wù)器
國內(nèi)也有相應(yīng)的ngrok服務(wù) natapp、frp、nat123端口映射、內(nèi)網(wǎng)通、花生殼等等,這里就不一個個介紹了,有興趣的可以自行谷歌,畢竟今天的主角是Ngrok。
下面一張圖我們來了解一下Ngrok的穿透流程:
環(huán)境說明云服務(wù)器Linux(centos7.4)、Nginx、Docker、hteen/ngrok Docker鏡像,備案域名一枚
安裝說明這里省去了Docker安裝說明,請自行安裝Docker。
獲取ngrok鏡像:docker pull hteen/ngrok
啟動sudo docker run --rm -it -e DOMAIN="ngrok.52itstyle.com" -v /data/ngrok:/myfiles hteen/ngrok /bin/sh /build.sh
安裝成功會出現(xiàn)以下提示(省略中間過程):
Generating RSA private key, 2048 bit long modulus
.............................+++
.............................+++
e is 65537 (0x10001)
Generating RSA private key, 2048 bit long modulus
...............................+++
...............................+++
go get -tags 'release' -d -v ngrok/...
go install -tags 'release' ngrok/main/ngrok
build ok !
客戶端和服務(wù)端生成在/data/ngrok/bin目錄下:
bin/ngrokd 服務(wù)端
bin/ngrok linux客戶端
bin/darwin_amd64/ngrok osx客戶端
bin/windows_amd64/ngrok.exe windows客戶端
啟動Ngrok server由于ngrok默認使用80和443端口,這里我們使用Nginx服務(wù)做轉(zhuǎn)發(fā),通過端口映射的方式訪問Docker容器(參考docker-compose.yml配置)。
docker run -idt --name ngrok-server \
-v /data/ngrok:/myfiles \
-p 8082:80 \
-p 4432:443 \
-p 4443:4443 \
-e DOMAIN='ngrok.52itstyle.com' hteen/ngrok /bin/sh /server.sh
啟動之后需要在nginx.conf 添加兩條反向代理配置(HTTPS請求自行配置):
server {
listen 80;
server_name ngrok.52itstyle.cn *.ngrok.52itstyle.com;
location / {
proxy_redirect off;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://127.0.0.1:8082;
}
}
配置DNS解析服務(wù)啟動后,要想正常運行,我們還需要添加兩條A記錄到云服務(wù)器(替換成自己的IP地址):
啟動Ngrok client首先從data/ngrok/bin目錄下載各個環(huán)境下的客戶端。
windows 環(huán)境首先創(chuàng)建一個ngrok.cfg配置文件:
server_addr: "ngrok.52itstyle.com:4443"
trust_host_root_certs: false
使用cmd命令切換到對應(yīng)的目錄下,然后執(zhí)行以下命令:
ngrok.exe -config ngrok.cfg -subdomain doc 192.168.1.125:4999
如果出現(xiàn)以下界面,說明安裝成功:
Linux 環(huán)境奇了個怪怪,linux下運行一直報以下錯誤,然并不清楚什么原因,有知道的小伙伴還望告知:
-bash: ./ngrok: /lib/ld-musl-x86_64.so.1: bad ELF interpreter: 沒有那個文件或目錄
注意事項最后推薦一款支付寶,微信,銀聯(lián)詳細代碼案例:https://gitee.com/52itstyle/spring-boot-pay
參考https://hub.docker.com/r/hteen/ngrok/
https://hteen.cn/docker/docker-ngrok.html
https://github.com/hteen/docker-ngrok
https://gitee.com/52itstyle/spring-boot-pay