Flask写接口一(路由,json , session模拟登录)

from flask import Flask, request, jsonify, session
from werkzeug.utils import redirect

app = Flask(__name__)
# 使用session必须给应用加密 app.secret_key
= "asdasdasdasdasdsaa" @app.route("/", methods=["GET"]) def hello_world(): return "hello boy" @app.route("/hey/<username>") def hey_yingong(username): return "我是 %s" % (username + username) @app.route("/my/<float:number>") def my_number(number): return "我的数字 %s" % (number + number) @app.route("/bilibili") def bilibili(): return redirect("https://www.bilibili.com/") @app.route("/test/my/first", methods=["POST"]) def first_post(): try: my_json = request.get_json() print(my_json) get_name = my_json.get("name") get_age = my_json.get("age") if not all([get_name, get_age]): return jsonify(msg="缺少参数") get_age += 10 return jsonify(name=get_name, age=get_age) except Exception as e: print(e) return jsonify(msg="出错了哦,请查看是否正确访问") # 登录 @app.route("/try/login", methods=["POST"]) def login(): """ 账号 username asd123 密码 password asdasd :return: """ get_data = request.get_json() username = get_data.get("username") password = get_data.get("password") if not all([username, password]): return jsonify(msg="参数不完整") if username == "asd123" and password == "asdasd": # 如果验证通过 保存登录状态在session中 session["username"] = username return jsonify(msg="登录成功") else: return jsonify(msg="账号或密码错误") # 检查登录状态 @app.route("/session", methods=["GET"]) def check_session(): username = session.get("username") if username is not None: # 操作逻辑 数据库什么的 # 数据库里面 把你的头像 等级 金币数量 查询出来 return jsonify(username=username) else: return jsonify(msg="出错了,没登录") # 登出 @app.route("/try/logout", methods=["GET"]) def logout(): session.clear() return jsonify(msg="成功退出登录!") app.run(host="0.0.0.0")

 

posted @ 2020-12-18 22:02  纸短情长lol  阅读(312)  评论(0编辑  收藏  举报