快速定位登录问题,让用户愉快登录——Python实现登录rightfind

一、选用合适的登录方式

如何选择用户登录时的验证方式?在选择验证方式时,需要综合考虑安全性、易用性和可扩展性等因素。目前常用的验证方式有密码验证、验证码验证、手机号验证及社交账号验证等多种方式,根据不同场景的需求来选择合适的验证方式。

以密码验证为例,在写登录代码之前,需先做好安全性考虑。密码需要进行加密处理,可以使用Python内置库hashlib中的sha256方法进行加密。在登录时,将用户输入的密码同数据库中的加密后密码进行比对,来完成登录验证。

import hashlib

def encrypt_password(password):
    return hashlib.sha256(password.encode('utf-8')).hexdigest()

加密密码函数已完成,接下来我们需要将函数应用到具体的登录代码中:

from flask import (Blueprint, jsonify,
                   request, current_app)
from app.models import User
from app.extensions import db
from app.utils.auth import generate_token, login_required

bp_auth = Blueprint('auth', __name__, url_prefix='/auth')


@bp_auth.route('/login', methods=['POST'])
def login():
    try:
        email = request.json.get('email').strip().lower()
        password = request.json.get('password').strip()
        user = User.query.filter_by(email=email).first()

        if user and encrypt_password(password) == user.password_hash:
            token = generate_token(user.id)
            return jsonify({'token': token, 'user': user.to_dict()}), 200
        else:
            return jsonify({'msg': '用户名或密码错误'}), 401
    except Exception as e:
        current_app.logger.error(e)
        return jsonify({'msg': '未知错误,请联系开发人员'}), 500

二、增加友好的错误提示

当用户在登录时出现一些问题时,及时给出针对性的错误提示,可以大大提高用户体验。比如提示用户账号或密码错误,或者是用户名不存在等等。

在具体代码实现上,在完成用户输入验证之后,可以使用Flask框架中的flask_flash函数进行错误提示。同时也可以在html模板中使用Jinja2模板引擎来渲染并显示错误信息。

from flask import (Blueprint, jsonify, flash,
                   request, current_app, redirect, url_for)
from app.models import User
from app.extensions import db
from app.utils.auth import generate_token, login_required

bp_auth = Blueprint('auth', __name__, url_prefix='/auth')


@bp_auth.route('/login', methods=['POST'])
def login():
    try:
        email = request.json.get('email').strip().lower()
        password = request.json.get('password').strip()
        user = User.query.filter_by(email=email).first()

        if user and encrypt_password(password) == user.password_hash:
            token = generate_token(user.id)
            flash('欢迎回来!')
            return jsonify({'token': token, 'user': user.to_dict()}), 200
        else:
            flash('用户名或密码错误')
            return redirect(url_for('auth.login')), 401
    except Exception as e:
        current_app.logger.error(e)
        return jsonify({'msg': '未知错误,请联系开发人员'}), 500

上面代码中,如果登录成功,就会把”欢迎回来!”提示信息传递到前端;如果登录失败,就会把”用户名或密码错误”提示信息传递到前端,并且跳转到登录页面。

三、添加登录日志

针对一些特殊需求,可能需要记录用户的登录历史,这样可以及时发现登录异常情况,进行针对性的处理。

实现这一功能的代码如下:

from datetime import datetime
from flask import (Blueprint, jsonify, flash,
                   request, current_app, redirect, url_for)
from app.models import User, LoginLog
from app.extensions import db
from app.utils.auth import generate_token, login_required

bp_auth = Blueprint('auth', __name__, url_prefix='/auth')


