windows python + flask + nginx同局域下开放接口

由于flask本地启用后,只能自己调用,同局域网下想给其他同事使用,是无法访问的,因此通过nginx对外开放ip+端口,然后转发进行调用。

第一种方式

1、先确定好启动端口,如我使用的是9900

2、下载windows版本nginx

 nginx: download

2.1、解压后修改conf文件配置:\nginx\conf\nginx.conf,添加以下配置,表示对外开放5000端口,然后转发到本地9900端口

    server {
        listen       5000;
        server_name  localhost;
        server_name  127.0.0.1;     
        charset     utf-8; 

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            root   html;
            index  index.html index.htm;
            proxy_pass  http://localhost:9900;
        }

2.2、由于启动的时候默认会开一个80端口,常出现端口被占用的情况,因此可以直接把80端口的部分直接替换成2.1的部分

查看nginx的版本号:nginx -v

启动nginx:start nginx

快速停止或关闭nginx:nginx -s stop

正常停止或关闭nginx:nginx -s quit

配置文件nginx.conf修改重装载命令:nginx -s reload

 2.3、启用flask服务,他人使用启动服务的计算机ip地址就可以访问

 第二种方式

 1、网上看到过另一种方法,不确定具体场景有什么用,但效果一样,区别在多加一个service.py文件,加载flask的启动文件,如图

参考博客:在 Windows 平台部署 Flask_stone0823的博客-CSDN博客_windows下flask部署

from tornado.httpserver import HTTPServer
from tornado.wsgi import WSGIContainer
from mockInterface import app
from tornado.ioloop import IOLoop
s = HTTPServer(WSGIContainer(app))
s.listen(9900) # 监听 9900 端口
IOLoop.current().start()

 2、过程遇到no module named "XX"问题,可采取加路径的方法解决问题,以后遇到这个情况也是同样的解决

sys.path.append('你的项目路径')

sys.path.append('包路径') 

  • 0
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
根据提供的引用内容,没有找到与Python+Flask+crsf相关的信息。但是,可以介绍一下Python+Flask+CSRF的相关内容。 CSRF(Cross-Site Request Forgery)跨站请求伪造,是一种常见的Web攻击方式。攻击者通过某些手段诱导用户点击链接或访问恶意网站,从而在用户不知情的情况下,以用户的身份向目标网站发送请求,执行某些恶意操作。 为了防止CSRF攻击,Flask-WTF提供了CSRF保护机制。在使用Flask-WTF时,需要在表单中添加一个隐藏字段,该字段包含一个加密的token,用于验证表单提交的来源是否合法。Flask-WTF会自动为每个表单生成一个CSRF token,并将其添加到表单中。 以下是一个使用Flask-WTF进行CSRF保护的示例: ```python from flask import Flask, render_template, request from flask_wtf.csrf import CSRFProtect from flask_wtf import FlaskForm from wtforms import StringField, SubmitField app = Flask(__name__) app.config['SECRET_KEY'] = 'secret_key' csrf = CSRFProtect(app) class MyForm(FlaskForm): name = StringField('Name') submit = SubmitField('Submit') @app.route('/', methods=['GET', 'POST']) def index(): form = MyForm() if form.validate_on_submit(): name = form.name.data return 'Hello, {}'.format(name) return render_template('index.html', form=form) ``` 在上面的示例中,我们首先导入了CSRFProtect和FlaskForm类。然后,我们创建了一个名为MyForm的表单类,该类包含一个名为name的文本字段和一个名为submit的提交按钮。接下来,我们创建了一个名为index的视图函数,该函数渲染了一个名为index.html的模板,并将表单对象传递给模板。如果表单提交成功,则从表单中获取name字段的值,并返回一个包含该值的字符串。 在模板中,我们需要添加一个隐藏字段,以包含CSRF token。可以使用Flask-WTF提供的{{ form.csrf_token }}模板标签来生成该字段。以下是一个简单的index.html模板示例: ```html <!DOCTYPE html> <html> <head> <title>Flask-WTF CSRF Example</title> </head> <body> <h1>Flask-WTF CSRF Example</h1> <form method="post"> {{ form.hidden_tag() }} {{ form.name.label }} {{ form.name() }} {{ form.submit() }} </form> </body> </html> ``` 在上面的示例中,我们使用了Flask-WTF提供的hidden_tag()方法来生成一个包含CSRF token的隐藏字段。在表单中添加该字段后,Flask-WTF会自动验证表单提交的来源是否合法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

郑*杰

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值