flask入门 快速入门后台写接口【API】【Python3】【无前端】【json格式】

flash官网手册地址:
https://dormousehole.readthedocs.io/en/latest/#api
https://github.com/BeyondLam/bili
新建项目
虚拟环境
- pycharm创建
- Linux下创建(服务器)
- python3 -m venv venv(创建虚拟环境)
- source venv/bin/activate(激活环境)
 


安装flask插件包
1)方式一:pycharm安装

2)方式二:命令行安装
$ pip install flask
新建hello_world.py
from flask import Flask
app = Flask(__name__)
@app.route('/')
def hello_world():
    return "Hello World!"
if __name__ == '__main__':
    app.run()
运行

访问: http://127.0.0.1:5000/
返回 Hello World!
debug调适
打断点--》debug运行 --》访问打断点的路由器http://127.0.0.1:5000/--》进入断点的位置--》单步调适

四、flask应用
from flask import Flask
app = Flask(__name__)
# http://127.0.0.1:5000/index
@app.route('/index')
def hello_index():
    return "Hello Index!"
# http://127.0.0.1:5000/
@app.route('/')
def hello_world():
    return "Hello World!"
if __name__ == '__main__':
    # 在服务器上,不加host=’0.0.0.0‘只能本服务器内网访问
    app.run(host='0.0.0.0')
flask路由
# http://127.0.0.1:5000/index
@app.route('/index')
def hello_index():
    return "Hello Index!"
# http://127.0.0.1:5000/
@app.route('/')
def hello_world():
    return "Hello World!"
变量规则
通过把 URL 的一部分标记为 <variable_name> 就可以在 URL 中添加变量。标记的 部分会作为关键字参数传递给函数。通过使用 converter:variable_name ,可以 选择性的加上一个转换器,为变量指定规则。请看下面的例子:
from markupsafe import escape
@app.route('/user/<username>')
def show_user_profile(username):
    # show the user profile for that user
    return f'User {escape(username)}'
@app.route('/post/<int:post_id>')
def show_post(post_id):
    # show the post with the given id, the id is an integer
    return f'Post {post_id}'
@app.route('/path/<path:subpath>')
def show_subpath(subpath):
    # show the subpath after /path/
    return f'Subpath {escape(subpath)}'
转换器类型:
| 类型 | 说明 | 
|---|---|
| string | (缺省值) 接受任何不包含斜杠的文本 | 
| int | 接受正整数 | 
| float | 接受正浮点数 | 
| path | 类似 string ,但可以包含斜杠 | 
| uuid | 接受 UUID 字符串 | 
唯一的 URL / 重定向行为
以下两条规则的不同之处在于是否使用尾部的斜杠。:
@app.route('/projects/')
def projects():
    return 'The project page'
@app.route('/about')
def about():
    return 'The about page'
projects 的 URL 是中规中矩的,尾部有一个斜杠,看起来就如同一个文件 夹。访问一个没有斜杠结尾的 URL ( /projects )时 Flask 会自动进行重 定向,帮您在尾部加上一个斜杠( /projects/ )。
about 的 URL 没有尾部斜杠,因此其行为表现与一个文件类似。如果访问这 个 URL 时添加了尾部斜杠(/about/ )就会得到一个 404 “未找到” 错 误。这样可以保持 URL 唯一,并有助于搜索引擎重复索引同一页面。
flask重定向
# http://192.168.0.106:5000/baidu
# 重定向 需要引入 from flask import redirect
@app.route('/baidu') ## 加int后,参数只能传int
def baidu():
    return redirect("https://baidu.com")
JSON 格式的 API demo1
@app.route("/me")
def me_api():
    userInfo = {
        "username": "lisi",
        "theme": "user.theme",
        "age": "30",
    }
    return userInfo
