当前位置: 首页 > news >正文

简单的 ​Flask​ 后端应用

from flask import Flask, request, jsonify, session
import os
app = Flask(__name__)
app.secret_key = os.urandom(24) 
users = {
'123': 'admin',
'admin': 'admin'
}
# 登录接口
@app.route('/login', methods=['POST'])
def login():
data = request.get_json()
username = data.get('username')
password = data.get('password')
if username in users and users[username] == password:
session['logged_in'] = True
return 'Login successful', 200
else:
return 'Login failed', 401

这段代码是一个简单的 ​Flask​ 后端应用,实现了一个用户登录功能,并使用 ​Session​ 来管理用户登录状态。以下是代码的详细解释:


1. 导入必要的模块

from flask import Flask, request, jsonify, session
import os
  • ​**Flask**​:Flask 框架的核心类,用于创建 Web 应用。
  • ​**request**​:用于处理 HTTP 请求(如获取 POST 数据)。
  • ​**jsonify**​:用于返回 JSON 格式的响应(虽然代码中没有直接使用)。
  • ​**session**​:用于管理用户会话(Session),存储登录状态等信息。
  • ​**os**​:用于生成安全的随机密钥。

2. 创建 Flask 应用

app = Flask(__name__)
app.secret_key = os.urandom(24)  # 设置一个密钥,用于加密 session 数据
  • ​**app = Flask(__name__)**​:创建一个 Flask 应用实例。
  • ​**app.secret_key = os.urandom(24)**​:
    • ​**secret_key**​ 是 Flask 用来加密 Session 数据的密钥。
    • ​**os.urandom(24)**​ 生成一个 24 字节的随机密钥,确保 Session 数据的安全性。

3. 模拟用户数据

users = {'123': 'admin','admin': 'admin'
}
  • 这是一个简单的字典,存储用户名和密码(实际项目中应该使用数据库)。
  • 示例用户:
    • 用户名 123,密码 admin
    • 用户名 admin,密码 admin

​4. 登录接口 /login

@app.route('/login', methods=['POST'])
def login():data = request.get_json()  # 获取 POST 请求的 JSON 数据username = data.get('username')  # 获取用户名password = data.get('password')  # 获取密码if username in users and users[username] == password:session['logged_in'] = True  # 登录成功,设置 Sessionreturn 'Login successful', 200  # 返回成功消息else:return 'Login failed', 401  # 返回失败消息

功能解析

  1. ​**@app.route('/login', methods=['POST'])**​:
    • 定义了一个 ​POST​ 请求的路由 /login,用于处理登录请求。
  2. ​**data = request.get_json()**​:
    • 获取客户端发送的 ​JSON 数据​(如 {"username": "hami", "password": "admin"})。
  3. ​**username = data.get('username')​ 和 ​password = data.get('password')**​:
    • 从 JSON 数据中提取 username 和 password
  4. 验证用户
    • 检查 username 是否在 users 字典中,并且密码是否匹配。
    • 如果匹配:
      • ​**session['logged_in'] = True**​:设置 Session,标记用户已登录。
      • ​**return 'Login successful', 200**​:返回成功消息(HTTP 200)。
    • 如果不匹配:
      • ​**return 'Login failed', 401**​:返回失败消息(HTTP 401 未授权)。

5. Session 的作用

  • ​**session['logged_in'] = True**​:
    • 在用户登录成功后,Flask 会存储一个加密的 Session Cookie 在客户端(浏览器)。
    • 后续请求会自动携带这个 Cookie,服务器可以检查 session['logged_in'] 来判断用户是否登录。
  • ​**secret_key**​ 的作用:
    • 确保 Session 数据不会被篡改(因为数据是加密的)。

6. 如何测试这个 API?​

可以使用 ​Postman​ 或 ​curl​ 发送 POST 请求:

curl -X POST http://127.0.0.1:5000/login \-H "Content-Type: application/json" \-d '{"username": "hami", "password": "admin"}'

成功响应:​

Login successful

失败响应:​

Login failed

7. 可能的改进

  1. 使用数据库存储用户​(如 SQLite、MySQL)。
  2. 密码加密存储​(如 bcrypt 或 hashlib)。
  3. 添加注销功能​(session.pop('logged_in', None))。
  4. 返回 JSON 格式的响应​(如 jsonify({"message": "Login successful"}))。

总结

  • 这是一个简单的 ​Flask 登录 API,使用 ​Session​ 管理登录状态。
  • 适用于小型应用或学习 Flask 的 Session 机制。
  • 实际项目中需要更安全的用户管理和数据库支持。

 

相关文章:

  • 汽车加气站操作工考试题库含答案【最新】
  • 《棒球青训》打造几个国家级运动基地·棒球1号位
  • 阿里云OSS对象云储存入门操作
  • 【系统规划与管理师第二版】1.3 新一代信息技术及发展
  • [Java] 继承和多态
  • 【Python小练习】3D散点图
  • LeetCode 680.验证回文串 II
  • WinUI3开发_设置标题栏高度
  • .NET 4.7中使用NLog记录日志到数据库表
  • 通过Radius认证服务器实现飞塔/华为防火墙二次认证:原理、实践与安全价值解析
  • 非线性方程组求解:复杂情况下的数值方法
  • JavaScript Symbol 属性详解
  • GA3C(GPU/CPU混合式异步优势Actor-Critic)算法实现控制倒立摆
  • Cppcheck 使用教程:本地 + CMake + GitHub Actions 自动分析实战
  • 创业知识概论
  • 【ing】Ubuntu安装Anaconda及环境配置\docker\pycharm
  • Qwen3 Embedding 结构-加载-训练 看透模型设计哲学
  • Linux——库文件生成和使用
  • ADC的传递函数
  • Spring 源码学习 2:Bean 后处理器
  • 有免费网站推荐吗/营销宣传方式有哪些
  • 商城网站的搜索记录代码怎么做/公关
  • 域名买卖网站/广州顶正餐饮培训学校
  • 做网站首页有什么/外贸seo推广招聘
  • 电子商务网站建设携程/上海职业技能培训机构一览表
  • 郑州网站制作-中国互联/怎么注册域名网址