码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • flask中的跨域处理-方法二不使用第三方库


    方法1(第三方库)

    pip install flask-cors

    from flask import Flask
    from flask_cors import CORS
    
    app = Flask(__name__)
    CORS(app, resources={r"/api/*": {"origins": ["http://localhost:63342", "http://localhost:63345"]}})
    
    • 1
    • 2
    • 3
    • 4
    • 5

    方法2(声明周期函数)

    from flask import Flask, jsonify, request, make_response
    
    # 创建Flask应用程序实例
    app = Flask(__name__)
    origins = ["http://localhost:63342", "http://localhost:63345"]
    
    
    # 定义路由和视图函数
    @app.route('/api/object', methods=["get", "post"])
    def hello_world():
        loginWay = request.args.get("loginWay")
    
        username = ""
        if loginWay == "sms":
            mobile = request.json.get("mobile")
            code = request.json.get("code")
            if mobile != "153" or code != "123":
                return jsonify(code=-1, msg="短信验证码错误或已过期")
        elif loginWay == "password":
            username = request.json.get("username")
            password = request.json.get("password")
            if username != "myn" or password != "149":
                return jsonify(code=-1, msg="用户名或密码错误")
        data = {"account": username if username else mobile, "loginWay": loginWay, "msg": "登录成功"}
        return jsonify(code=0, msg="登录成功", data=data)
    
    
    @app.after_request
    def app_after_request(response):
        current_origin = request.headers.get("Origin")
        response.headers['Access-Control-Allow-Origin'] = current_origin
        return response
    
    
    @app.before_request
    def app_before_request():
        if request.method == "OPTIONS" and request.headers.get("Origin") in origins:
            resp = make_response()
            resp.headers.add('Access-Control-Allow-Credentials', 'true')
            resp.headers.add('Access-Control-Allow-Methods', 'GET,POST,OPTIONS')
            resp.headers.add('Access-Control-Allow-Headers',
                             "Content-Type,X-Requested-With,X-Csrf-Token,DNT,X-CustomHeader,"
                             "Keep-Alive,User-Agent,If-Modified-Since,Cache-Control,Authorization")
            return resp
    
    # 启动应用程序
    if __name__ == '__main__':
        app.run(debug=True)
    
    
    • 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
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
  • 相关阅读:
    【小程序项目开发-- 京东商城】uni-app之分类导航区域
    【Git技巧】第八篇 git历史提交版本回退(可切换任意已经提交的版本)
    优思学院|六西格玛管理常用的假设检验是什么?
    大数据要怎么样学才可以到企业级实战
    map和unordered_map区别
    通过WinSCP实现Windows给Ubuntu(Linux)虚拟机传输数据
    Java实现图书管理系统
    手把手教你使用Vue3指定状态管理库--Pinia
    Error occurred while trying to proxy request项目突然起不来了
    10款最赞的ROS机器人操作系统课程+为何ROS不是必须的
  • 原文地址:https://blog.csdn.net/weixin_42289273/article/details/132942217
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号