flask 完成简单查询请求处理,及跨域
时间:2022-06-21
本文章向大家介绍flask 完成简单查询请求处理,及跨域,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
flask通用项目结构
| - projectName
| - app //程序包
| - templates //jinjia2模板
|- static //css,js 图片等静态文件
| - main //py程序包 ,可以有多个这种包,每个对应不同的功能
| - __init__.py
|- errors.py
|- forms.py
|- views.py
|- __init__.py
|- email.py //邮件处理程序
|- models.py //数据库模型
|- migrations //数据迁移文件夹
| - tests //单元测试
|- __init__.py
|- test*.py //单元测试程序,可以包含多个对应不同的功能点测试
|- venv //虚拟环境
|- requirements.txt //列出了所有依赖包以及版本号,方便在其他位置生成相同的虚拟环境以及依赖
|- config.py //全局配置文件,配置全局变量
|- manage.py //启动程序
flask 简介
http://docs.jinkan.org/docs/flask/quickstart.html#a-minimal-application
主体代码逻辑
一个最简单的查询服务样例
#!/usr/bin/env python
# -*- encoding: utf-8 -*-
#-------------------------------------------------------------------------------
'''
@Author : {SEASON}
@License : (C) Copyright 2013-2022, {OLD_IT_WANG}
@Contact : {shiter@live.cn}
@Software: PyCharm
@File :
@Time : 2019/4/25 14:57
@Desc :
'''
#-------------------------------------------------------------------------------
import json
import random
import logging
from flask import Flask
from flask_sqlalchemy import SQLAlchemy
from flask import request,Response
from flask_cors import CORS
log_file_str = 'shuanghe_demo.log'
log_level = logging.INFO
app = Flask(__name__)
CORS(app)
app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql+pymysql://username:password@ip:3306/database'
app.config['SQLALCHEMY_COMMIT_ON_TEARDOWN'] = True
db = SQLAlchemy(app)
english_chinese_dict = {'id':'身份证号',
'name':'姓名',
'sex':'性别',
'age':'年龄',
}
class neihuang_underwriting_search_result(db.Model):
__tablename__ = 'neihuang_underwriting_search_result'
id = db.Column(db.String(32),primary_key=True)
name = db.Column(db.String(32))
sex = db.Column(db.String(32))
age = db.Column(db.String(32))
def __repr__(self):
return '<neihuang_underwriting_search_result %r>' % self.id
def convert_to_dict(obj):
'''把Object对象转换成Dict对象'''
result_dict = {}
result_dict.update(obj.__dict__)
result_dict.pop('_sa_instance_state', None)
result_dict = random_value_of_labels(result_dict)
return result_dict
def get_id_result(id):
result = neihuang_underwriting_search_result.query.filter_by(id=id).one()
result_dict = convert_to_dict(result)
# result_list = database_name_conversion(result_dict)
result_json = json.dumps(result_dict,ensure_ascii=False)
return result_json
@app.route('/api/search',methods=['POST','GET'])
def search():
#result_json = get_id_result(id)
if request.method == 'GET':
user_id = json.loads(''.join(x for x in request.args))['id']
print(user_id)
app.logger.info(user_id + ' is search ING .......')
result_json = get_id_result(user_id)
return Response(result_json)
if __name__ == '__main__':
handler = logging.FileHandler(log_file_str, encoding='UTF-8')
handler.setLevel(log_level)
logging_format = logging.Formatter(
'%(asctime)s - %(levelname)s - %(filename)s - %(funcName)s - %(lineno)s - %(message)s')
handler.setFormatter(logging_format)
app.logger.addHandler(handler)
app.run(debug=True, host='0.0.0.0', port=18081)
#放在这里是不对的
# CORS(app, supports_credentials=True)
flask 跨域问题的处理
在处理跨域问题时候,应该把下列代码弄成全局的,也就是放 app = Flask(name) cors = CORS(app)
否则跨域问题依然存在,报错信息为:
Access to XMLHttpRequest at ‘-----’ from origin ‘http://localhost:63342’ has been blocked by CORS policy: Response to preflight request doesn’t pass access control check: No ‘Access-Control-Allow-Origin’ header is present on the requested resource.
flask 日志
https://blog.csdn.net/iszhenyu/article/details/56846551
flask 微服务Flask-RESTful
写完了发现 https://flask-restful.readthedocs.io/en/latest/
启动服务命令
参考:https://www.cnblogs.com/zzyoucan/p/7764590.html nohup command > myout.file 2>&1 &
- 中国大数据行业发展现状及趋势预测
- 【腾讯云的1001种玩法】十分钟轻松搞定云架构 · 负载均衡的几种类型
- 常用的Hadoop 文件查看工具
- 机器学习之——LINE及LargeVis可视化算法
- 开发人员看测试之细说JBehave
- 智能合约中存在的3种最常见的误解
- O'ReillyAI系列:将学习速率可视化来优化神经网络
- 再下一城,腾讯黑科技介入新零售
- 微信团队广发内部体验邀请,小程序将大火!
- 胖虎科技获1亿元融资 域名“我爱胖虎”创意十足!
- 高挺:区块链在金融领域的三个应用方向
- 条码支付迎来分级限额制 支付宝、微信纷纷响应
- 关键基础设施威胁预警,HDD声波攻击可致蓝屏
- 集成学习之随机森林通俗理解
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- R语言风险价值VaR(Value at Risk)和损失期望值ES(Expected shortfall)的估计
- R语言机器学习实战之多项式回归
- 5000字!带你零距离接触websocket!
- 使用 GitLab CI 和 Docker 自动部署 Spring Boot 应用
- 玩转StyleGAN2模型:教你生成动漫人物
- R语言时间序列数据指数平滑法分析交互式动态可视化
- 再见Excel!最强国产开源在线表格Luckysheet走红GitHub
- R语言广义线性模型索赔频率预测:过度分散、风险暴露数和树状图可视化
- R语言多分类logistic逻辑回归模型在混合分布模拟单个风险损失值评估的应用
- sas神经网络:构建人工神经网络模型来识别垃圾邮件
- 图像倾斜校正算法的MATLAB实现:图像倾斜角检测及校正
- 手写dubbo框架9-SPI实现
- R语言非参数模型厘定保险费率:局部回归、广义相加模型GAM、样条回归
- VsCode插件之Live Serve探秘.(上)
- R语言小数定律的保险业应用:泊松分布模拟索赔次数