首发于个人博客《若水斋:Nginx反向代理Gοοgle 》。
在某些网络环境下不能使用代理,如管理较为严格的公司中,但仍有访问Gοοgle的需求。这种情况下可以事先搭建好Gοοgle反向代理,在公司时通过访问反向代理来使用Gοοgle搜索。前提条件是有一台在公司可以访问且它也可以访问Gοοgle的VPS(Virtual Private Server 虚拟专用服务器)。
我选择使用Nginx来建反向代理,我的Nginx版本是:
nginx/1.10.3 (Ubuntu)
给出配置文件:
server {
listen 80;
listen [::]:80;
server_name search.werner.wiki;
rewrite ^(.*) https://$server_name$1 permanent;
}
server {
listen 443 ssl;
server_name search.werner.wiki;
auth_basic "Restricted Access";
auth_basic_user_file /etc/nginx/httppasswd.users;
ssl_certificate ssl/chain.pem;
ssl_certificate_key ssl/private.key;
ssl_session_cache shared:SSL:1m;
ssl_session_timeout 5m;
ssl_ciphers HIGH:!aNULL:!MD5;
ssl_prefer_server_ciphers on;
underscores_in_headers on;
add_header Access-Control-Allow-Origin *;
add_header Access-Control-Allow-Headers X-Requested-With;
add_header Access-Control-Allow-Methods GET,POST,OPTIONS;
location / {
proxy_pass https://www.google.com;
sub_filter www.google.com search.werner.wiki;
sub_filter_once off;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto https;
proxy_set_header User-Agent $http_user_agent;
proxy_set_header Accept-Language "zh-CN";
proxy_set_header Accept-Encoding "gzip, deflate, br";
proxy_redirect http://www.google.com/ /;
proxy_cookie_domain google.com search.werner.wiki;
proxy_connect_timeout 240;
proxy_send_timeout 240;
proxy_read_timeout 240;
}
}
配置文件的含义如下:
server_name search.werner.wiki;
这句话的含义是服务名为search.werner.wiki,即只有头部Host字段值为search.werner.wiki的HTTP请求才归此配置文件。
server {
listen 80;
listen [::]:80;
server_name search.werner.wiki;
rewrite ^(.*) https://$server_name$1 permanent;
}
这一段配置新建了一个服务,监听80端口,永久(permanent)重定向(rewrite)所有请求(^(.*))到https,参数不变($1)。
开启认证的原因是Gοοgle反向代理使用的人越少,生命力越强。
auth_basic "Restricted Access";
auth_basic_user_file /etc/nginx/httppasswd.users;
这两句开启了HTTP基本认证,认证由Nginx的ngx_http_auth_basic_module模块提供。auth_basic可设置为off或其它字符串,为off时表示不开启密码验证。auth_basic_user_file 为包含用户名和密码的文件,最好写成绝对路径,文件内容为一行一个用户名和密码,用户名和密码之间用冒号分隔。密码当然不是明文存储的,支持以下几种加密方式:
我使用如下的命令生成用户名和密码:
sudo htpasswd -bc /etc/nginx/httppasswd.users Admin DWfvmAGMvGNOadmEjF
将反向代理配置为通过HTTPS更加安全。相关配置为:
ssl_certificate ssl/chain.pem; # 证书
ssl_certificate_key ssl/private.key; # 私钥
ssl_session_cache shared:SSL:1m; # SSL会话缓存,提供性能
ssl_session_timeout 5m; # SSL会话超时时间
ssl_ciphers HIGH:!aNULL:!MD5; # 不使用MD5等弱密码组件
ssl_prefer_server_ciphers on; # SSLv3或TLSv1握手时服务器密码优先
不忽略HTTP头部中的下划线:
underscores_in_headers on;
HTTP响应头中添加字段以支持跨域访问:
add_header Access-Control-Allow-Origin *;
add_header Access-Control-Allow-Headers X-Requested-With;
add_header Access-Control-Allow-Methods GET,POST,OPTIONS;
proxy_pass https://www.google.com;
反向代理的目标地址。
sub_filter www.google.com search.werner.wiki;
替换返回页面中的字符串“www.google.com”为“search.werner.wiki”。注意若是被代理服务器返回压缩过的页面,则替换不能成功。
sub_filter_once off;
关闭只替换一次,即全部替换。
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto https;
在代理发出的HTTP请求头中添加字段。添加这些字段让被代理服务器可以获取到访问者真实IP地址。换句话说,有这些字段,这个代理便不是高匿代理。
proxy_set_header User-Agent $http_user_agent;
proxy_set_header Accept-Language "zh-CN";
proxy_set_header Accept-Encoding "";
在代理发出的HTTP请求头中添加字段。这些字段是浏览器用户代理,语言和接受的编码。"Accept-Encoding"设置为空,防止被代理服务器返回压缩内容,使得内容替换配置失效。
proxy_redirect http://www.google.com/ /;
修改从被代理服务器传来的HTTP响应的头部中的"Location"和"Refresh"字段,将“http://www.google.com/”重写为“/”。
proxy_cookie_domain google.com search.werner.wiki;
修改从被代理服务器传来的HTTP响应的头部set-cookie中的domain,将domain的值由“google.com”替换为“search.werner.wiki”。
proxy_connect_timeout 240;
proxy_send_timeout 240;
proxy_read_timeout 240;
设置几个超时时间。
反向代理的好处是只要有浏览器便可以使用Gοοgle搜索,就像使用百度搜索一样方便。缺点是只能使用Gοοgle搜索,不能访问Facebοοk等网站。但这有什么关系呢?只要能使用Gοοgle搜索就足够了。