访问:
返回:
{
  "age": "30",
  "theme": "user.theme",
  "username": "lisi"
}
JSON 格式的 API demo2
# http://192.168.0.106:5000/post_first
# post请求
"""
请求参考 post raw
{
    "age": 30,
    "theme": "user.theme",
    "username": "lisi"
}
返回数据
# return rs
{
    "age": 40,
    "code": 200,
    "data": null
}
 =========================================================
# return jsonify(age=age, code=rs["code"], qData=qData)
{
    "age": 30,
    "code": 200,
    "qData": {
        "age": 30,
        "theme": "user.theme",
        "username": "lisi"
    }
}
"""
from flask import Flask, request, jsonify
@app.route('/post_first', methods=["POST"])
def post_first():
    try:
        qData = request.get_json()
        print(qData)  # {'age': '30', 'theme': 'user.theme', 'username': 'lisi'}
        username = qData.get("username1")
        age = qData.get("age")
        if not all([username,age]):
            return jsonify(msg="username or age is not empty")
        print(username)  # 没有key的参数  打印None  返回给前端null
        rs = {
            "code": 200,
            "data": username,
            "age": age + 10,
        }
        # 以下返回json格式的数据
        # return rs
        # return jsonify(age=age, code=rs["code"], qData=qData)
        return jsonify({"age": age, "code": rs["code"], "qData": qData})
    except Exception as e:
        errMsg = f"出错了, e:{e}"
        print(errMsg)
        return jsonify(msg=errMsg)
Cookies
要访问 cookies ,可以使用 cookies 属性。可以使用响应 对象 的 set_cookie 方法来设置 cookies 。请求对象的 cookies 属性是一个包含了客户端传输的所有 cookies 的字典。在 Flask 中,如果使用 会话 ,那么就不要直接使用 cookies ,因为 会话 比较安全一些。
读取 cookies:
from flask import request
@app.route('/')
def index():
    username = request.cookies.get('username')
    # use cookies.get(key) instead of cookies[key] to not get a
    # KeyError if the cookie is missing.
储存 cookies:
from flask import make_response
@app.route('/')
def index():
    resp = make_response(render_template(...))
    resp.set_cookie('username', 'the username')
    return resp
注意 cookies 设置在响应对象上。通常只是从视图函数返回字符串, Flask 会把它们转换为响应对象。如果您想显式地转换,那么可以使用 make_response() 函数,然后再修改它。
会话
除了请求对象之外还有一种称为 session 的对象,允许您在不同请求 之间储存信息。这个对象相当于用密钥签名加密的 cookie ,即用户可以查看您的 cookie ,但是如果没有密钥就无法修改它。
使用会话之前您必须设置一个密钥。举例说明:
Set the secret key to some random bytes. Keep this really secret!
app.secret_key = b'_5#y2L"F4Q8z\n\xec]/'
code demo
from flask import Flask, request, jsonify
from flask import redirect
from flask import session
# from werkzeug.middleware.proxy_fix import ProxyFix
# from flask_esearch import ESearch  # https://pypi.org/project/Flask-ESearch/
app = Flask(__name__)
app.secret_key = "12313123"
# http://127.0.0.1:5000/try/login
@app.route("/try/login", methods=["POST"])
def login():
    '''
    username admin
    password 123455
    '''
    get_data = request.get_json()
    user_name = get_data.get("username")
    password = get_data.get("password")
    if not all([user_name,password]):
        return jsonify(errCode=400, msg="username or password not emtpy")
    if user_name == "admin" and password == "123456":
        session['user_name'] = "admin"
        session['admin_id'] = "111"
        session['avatar'] = "user_avatar.jpg"
        return jsonify(errCode=200, msg="login success")
    else:
        return jsonify(errCode=400, msg="username or password error")
# http://127.0.0.1:5000/try/logout
@app.route("/try/logout", methods=["GET"])
def logout():
    # session.pop('user_name',None)
    session.clear()
    return jsonify(errCode=200, msg="logout success")
# http://127.0.0.1:5000/session
@app.route("/session", methods=["GET"])
def check_session():
    # 查检登陆状态
    s_data = {
        "user_name": session.get("user_name"),
        "admin_id": session.get("admin_id"),
        "avatar": session.get("avatar"),
    }
    # 从session中获取用户数据
    if s_data["user_name"] is not None:
        return jsonify(errCode=200, msg="true", data=s_data)
    else:
        return jsonify(errCode=400, msg="not login", data=s_data)
