• 请不要在回答技术问题时复制粘贴 AI 生成的内容
timqian
10.02D
V2EX  ›  程序员

目前认为是 RESTful api 设计的正确姿势。欢迎批评指正: https://github.com/timqian/jwtAuth-RESTful-server-starter

  •  2
     
  •   timqian ·
    timqian · Dec 2, 2015 · 4813 views
    This topic created in 3847 days ago, the information mentioned may be changed or developed.
    24 replies    2015-12-03 11:54:37 +08:00
    Juggernaut
        1
    Juggernaut  
       Dec 2, 2015
    node.js 代码?
    timqian
        2
    timqian  
    OP
       Dec 2, 2015
    haozhang
        3
    haozhang  
       Dec 2, 2015
    说实话你的登陆的 endpoint 命名用的是 login ,这不好,应该用 authentications 之类的。而且 token 最好再次加密下。
    timqian
        4
    timqian  
    OP
       Dec 2, 2015 via Android
    @haozhang 你说的加密指的是怎样
    haozhang
        5
    haozhang  
       Dec 2, 2015
    @timqian 将 token 进行加密,第一次生成 jwt 的特征太明显了。
    timqian
        6
    timqian  
    OP
       Dec 2, 2015
    @haozhang 其实不把重要信息(比如 password )放在 claims 里,应该没什么问题。对安全性有更高要求的话就用 JWE 了。
    参考: https://stormpath.com/blog/jwt-the-right-way/
    haozhang
        7
    haozhang  
       Dec 2, 2015
    @timqian 这种特征很明显的东西不加层密能说得过去么...而且你的 API 的命名明显是错的。
    像 login 这种应该用 authentications 之类的。
    nuc093
        8
    nuc093  
       Dec 2, 2015   ❤️ 1
    timqian
        9
    timqian  
    OP
       Dec 2, 2015
    @haozhang 谢谢你的回复。
    关于验证用户的 API 叫作 login 还是 authentications :的确看到大家大多用后者,我之后很可能会把它改掉。但我没有找到很好的理由非得用 authentications ( URL 应该用名词这个惯例我是知道的,但 login 也可作名词的吧)。不知道你有什么重要的理由?
    关于加密,我对网络安全不是很熟,能不能说下为什么说不过去或者给个链接给我参考。

    我原本想的是对于一般的用户相关 API 使用 token 来验证(比如查看用户点赞的内容), 当涉及比较重要的操作(比如下订单)。需要用户重新验证用户名密码。
    timqian
        10
    timqian  
    OP
       Dec 2, 2015
    @nuc093 的确不错。回头仔细看看
    nuc093
        11
    nuc093  
       Dec 2, 2015
    @timqian 我已经用在我们的项目里了啊。后面准备加 LDAP 、权限角色。他有 github demo 跑起来很快的。
    Juggernaut
        12
    Juggernaut  
       Dec 2, 2015
    目前 RESTful ,哪几本书最值得推荐?
    大家聊聊
    blue7wings
        13
    blue7wings  
       Dec 2, 2015
    @Juggernaut <build apis you won't hate> laravel 相关. 这类书貌似不是特别多.
    canesten
        14
    canesten  
       Dec 2, 2015
    现在神烦 RESTful
    html4 form method 只有 get post
    一个 http 请求的一个完整事务里牵扯到两个不同的 resuorce 的不同 action 要咋命名?
    10 个动态查询条件的 http 请求要如何设计 RESTful 的 url ?
    求大神教教我
    int64ago
        15
    int64ago  
       Dec 2, 2015   ❤️ 1
    @canesten
    - AJAX
    - 分别请求
    - /path/to/:your_resource
    haozhang
        16
    haozhang  
       Dec 2, 2015
    hantsy
        18
    hantsy  
       Dec 3, 2015
    hantsy
        19
    hantsy  
       Dec 3, 2015
    devtiange
        20
    devtiange  
       Dec 3, 2015
    @haozhang
    - 叫 login 好像没啥不妥
    - jwt 里没敏感信息, 没必要加密. 你好像不太懂 jwt
    - 你贴的那个 koablog 没有楼主写的好
    haozhang
        21
    haozhang  
       Dec 3, 2015
    @devtiange ....我的思路和他的思路不是一样的么...都是发 username 和 pwd 拿 token ,每次验证 token....哪里有我写的没他好这种说法...
    haozhang
        22
    haozhang  
       Dec 3, 2015
    @devtiange 叫 login 我觉得非常不妥。 jwt 起码会有 user 的 id 在里面,必须加密。 koablog 是我自己写的,我觉得比楼主的写得好。
    hantsy
        23
    hantsy  
       Dec 3, 2015
    还在为 Authentication 这种东西费心。。。
    haozhang
        24
    haozhang  
       Dec 3, 2015
    @hantsy 不为这种东西费心?准守规则不对吗?
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   1197 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 65ms · UTC 17:24 · PVG 01:24 · LAX 10:24 · JFK 13:24
    ♥ Do have faith in what you're doing.