使用nginx反向代理,一个80端口下,配置多个微信项目
2017-01-03 17:57
579 查看
我们要接入微信公众号平台开发,需要填写服务器配置,然后依据接口文档才能实现业务逻辑。但是微信公众号接口只支持80接口(80端口)。我们因业务需求需要在一个公众号域名下面,发布两个需要微信授权的项目,怎么办?
我们可以用nginx服务器做反向代理来解决这个问题。nginx服务器对外80端口,然后根据URL参数不同,对内访问不同的项目。
View Code
当我们打开URL包含h5时,就会跳到8081端口项目中,但是对外还是80端口。所以两个项目可以同时实现微信授权登录等。
我们可以用nginx服务器做反向代理来解决这个问题。nginx服务器对外80端口,然后根据URL参数不同,对内访问不同的项目。
worker_processes 2; events { worker_connections 1024; } http { include mime.types; default_type application/octet-stream; access_log /home/nginx_log/reverse_proxy_no1_access.log; sendfile on; keepalive_timeout 65; upstream backend1 { #server 192.168.1.1:8181; server 192.168.1.1:8081; } upstream backend2 { #server 192.168.1.1:8082; server 192.168.1.1:8082; } proxy_cache_path /tmp/cache levels=1:2 keys_zone=cache:128m inactive=30m max_size=1G; server { listen 8081; server_name h5.xxxx.com; location / { proxy_pass http://backend1; #Proxy Settings 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_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504; proxy_max_temp_file_size 0; proxy_connect_timeout 90; proxy_send_timeout 90; proxy_read_timeout 90; proxy_buffer_size 4k; proxy_buffers 4 32k; proxy_busy_buffers_size 64k; proxy_temp_file_write_size 64k; add_header Nginx-Res "http://backend1"; } location ~ ^/(h5)(.*)$ { proxy_pass http://backend2; proxy_redirect off; proxy_set_header Host $host; proxy_cache cache; proxy_cache_valid 200 302 1d; proxy_cache_valid 301 1d; proxy_cache_valid any 1m; expires 1h; add_header Nginx-Res "http://backend2"; proxy_ignore_headers "Cache-Control" "Expires" "Set-Cookie"; add_header Nginx-Cache "$upstream_cache_status"; } error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } location ~ .*\.(gif|jpg|png|css|js|ico)(.*) { proxy_pass http://backend1; proxy_redirect off; proxy_set_header Host $host; proxy_cache cache; proxy_cache_valid 200 302 30d; proxy_cache_valid 301 1d; proxy_cache_valid any 1m; expires 30d; proxy_ignore_headers "Cache-Control" "Expires" "Set-Cookie"; add_header Nginx-Res "http://backend1"; add_header Nginx-Cache "$upstream_cache_status"; }
View Code
当我们打开URL包含h5时,就会跳到8081端口项目中,但是对外还是80端口。所以两个项目可以同时实现微信授权登录等。
相关文章推荐
- Nginx反向代理一个80端口下配置多个微信项目详解
- maven hello world: 使用maven前的一些配置和命令行创建一个webapp项目
- 一个基于servlet 3.0的不使用web.xml配置文件的建议web项目demo
- 【SpringMVC】Intellij Idea搭建一个完整的 spring mvc项目 (附带ibatis的配置与使用)
- nodejs安装,配置环境,使用express建立一个新项目
- tomcat 不使用ROOT 使用server.xml配置 去除项目名 使用80端口访问项目
- nodejs安装,配置环境,使用express建立一个新项目
- 使用Visual Studio .NET 2010的配置和条件编译在一个项目实现不同版本
- java项目中使用angularjs1.X,解决微信内置h5支付授权目录配置
- 关于在tomcat中一个80端口跑多个项目的配置
- 使用VUE-CLI构建一个项目基本的配置
- tomcat 不使用ROOT 使用server.xml配置 去除项目名 使用80端口访问项目
- 使用MyEclipse开发Java EE应用:如何配置一个独立的Java项目
- Tomcat配置不使用项目名访问并修改为80端口
- 项目使用log4j,指定日志打印出来的格式,打印到指定文件夹,每天打印一个日志等配置
- 不同的项目使用同一个配置文件
- 如何使用Android Studio打开一个App项目,导入Android App项目需要修改哪些配置文件?
- 同时使用apache和IIS,共用80端口的一个解决方案
- 使用VIM开发软件项目 - (4) 保存项目相关配置