应用nginx处理跨域成绩的办法(以flask为例)
发布时间:2017-03-23 12:16 来源:互联网 以后栏目:web技巧类
媒介
我们单位的架构是在api和js之间架构一个中心层(python编写),以完成后端衬着,登录状况剖断,跨域转发api等功能。然则如许一个中心会使前端工程师的任务量乘上两倍,本来js可以直接ajax请求api,然则我们不能不ajax请求中心层,中心层再请求api。
如图:
为了少敲代码,进步任务效力,我们固然欲望将python中心层砍掉落,然则若何处理以下三个成绩,成为关键:
后端衬着 登录状况剖断 跨域转发api关于1,2我会在别的两篇博客中详细论述,这篇文章重要处理3,也就是跨域成绩。处理跨域成绩办法很多:反向代理,jsonp,Cross-Origin Resource Sharing等,我们明天经过过程nginx反向代理完成。
新建两个flask法式榜样来实验
翻开pycharm,新建项目选择flask,name分别设为client和server。
编写client和server的python文件,使其分别跑在5000端口和5001端口:
client.py
from flask import Flaskapp = Flask(__name__)@app.route('/') def hello_world(): return 'this is client'if __name__ == '__main__': app.run(port=5000)
server.py
from flask import Flaskapp = Flask(__name__)@app.route('/') def hello_world(): return 'this is server' @app.route('/api/') def api(): return 'api'if __name__ == '__main__': app.run(port=5001)
运转client.py
运转server.py
装置nginx(ubuntu)
翻开新立得,搜刮nginx,选中并装置。ubuntu就是这么简单,其他平台暂不论述,可自行搜刮。
设备nginx,使其将5000端口(客户端)的请求转发到5001端口(办事器端)
翻开nginx默许的设备文件:
sudo gedit /etc/nginx/sites-available/default
在文件末尾添加以下敕令:
## demo listen 5017 proxy 5000 and 5001 ##server { listen 5017; server_name a.xxx.com; access_log /var/log/nginx/a.access.log; error_log /var/log/nginx/a.error.log; root html; index index.html index.htm index.php; ## send request back to flask ## location / { proxy_pass http://127.0.0.1:5000/ ; #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; } location /proxy { rewrite ^.+proxy/?(.*)$ /$1 break; proxy_pass http://127.0.0.1:5001/ ; #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; }}## End a.xxx.com ##
1、
2、
3、
4、
5、
6、
7、
8、
9、
10、
11、
12、
13、
14、
15、
16、
17、
18、
19、
20、
21、
22、
23、
24、
25、
1、
2、
3、
4、
5、
6、
7、
8、
9、
10、
11、
12、
13、
14、
15、
16、
17、
18、
19、
20、
21、
22、
23、
24、
25、