推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
kadycui
V2EX  ›  Python

django 实现计时功能

  •  
  •   kadycui · Feb 27, 2020 · 3686 views
    This topic created in 2271 days ago, the information mentioned may be changed or developed.

    有这样一个需求,每个普通用户只能在线 30 分,超过 30 分钟提示开启 vip,这个问题怎么解决?

    17 replies    2020-02-28 09:43:45 +08:00
    wuwukai007
        1
    wuwukai007  
       Feb 27, 2020 via Android
    用 token 计时,放 cookie 里
    dcalsky
        2
    dcalsky  
       Feb 27, 2020   ❤️ 1
    1. 登录发放 Token(Payload 里放 now 时间戳)
    2. 每次用户操作验证 Token 的时候(修改 middleware), 都 diff 一下 now 和 Token 里带的时间戳, 看看有没有>30 分钟, 如果大于 30 分钟, 返回 403
    3. 客户端收到 403 以及超时 message, 提醒用户去开启 VIP
    est
        3
    est  
       Feb 27, 2020
    跟 django 无关。。
    wuwukai007
        4
    wuwukai007  
       Feb 27, 2020 via Android
    redis 也行
    kadycui
        5
    kadycui  
    OP
       Feb 27, 2020
    @dcalsky 提前要提前 5 分钟通知用户,要实现计时器功能吧
    kadycui
        6
    kadycui  
    OP
       Feb 27, 2020
    @est 主要是实现计时器功能,计算每个玩家的在线时长,这个怎么实现?
    est
        7
    est  
       Feb 27, 2020
    @kadycui 你抛开 django 考虑下,时长是如何定义的?

    如果用户切 tab 了,或者浏览器关了,你怎么判断?
    wuwukai007
        8
    wuwukai007  
       Feb 27, 2020 via Android
    你如果用的自带的 session 做会话的话,写个中间件,通过 request.user 拿到用户信息,把普通用户的 id 登陆时间存 redis,设个过期时间就好,每次通过中间件检查
    wuwukai007
        9
    wuwukai007  
       Feb 27, 2020
    那我的理解,如果不管用户切换浏览器,还是切换设备登录,只要他第一次登录了,redis 就存储这个用户的 id 等信息,弄个过期时间,那么每次访问通过中间件判断 redis 信息过期没有,这样就跟多点登录设备啥的没关系
    Vegetable
        10
    Vegetable  
       Feb 27, 2020
    你首先要定义什么叫在线,如果注册了之后算在线,那么每次网络请求检查注册时间是否达到标准线就行了。
    37Y37
        11
    37Y37  
       Feb 27, 2020
    websocket 长连接吧,这样最准确也最方便,判断长连接在线时间
    ben1024
        12
    ben1024  
       Feb 27, 2020
    看触发机制问题
    1.用户行为操作时通过中间件拦截
    2.定任务扫登录数据推送
    RickyC
        13
    RickyC  
       Feb 27, 2020
    在 session 里保存一个登录时间戳 logintime , 打开任何页面都计算此刻与 logintime 的差; 当这个差大于 1800 秒时, 提示开启 vip
    MOONLIGHTT
        14
    MOONLIGHTT  
       Feb 27, 2020 via iPhone
    在 token 里加一个初始登陆时间不就行了么
    kadycui
        15
    kadycui  
    OP
       Feb 27, 2020
    @ben1024 感觉 2 可行
    wizardoz
        16
    wizardoz  
       Feb 28, 2020
    定制自己的 Authorization 类,Authorization 类主要功能继承自父类,自己加上判断用户的认证时间,时间超过 30 分钟返回 403 Forbidden。
    wizardoz
        17
    wizardoz  
       Feb 28, 2020
    @wizardoz 补充,是扩展 SessionMiddleware
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   3011 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 45ms · UTC 00:21 · PVG 08:21 · LAX 17:21 · JFK 20:21
    ♥ Do have faith in what you're doing.