@bp_auth.route('/login', methods=['POST'])
def login():
    try:
        email = request.json.get('email').strip().lower()
        password = request.json.get('password').strip()
        user = User.query.filter_by(email=email).first()

        if user and encrypt_password(password) == user.password_hash:
            token = generate_token(user.id)
            log = LoginLog(
                user_id=user.id,
                ip=request.remote_addr,
                user_agent=request.user_agent.string,
                login_time=datetime.now(),
                status=True
            )
            db.session.add(log)
            db.session.commit()
            flash('欢迎回来!')
            return jsonify({'token': token, 'user': user.to_dict()}), 200
        else:
            log = LoginLog(
                user_id=user.id if user else None,
                ip=request.remote_addr,
                user_agent=request.user_agent.string,
                login_time=datetime.now(),
                status=False
            )
            db.session.add(log)
            db.session.commit()
            flash('用户名或密码错误')
            return redirect(url_for('auth.login')), 401
    except Exception as e:
        current_app.logger.error(e)
        return jsonify({'msg': '未知错误,请联系开发人员'}), 500

上述代码中,我们在登录成功和登录失败的情况下,都在数据库中添加一条登录记录。这里的LoginLog是一个ORM类,用来映射到数据库中的login_log表。

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/239540.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝的头像小蓝
上一篇 2024-12-12 12:17
下一篇 2024-12-12 12:17

相关推荐

  • Python官网中文版:解决你的编程问题

    Python是一种高级编程语言,它可以用于Web开发、科学计算、人工智能等领域。Python官网中文版提供了全面的资源和教程,可以帮助你入门学习和进一步提高编程技能。 一、Pyth…

    编程 2025-04-29
  • 如何解决WPS保存提示会导致宏不可用的问题

    如果您使用过WPS,可能会碰到在保存的时候提示“文件中含有宏,保存将导致宏不可用”的问题。这个问题是因为WPS在默认情况下不允许保存带有宏的文件,为了解决这个问题,本篇文章将从多个…

    编程 2025-04-29
  • Ojlat:一款快速开发Web应用程序的框架

    Ojlat是一款用于快速开发Web应用程序的框架。它的主要特点是高效、易用、可扩展且功能齐全。通过Ojlat,开发人员可以轻松地构建出高质量的Web应用程序。本文将从多个方面对Oj…

    编程 2025-04-29
  • Java Thread.start() 执行几次的相关问题

    Java多线程编程作为Java开发中的重要内容,自然会有很多相关问题。在本篇文章中,我们将以Java Thread.start() 执行几次为中心,为您介绍这方面的问题及其解决方案…

    编程 2025-04-29
  • Python爬虫乱码问题

    在网络爬虫中,经常会遇到中文乱码问题。虽然Python自带了编码转换功能,但有时候会出现一些比较奇怪的情况。本文章将从多个方面对Python爬虫乱码问题进行详细的阐述,并给出对应的…

    编程 2025-04-29
  • NodeJS 建立TCP连接出现粘包问题

    在TCP/IP协议中,由于TCP是面向字节流的协议,发送方把需要传输的数据流按照MSS(Maximum Segment Size,最大报文段长度)来分割成若干个TCP分节,在接收端…

    编程 2025-04-29
  • 如何解决vuejs应用在nginx非根目录下部署时访问404的问题

    当我们使用Vue.js开发应用时,我们会发现将应用部署在nginx的非根目录下时,访问该应用时会出现404错误。这是因为Vue在刷新页面或者直接访问非根目录的路由时,会认为服务器上…

    编程 2025-04-29
  • Python中接收用户的输入

    Python中接收用户的输入是一个常见的任务,可以通过多种方式来实现。本文将从以下几个方面对Python中接收用户的输入做详细阐述。 一、使用input函数接收用户输入 Pytho…

    编程 2025-04-29
  • 如何解决egalaxtouch设备未找到的问题

    egalaxtouch设备未找到问题通常出现在Windows或Linux操作系统上。如果你遇到了这个问题,不要慌张,下面我们从多个方面进行详细阐述解决方案。 一、检查硬件连接 首先…

    编程 2025-04-29
  • Python折扣问题解决方案

    Python的折扣问题是在计算购物车价值时常见的问题。在计算时,需要将原价和折扣价相加以得出最终的价值。本文将从多个方面介绍Python的折扣问题,并提供相应的解决方案。 一、Py…

    编程 2025-04-28

发表回复

登录后才能评论