(八)登录认证与学生写作画像

本次将赵昱琨同学之前完成的学生写作画像与智能学习路径规划的后端与目前已有的后端框架进行整合。同时为了实现学生写作画像与智能学习路径规划,需要在之前简易的登录系统上进行重构,所以本次大规模重写了登录模块,同时发现很多过去冗余的代码,也一并进行了删除。

一、学生写作画像

在之前的学生写作画像板块,主要是采用了test_profie文件进行自动化测试。其中为了测试方便并未直接使用DeepSeek API,而是采用通过自己写prompt文件来进行测试填写,本次与当前后端框架合并后,已可以使用DeepSeek API进行测试。

python 复制代码
 logger.info(f"API 响应状态码: {response.status_code}")
        logger.info(f"API 响应内容: {response.text[:500]}...")
        result = response.json()
        
        # 解析API返回的JSON
        content = result['choices'][0]['message']['content']
        cleaned_api_response = remove_think_block(content)
        logger.info(f" 返回结果: {cleaned_api_response}")
        print("类型是:", type(cleaned_api_response))
        print("内容是:", repr(cleaned_api_response))

        return json.loads(cleaned_api_response)
        

可以看到当前要求的是返回json格式,在运行中,曾出现多次json.loads无法正常使用,最后发现虽然已经要求并且规定DeepSeek API返回纯净的json格式,但其仍会返回带有markdown特征的返回格式,这些与think内容一样都可以通过正则匹配来进行清除。清楚后成功调用/update-profile,完成了内容的更新。

本次测试还将作文例子进行了外封包装,将作文例子包装在essay_sample中,便于修改,同时简化主体的代码。

可以看到数据库已经进行了更新,在6个维度进行了点评,并且为6个维度进行了评分,同时还统计了错误类型与次数,这些都可以作为日后在可视化输出时的数据。

二、登录认证

现在采用LoginManager进行管理登录。

python 复制代码
from extensions import LoginManager 

login_manager = LoginManager()
login_manager.init_app(app)  # 绑定到主应用
login_manager.login_view = 'auth.login'  # 设置登录路由

@login_manager.user_loader
def load_user(user_id):
    print(f"尝试加载用户 ID: {user_id}")
    cursor = mysql.connection.cursor(MySQLdb.cursors.DictCursor)
    cursor.execute('SELECT * FROM accounts WHERE id = %s', (user_id,))
    user = cursor.fetchone()
    cursor.close()
    if user:
        from auth_routes import User  # 避免循环导入
        return User(user)
    return None

通过@login_required进行管理,这样便可以获取currentuserid,便于后续调用各种数据,同时还有登陆状态验证。

python 复制代码
from flask import Blueprint, request, jsonify
from flask_login import UserMixin, login_user, logout_user, current_user
import MySQLdb.cursors

auth_bp = Blueprint('auth', __name__)

class User(UserMixin):
    def __init__(self, user_data):
        self.id = user_data['id']
        self.username = user_data['username']

@auth_bp.route('/login', methods=['POST'])
def login():
    data = request.get_json()
    if not data:
        return jsonify({'status': 'error', 'message': '缺少请求数据'}), 400

    username = data.get('username')
    password = data.get('password')

    if not username or not password:
        return jsonify({'status': 'error', 'message': '用户名和密码不能为空'}), 400

    try:
        from app_test_new import user_model  # 避免循环导入
        account = user_model.get_user_by_credentials(username, password)

        if account:
            user = User(account)
            login_user(user)  # 使用Flask-Login的login_user
            print(f"用户 {user.id} 登录成功")
            return jsonify({
                'status': 'success',
                'message': '登录成功',
                'user': {
                    'id': user.id,
                    'username': user.username,
                }
            })
        return jsonify({'status': 'error', 'message': '用户名/密码错误'}), 401

同时auth_routes也进行了更改,确保使用login_user来进行加载用户。

但目前存在无法正确识别登录的问题,虽然已经成功登录,但貌似因为仍鉴别为未登录导致load_user方法无法加载,目前正在定位问题并进行修改。

相关推荐
财迅通Ai14 小时前
6000万吨产能承压 卫星化学迎来战略窗口期
大数据·人工智能·物联网·卫星化学
武子康15 小时前
大数据-263 实时数仓-Canal 增量订阅与消费原理:MySQL Binlog 数据同步实践
大数据·hadoop·后端
LJ979511115 小时前
媒体发布新武器:Infoseek融媒体平台使用指南
大数据·人工智能
科技小花15 小时前
AI重塑数据治理:2026年核心方案评估与场景适配
大数据·人工智能·云原生·ai原生
方向研究15 小时前
存储芯片生产
大数据
代码青铜16 小时前
如何用 Zion 实现 AI 图片分析与电商文案自动生成流程
大数据·人工智能
gaoshengdainzi17 小时前
GB/T23448-2019卫生洁具软管专用检测设备全套解决方案
大数据·卫生洁具软管检测设备·软管试验机
茶靡花开041518 小时前
什么是DMS经销商管理系统?经销商管理系统哪个好?
大数据·人工智能
Gofarlic_OMS18 小时前
HyperWorks用户仿真行为分析与许可证资源分点配置
java·大数据·运维·服务器·人工智能
fire-flyer18 小时前
ClickHouse系列(二):MergeTree 家族详解
大数据·数据库·clickhouse