背景:
有一些客户的服务是我本地windows电脑开vpn之后才能访问的。为了让公司内网的别的电脑不开vpn也能正常请求客户的接口,方便调试,所以使用我的windows电脑实现一个代理的功能。
原理简单画个图:
功能简单直接上代码:
from flask import Flask, request, Response
import requests
app = Flask(__name__)
@app.route('/<path:dummy>', methods=['GET', 'POST'])
def proxy(dummy):
host = request.host
print("请求host:", host)
if host == "proxy_aaaaaa.cn:5000":
proxy_service = "https://aaaaaa.cn"
pass
elif host == "proxy_bbbbbb.cn:5000":
proxy_service = "http://bbbbbb.cn"
pass
elif host == "proxy_cccccc.com:5000":
proxy_service = "https://cccccc.com"
# 获取请求 URL
url = f'{proxy_service}/{dummy}'
print(f"真实请求的url:{url}")
print(f"真实请求的method:{request.method}")
params = request.args
print(f"真实请求的url字符串传参:{dict(request.args)}")
form_data = dict(request.form)
print("真实请求的form_data传参:", form_data)
# 转发请求到目标服务器, 这里只代理了form_data传参和url查询字符串传参, 如果是json传参可以加上
response = requests.request(
method=request.method,
url=url,
params=params,
data=form_data,
)
# 将目标服务器的响应返回给客户端
print(f"真实响应status_code: {response.status_code}")
return Response(response.content, content_type=response.headers['Content-Type'], status=response.status_code)
if __name__ == '__main__':
app.run(host="0.0.0.0", port=5000, debug=False)
上面是代理的客户的三个服务, 我通过我本机的hosts文件区分访问的哪个真实的服务,hosts文件windows机器一般在 C:\Windows\System32\drivers\etc 这个位置
本地hosts配置:
192.168.9.243 proxy_aaaaaa.cn proxy_bbbbbb.cn proxy_cccccc.com
请求的时候把原始的域名换成代理的域名就好了:
# HOST = "http://aaaaaa.cn" # 把客户原始的域名换成代理的域名就好了
HOST = "http://proxy_aaaaaa.cn"