目录
引言1. 登录时2. 定义全局拦截器引言
在已有的网站中,几乎所有的网站都已经实现了 自动登录
所谓自动登录,其实就是在你登录后,然后关闭浏览器,接着再启动浏览器重新进入刚刚的网站时,无需自己再次登录。更准确的说,在一段时间内,无需自己再次登录
【资料图】
思路:其实所谓的自动登录,到最后的后端逻辑,和你正常的登录逻辑是一样的,也是判断用户名和密码是否正确。只是我们要省略让用户再次输入用户名和密码的步骤,那么肯定就要将用户名和密码存储在一个地方。当检测到用户再次进入时,看看是否满足可以自动登录的条件,满足的话,将保存的用户名和密码取出来,帮用户自动登录。那我们就要去想,将用户名和密码存储到什么地方
在本篇文章中,本人会在 Flask 项目中使用 ** session + cookie** 的方式,实现上述的功能
实现的方式有很多种,下面的只是其中一种,大家可以自己的需求进行改造和拓展
1. 登录时
登录,前端传来用户名和密码,然后去后端进行验证。如果用户名和密码都正确,则正常登录
此时,我们需要把用户名、密码存进 cookie 中,然后在 session 存储一个是否已经登录的标识
重要的话说三次:
存储密码时,记得加密!
存储密码时,记得加密!
存储密码时,记得加密!
参考代码如下
from flask import make_response, session, request @user.route("/login", methods=["POST"]) def login(): username = request.form.get("username").strip() password = request.form.get("password").strip() ...... // 自己的逻辑处理 if 登录成功: session["islogin"] = "true" // 是否已经登录的标识 session["username"] = username // 根据自己的需求,在session里存储一些值 # 将Cookie写入浏览器 response = make_response("login-pass") // 登录成功,返回给前端的值 response.set_cookie("username", username, max_age=30*24*3600) // max_age,cookie的存活时间,这里表示一个月 response.set_cookie("password", password, max_age=30*24*3600) return response else: return "login-fail" // 登录失败,返回给前端的值
2. 定义全局拦截器
这个时候,可能会有人有疑问,为什么要使用拦截器?
试想:进入一个网站有多个入口,你知道用户会以哪个入口来访问你的网站吗?那我们总不能每一个进入网站的接口都去写一份自动登录的逻辑代码吧。所以我们可以直接使用拦截器,将所有的请求都拦截起来,进行统一的处理。然后将静态的资源和不用进行自动登录逻辑处理的请求过滤掉即可
在程序的主入口 main.py 定义一个拦截器
# 定义全局拦截器,实现自动登录 @app.before_request def before(): url = request.path pass_list = ["/user", "/login", "logout"] // 不用进行自动登录逻辑判断的请求 if url in pass_list or url.endswith(".js") or url.endswith(".jpg"): pass // 过滤不用进行自动登录逻辑处理的请求和静态的资源 else: if session.get("islogin") is None: username = request.cookies.get("username") password = request.cookies.get("password") if username != None and password != None: ...... // 自己的逻辑处理 if 登录成功: session["islogin"] = "true" // 是否已经登录的标识 session["username"] = username // 根据自己的需求,在session里存储一些值
3. 退出登录时
退出登录时,清空 session 和 cookie
from flask import make_response, session, request, url_for @user.route("/logout") def logout(): # 清空session和Cookie,页面跳转 session.clear() response = make_response("注销并进行重定向", 302) # 302状态码表示重定向 # 两种重定向的方法 # response.headers["Location"] = "/" response.headers["Location"] = url_for("index.home") # 另一种方式,括号里的值写请求为“/” 的 - Blueprint名.方法名 # 两种清除cookie的方式 response.delete_cookie("username") response.set_cookie("password", "", max_age=0) return response
上面第二种重定向方式中,所对应的值
index = Blueprint("index", __name__) @index.route("/") def home(): ...... // 自己的逻辑处理
到此这篇关于Python Flask前端自动登录功能实现详解的文章就介绍到这了,更多相关Python Flask自动登录内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
X 关闭
X 关闭
- 15G资费不大降!三大运营商谁提供的5G网速最快?中国信通院给出答案
- 2联想拯救者Y70发布最新预告:售价2970元起 迄今最便宜的骁龙8+旗舰
- 3亚马逊开始大规模推广掌纹支付技术 顾客可使用“挥手付”结账
- 4现代和起亚上半年出口20万辆新能源汽车同比增长30.6%
- 5如何让居民5分钟使用到各种设施?沙特“线性城市”来了
- 6AMD实现连续8个季度的增长 季度营收首次突破60亿美元利润更是翻倍
- 7转转集团发布2022年二季度手机行情报告:二手市场“飘香”
- 8充电宝100Wh等于多少毫安?铁路旅客禁止、限制携带和托运物品目录
- 9好消息!京东与腾讯续签三年战略合作协议 加强技术创新与供应链服务
- 10名创优品拟通过香港IPO全球发售4100万股 全球发售所得款项有什么用处?