Flask如何获取用户的ip,查询用户的登录次数,并且封ip

 更新时间:2023年01月03日 11:09:20   作者:只因为你而温柔  
这篇文章主要介绍了Flask如何获取用户的ip,查询用户的登录次数,并且封ip问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

Flask获取用户的ip,查询用户的登录次数,并且封ip

尝试获取用户ip的登录次数(LOGIN_ERROR_MAX_TIMES==5), 从redis中获取

	# 判断错误次数是否超过限制, 如果超过限制, 则返回
	    # redis记录: "access_num_请求的ip":"次数"
	    # 获取用户的ip
	    user_ip = request.remote_addr
	
	    try:
	        # redis 我们这里用string类型保存用户尝试次数, 所以获取也用string类型
	        access_num = redis_store.get("access_num_%s" % user_ip)
	    except Exception as e:
	        current_app.logger.error(e)
	    else:
	        # 错误上线5次, 限制它的ip
	        if access_num is not None and int(access_num) >= LOGIN_ERROR_MAX_TIMES:
	            return jsonify(errnum=RET.REQERR, errmsg=u"超过请求次数, 请稍后重试")

设置redis缓存(缓存时间LOGIN_ERROR_FORBID_TIME)

	# 判断用户是否存在或判断用户输入密码与数据库密码不一直
	    if user is None or user.check_password(password):
	        # 如果验证失败, 记录错误次数, 返回信息
	        try:
	            # incr 是直接帮我们自动正常次数累加1
	            redis_store.incr("access_num_%s" % user_ip)
	            redis_store.expire("access_num_%s" % user_ip, LOGIN_ERROR_FORBID_TIME)
	        except Exception as e:
	            current_app.login.error(e)
	
	        return jsonify(errnum=RET.DATAERR, errmsg=u"用户名或密码错误")

Flask获取用户ip,限制用户登录错误次数

从redis中获取用户登录的次数

#获取用户登录的ip
user_addr = request.remote_addr
    try:
    #从redis中获取该ip的登录次数
        sccess_num = redis_store.get('login_error_num_%s' % user_addr)
    except Exception as e:
        current_app.logger.error(e)
    else:
    #判断用户ip是否超过5次(LOGIN_ERROR_TIMES自己定义的常量,为5次)
        if sccess_num is not None and int(sccess_num) >= constans.LOGIN_ERROR_TIMES:
            return jsonify(status=4021,msg='登录失败次数过多,请稍后再试')

设置redis缓存时间

#查询手机号码和密码是否一致
user = User.query.filter_by(mobile=mobile,password=password).first()
#如果存在,就登录成功
    if user:
        return jsonify(status=200,msg='登录成功')
    else:
    #不存在 就设置将用户的ip设置缓存,表示失败,
    #incr()这个函数表示先被初始化为 0 ,然后再执行 INCR 操作,如果存在,就自动加1,自己也可以指定加的次数
        redis_store.incr('login_error_num_%s' % user_addr)
        #设置缓存时间(LOGIN_ERROR_FORBID_TIME为常量,表示设置的时间  为600  单位是秒)
        redis_store.expire('login_error_num_%s' % user_addr,constans.LOGIN_ERROR_FORBID_TIME)

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Pytorch DataLoader 变长数据处理方式

    Pytorch DataLoader 变长数据处理方式

    今天小编就为大家分享一篇Pytorch DataLoader 变长数据处理方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-01-01
  • python request post 列表的方法详解

    python request post 列表的方法详解

    这篇文章主要介绍了python request post 列表的方法详解,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-02-02
  • Python 推导式、生成器与切片问题解决思路

    Python 推导式、生成器与切片问题解决思路

    这篇文章主要介绍了Python 推导式、生成器与切片,生成器实质就是迭代器,通过本文学习能够理解并掌握推导式、切片等用法并能解决实际问题,需要的朋友可以参考下
    2022-03-03
  • django manage.py扩展自定义命令方法

    django manage.py扩展自定义命令方法

    今天小编就为大家分享一篇django manage.py扩展自定义命令方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-05-05
  • 在Python中使用SimpleParse模块进行解析的教程

    在Python中使用SimpleParse模块进行解析的教程

    这篇文章主要介绍了在Python中使用SimpleParse模块进行解析的教程,文章来自于IBM官方的开发者技术文档,需要的朋友可以参考下
    2015-04-04
  • flask框架实现连接sqlite3数据库的方法分析

    flask框架实现连接sqlite3数据库的方法分析

    这篇文章主要介绍了flask框架实现连接sqlite3数据库的方法,结合实例形式分析了flask框架连接sqlite3数据库的具体操作步骤与相关实现技巧,需要的朋友可以参考下
    2018-07-07
  • Python+django实现文件下载

    Python+django实现文件下载

    本文是python+django系列的第二篇文章,主要是讲述是先文件下载的方法和代码,有需要的小伙伴可以参考下。
    2016-01-01
  • Pycharm连接远程服务器并实现远程调试的实现

    Pycharm连接远程服务器并实现远程调试的实现

    这篇文章主要介绍了Pycharm连接远程服务器并实现远程调试的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-08-08
  • 基于Python matplotlib库绘制箱线图

    基于Python matplotlib库绘制箱线图

    这篇文章主要为大家分享了如何利用Python中的matplotlib库实现绘制箱线图与异常值的输出,文中的示例代码讲解详细,需要的可以参考一下
    2022-04-04
  • python安装及变量名介绍详解

    python安装及变量名介绍详解

    这篇文章主要介绍了python安装及变量名介绍详解,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-12-12

最新评论