# http://127.0.0.1:5000/post_first
# post请求
"""
请求参考 post raw
{
    "age": 30,
    "theme": "user.theme",
    "username": "lisi"
}
返回数据
# return rs
{
    "age": 40,
    "code": 200,
    "data": null
}
 =========================================================
# return jsonify(age=age, code=rs["code"], qData=qData)
{
    "age": 30,
    "code": 200,
    "qData": {
        "age": 30,
        "theme": "user.theme",
        "username": "lisi"
    }
}
"""
@app.route('/post_first', methods=["POST"])
def post_first():
    try:
        qData = request.get_json()
        print(qData)  # {'age': '30', 'theme': 'user.theme', 'username': 'lisi'}
        username = qData.get("username1")
        age = qData.get("age")
        if not all([username, age]):
            return jsonify(msg="username or age is not empty")
        print(username)  # 没有key的参数  打印None  返回给前端null
        rs = {
            "code": 200,
            "data": username,
            "age": age + 10,
        }
        # 以下返回json格式的数据
        # return rs
        # return jsonify(age=age, code=rs["code"], qData=qData)
        return jsonify({"age": age, "code": rs["code"], "qData": qData})
    except Exception as e:
        errMsg = f"出错了, e:{e}"
        print(errMsg)
        return jsonify(msg=errMsg)
# http://192.168.0.106:5000/me
@app.route("/me")
def me_api():
    # app.wsgi_app = ProxyFix(app.wsgi_app)
    userInfo = {
        "username": "lisi",
        "theme": "user.theme",
        "age": "30",
    }
    app.logger.debug('A value for debugging')
    app.logger.warning('A warning occurred (%d apples)', 42)
    app.logger.error('An error occurred')
    return userInfo
# http://192.168.0.106:5000/baidu
# 重定向 需要引入 from flask import redirect
@app.route('/baidu')  ## 加int后,参数只能传int
def baidu():
    return redirect("https://baidu.com")
# http://192.168.0.106:5000/number_int/2
# 传递参数 规定参数类型 int / float / path / uuid
@app.route('/number_int/<int:number>')  ## 加int后,参数只能传int
def hello_number_int(number):
    return "number: %s!" % (number + number)  # number: 4!
# http://192.168.0.106:5000/number_float/2.1
# 传递参数 规定参数类型 int / float / path / uuid
@app.route('/number_float/<float:number>')  # 加float后,参数只能传float
def hello_number_float(number):
    return "number: %s!" % (number + number)  # number: 4.2!
# http://127.0.0.1:5000/hello/haima
# 传递参数
@app.route('/hello/<username>')
def hello_hello(username):
    return "Hello %s!" % username
# http://127.0.0.1:5000/index
@app.route('/index')
def hello_index():
    return "Hello Index!"
# http://127.0.0.1:5000/
@app.route('/')
def hello_world():
    return "Hello World!"
if __name__ == '__main__':
    # 在服务器上,不加host=’0.0.0.0‘只能本服务器内网访问  port=5001 指定端口
    app.run(host='0.0.0.0', port=5000)
