RESTful 接口如何保证客户端请求的用户唯一性 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
ytwman
V2EX    问与答

RESTful 接口如何保证客户端请求的用户唯一性

  •  
  •   ytwman 2015 年 6 月 29 日 5716 次点击
    这是一个创建于 3849 天前的主题,其中的信息可能已经有所发展或是发生改变。

    我们接口开发遇到一个问题,是这样的。例如我们使用 oauth 2.0 的密码协议认证。用户登录后认证系统给一个有时效性的 token,然后客户端每次请求的时候带上这个 toekn 访问 restful 资源。但是遇到一个蛋疼的问题就是怎么保证用户请求的资源是合理的。

    场景:
    用户A要删除他的车辆信息。那么client 提交过来 用户主键和车辆主键,先判断当前车辆是否属于当前用户。若数据可以进行删除动作。 这时候如果他人拦截模拟登录,然后传递一个非当前用户的主键(胡乱编造的主键)然后主动探测的模式去匹配对应的主键,去恶意删除他人的用户信息。这样就会出现非常大的危害。例如:所有主键都是通过自增的方式生成的,这样恶意删除的几率就会大得多。

    怎么样才能避免这种情况出现呢?之前也没设计过关于 restful 相关的内容,也没有这方面的经验。
    有种本方法可以实现,就是 把 token 和 用户信息在后端绑定(有点像 session的形式),但是感觉这种又违背了restful 的原则。有没有好的解决方案,或者我理解上的问题?

    10 条回复    2015-06-29 11:52:02 +08:00
    Madimo
        1
    Madimo  
       2015 年 6 月 29 日 via iPhone
    HTTPS,然后客户端本地存 token 的时候加密
    Septembers
        2
    Septembers  
       2015 年 6 月 29 日
    引入 悲观锁 概念?
    mhycy
        3
    mhycy  
       2015 年 6 月 29 日
    所有请求都有伪造的可能,所以所有用户隔离的操作,都必须在服务器有一层验证。
    理想的方式应该是把数据鉴权操作封装到model供前端API调用。

    所以总的来说你需要两样东西
    1:能保证不被伪造的用户相关的TOKEN,以便确定用户。
    2:利用这个用户的id进行操作鉴权,无论是操作上的还是数据上的。
    faceair
        4
    faceair  
       2015 年 6 月 29 日 via iPhone
    token必须跟用户绑定啊 不然用户请求自有的资源你们是怎么搞定的?
    skydiver
        5
    skydiver  
       2015 年 6 月 29 日
    token用签名的方式计算,这样才可以防重放攻击。

    token = hash (url + timestamp + secret + nonce)
    发送请求的时候带上token,username,nonce,服务器验证token和timestamp
    ytwman
        6
    ytwman  
    OP
       2015 年 6 月 29 日
    @skydiver token 的生成方式,我们到不担心,目前使用的是 jwt 的模式生成。
    df4VW
        7
    df4VW  
       2015 年 6 月 29 日
    用UUID防干。

    我没明白的是,操作之前还不是要验证ownership的么。比如用户只能删自己的帖子的话就算被hack了最差也是所有自己的帖子被删
    skydiver
        8
    skydiver  
       2015 年 6 月 29 日
    @ytwman 不担心你怕什么重放……换一个主键url就变了,token就失效了,为啥还怕人攻击
    otakustay
        9
    otakustay  
       2015 年 6 月 29 日 via iPhone
    传递用户主键干嘛,你应该根据token去确认当前用户,而不是信赖对方给你的主键
    cloudzhou
        10
    cloudzhou  
       2015 年 6 月 29 日
    @otakustay 这个做法才是对的,既然使用了 token,理所当然知道这个用户是谁,否则你们的设计太奇怪了吧。
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     2317 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 26ms UTC 01:11 PVG 09:11 LAX 17:11 JFK 20:11
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86