AFuture
V2EX  ›  问与答

小程序登录技术询问,使用 Django 做后台

  •  
  •   AFuture · Mar 5, 2019 · 3277 views
    This topic created in 2655 days ago, the information mentioned may be changed or developed.

    毕设使用 Django 做后台,小程序要经过后台的验证才能通过。

    目前已经利用 django 的 rest framework jwt 做到了:

    1. 小程序 POST 基本信息到后台
    2. 后台检测登录信息是否合法
    3. 合法的情况下 通过 code2session 获取 open id 和 session key
    4. 申请一个利用 User 信息申请一个 token。
    5. 返回这个 token

    现在面临技术难题:如何保存这个腾讯服务器给的 session key ? 我的思路是利用 Django 的 Session 缓存存下当前用户的需要存的信息,但是不知道具体如何操作,希望大佬们给点意见,谢谢!

    8 replies    2019-03-05 23:54:21 +08:00
    hoosin
        1
    hoosin  
       Mar 5, 2019
    JWT 了解一下
    AFuture
        2
    AFuture  
    OP
       Mar 5, 2019 via iPhone
    @hoosin 我 django 里使用了 rest framework jwt,目前的问题是如何存每个用户的必要的信息 如 session key.
    zqx
        3
    zqx  
       Mar 5, 2019 via Android
    jwt.io 这个库,把用户信息生成编码放到客户端存储中
    contradictspiral
        4
    contradictspiral  
       Mar 5, 2019 via Android
    我记得小程序的 session key 似乎是不能反给客户端的,我的话会通过 Abstractuser 自己实现 user model 来加个字段来存 session key
    qiayue
        5
    qiayue  
    PRO
       Mar 5, 2019 via Android
    存数据库不行吗
    so1n
        6
    so1n  
       Mar 5, 2019
    存数据库或者 redis
    AFuture
        7
    AFuture  
    OP
       Mar 5, 2019 via iPhone
    @zqx 多谢大佬 我看看

    @contradictspiral 我也有过这个考虑 但是 session key 不是会失效么 感觉加在用户表里不大好

    @qiayue 存数据库的话得再写额外代码维护 session key 的有效性 有点麻烦 所以想用 django 的 session 搞定
    contradictspiral
        8
    contradictspiral  
       Mar 5, 2019 via Android
    每次用户登录都可以获取到全新的 session key, 小程序这种快应用场景下感觉有效期应该足够用户操作完到退出了
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   4954 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 73ms · UTC 09:35 · PVG 17:35 · LAX 02:35 · JFK 05:35
    ♥ Do have faith in what you're doing.