flask扩展仓库
https://pypi.org/search/?c=Framework+%3A%3A+Flask&o=&q=+Flask-mysql&page=4
flask入门 快速入门后台写接口【API】【Python3】【无前端】【json格式】的更多相关文章
- flask 框架快速入门
		flask 框架快速入门 搭建一个简易flask项目 首先使用 Pycharm创建flask项目 运行flask项目 1.使用Pycharm搭建flask项目 (如果Pycharm新建项目中未出现该图 ... 
- Flask的快速入门详细笔记
		Flask的框架结构对应关系及理解 1.简介 简单介绍下Flask是一个轻量级的web前端框架,不像django那样本身具备一套完整的页面体系,轻量级说明了完全可以自定义,从功能逻辑到业务处理,都可以 ... 
- 使用Asp.net WebAPI 快速构建后台数据接口
		现在的互联网应用,无论是web应用,还是移动APP,基本都需要实现非常多的数据访问接口.其实对一些轻应用来说Asp.net WebAPI是一个很快捷简单并且易于维护的后台数据接口框架.下面我们来快速构 ... 
- angularJS入门小Demo2 【包含不用数据库而用data.json格式响应前台的ajax请求方式测试】
		事件绑定: <html> <head> <title>angularJS入门小demo-5 事件指令</title> <script src=&q ... 
- 8-2 开发接口 (入参是json格式)
		1.开发入参事json格式的接口 import json import tools import flask from .check_session import check_session serv ... 
- charles抓取线上接口数据替换为本地json格式数据
		最近要做下拉刷新,无奈测试服务器的测试数据太少,没有足够的数据做下拉刷新,所以用charles抓取了测试服务器的接口,然后在伪造了很多数据返回到我的电脑上,下面来说说使用方法: 第一步: 安装FQ软件 ... 
- DataTables学习:从最基本的入门静态页面,使用ajax调用Json本地数据源实现前端开发深入学习,根据后台数据接口替换掉本地的json本地数据,以及报错的处理地方,8个例子(显示行附加信息,回调使用api,动态显示和隐藏列...),详细教程
		一.DataTables 个人觉得学习一门新的插件或者技术时候,官方文档是最根本的,入门最快的地方,但是有时候看完官方文档,一步步的动手写例子,总会出现各种莫名其妙的错误,需要我们很好的进行研究出错 ... 
- springboot2.0入门(五)--swagger2接口API构建
		一.特点 代码变,文档变.只需要少量的注解,Swagger 就可以根据代码自动生成 API 文档,很好的保证了文档的时效性. 跨语言性,支持 40 多种语言. Swagger UI 呈现出来的是一份可 ... 
- Flask 安装 快速入门
		$ pip install flask Flask自带的Server在端口5000上监听: ython app.py flask通过request.form['name']来获取表单的内容. 外部可见 ... 
- c# 后台调用接口接收传过来的json
		public string GetRequestTest(string url) { HttpWebRequest httpWebRequest = (HttpWebRequest)WebReques ... 
随机推荐
- KingbaseES V8R6集群运维案例之---sys_monitor.sh start启动动态库错误
			案例说明: 在KingbaseES V8R6集群部署了postgis后,执行sys_monitor.sh start启动集群时,出现动态库错误,如下图所示: 适用版本: KingbaseES V8R6 ... 
- 前端 Typescript 入门
			前端 Typescript 入门 Ant design vue4.x 基于 vue3,示例默认是 TypeScript.比如 table 组件管理. vue3 官网介绍也使用了 TypeScript, ... 
- 10 JavaScrit定时器
			10 JavaScrit定时器 在JS中, 有两种设置定时器的方案: // 语法规则 t = setTimeout(函数, 时间) // 经过xxx时间后, 执行xxx函数 // 5秒后打印我爱你 t ... 
- 【中秋国庆不断更】OpenHarmony定义可动画属性:@AnimatableExtend装饰器
			[中秋国庆不断更]OpenHarmony定义可动画属性:@AnimatableExtend装饰器 @AnimatableExtend装饰器用于自定义可动画的属性方法,在这个属性方法中修改组件不可动画的 ... 
- C# 数据类型与类型转换:包含教程与示例
			C# 数据类型 C# 中的变量必须是指定的数据类型: int myNum = 5; // 整数(整数) double myDoubleNum = 5.99D; // 浮点数 char myLetter ... 
- Grafana 系列-统一展示-4-AWS Cloudwatch 数据源
			系列文章 Grafana 系列文章 AWS Cloudwatch 数据源 对于 AWS Cloudwatch, 主要在于 3 种不同的认证方式: AWS SDK Default IAM Role AK ... 
- HarmonyOS使用多线程并发能力开发
			一.多线程并发概述 1.简介 并发模型是用来实现不同应用场景中并发任务的编程模型,常见的并发模型分为基于内存共享的并发模型和基于消息通信的并发模型. Actor并发模型作为基于消息通信并发模型的典 ... 
- CentOS 6.5快速部署HTTP WEB服务器和FTP服务器
			CentOS 6.5快速部署HTTP WEB服务器和FTP服务器 时间:2014-03-29 来源:服务器之家 投稿:root 点击:210次 [题记]本文使用CentOS 6.5m ... 
- maven 设置阿里镜像[二]
			前言 因为我们在国内,网速很慢,所以最好设置一下阿里镜像. 1.在maven中的conf下的setting 修改为: <mirror> <id>alimaven</id& ... 
- nginx 学习的前提
			前言 在nginx 中,需要学会的是如何安装.基础的命令.看懂配置那么这时候才是一切的刚刚开始. 正文 安装可以去看菜鸟驿站的: https://www.runoob.com/linux/nginx- ... 
