Soft_Job 板


LINE

※ 引述《chan15 (ChaN)》之铭言: : 各位好,我正在设计公司的 RESTful api,遇到一个身份判定的问题有点卡住,想请教一下各位 : 假设我今天要拿到一个 team 里面我这个 user 的 profile,该怎麽下比较好 : 1. teams/{team_id}/users/profile : 2. teams/{team_id}/users/me/profile : 3. teams/{team_id}/users/{user_id}/profile : 会有这个问题是因为,一般 RESTful 都是表定是 me 了,登入後用在 header 的 token 拿取属於你的资料 : 这个定义的情况下 1 感觉是最接近的,但 users 下没有指定对象又感觉很怪,毕竟 users 是复数 : 假设 2 成立,那我 teams 想要一支 api 也透过 user_id 找其他人 profile 的话 3 跟 2 route 会打架 : 3 如果带上自己 user_id 可以解决全部问题,但又失去了直接比对 jwt token 的便利性 : for me: teams/{team_id}/me/profile : for someone: teams/{team_id}/users/{user_id}/profile : 如果上述成立,另一个模组是 users,专门处理 user 的内容,以忘记密码举例 : for me: users/me/forgot-password : for someone: users/{user_id}/forgot-password : 这 route 又打架了 XD,不确定表达的好不好,目前就是卡在该怎麽在如何在 url 上可以明确看出这只 api : 对到的是你或者是某个指定对象,route 不冲突但也可以兼顾直接拿 jwt token 来用,谢谢 在 teams A 的 users A 和 teams B 的 users A 会是不同的 user 吗? 如果不是的话要把 teams 前缀拿掉。 以目前设计到一半的 PTT API 为例, boards A 的 articles A 和 boards B 的 articles A 会是不同文章,因此要分开。 然後 me 的问题,我不建议使用 users/me 这样的做法,假如有人的 ID 是 me 会很衰 相较之下我会建议你直接用 /me/forget-password 也就是说 /me 来代表 /users/{{current_user_id}} 这样 然後推文有提到 302 我认为这也是好的作法,或是 301 也行,不过在进行Redirect的 时候务必要确定 Proxy Cache 会同时检查 Authorization ,否则有可能会看到别人的 资料。 顺带一提,我觉得me最好用的时机是让前端检查登入状态用,因为4字头就代表没登入 假如 200 就可以接着画使用者资料了。 然後我没有考虑 JWT, 因为 JWT 里的资讯本来就比较额外。 -- 人红是非多,活益比非多。 --
QR Code



※ 发信站: 批踢踢实业坊(ptt.cc), 来自: 111.248.47.164 (台湾)
※ 文章网址: https://webptt.com/cn.aspx?n=bbs/Soft_Job/M.1611796477.A.192.html
1F:推 yukang: 我觉得怕me 重复可能只有 ptt 才会发生 01/28 09:42
2F:→ yukang: 基本的帐号长度都超过2码 01/28 09:42
3F:→ bill0205: id如果是int其实就还好 如果是uuid就有可能了XD 01/28 09:48
4F:推 CMJ0121: p果是 RESTFul API 帐号相关还是不建议用可以列举的 int 01/28 13:53
5F:→ csieflyman: 我习惯用 /users/{userId}/profile 及 /users/myProfi 01/28 15:36
6F:→ csieflyman: le 因为 userId 会自动填入变数 型态可能是 long 或 u 01/28 15:36
7F:→ csieflyman: uid 所以不能直接写死 me 01/28 15:36







like.gif 您可能会有兴趣的文章
icon.png[问题/行为] 猫晚上进房间会不会有憋尿问题
icon.pngRe: [闲聊] 选了错误的女孩成为魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一张
icon.png[心得] EMS高领长版毛衣.墨小楼MC1002
icon.png[分享] 丹龙隔热纸GE55+33+22
icon.png[问题] 清洗洗衣机
icon.png[寻物] 窗台下的空间
icon.png[闲聊] 双极の女神1 木魔爵
icon.png[售车] 新竹 1997 march 1297cc 白色 四门
icon.png[讨论] 能从照片感受到摄影者心情吗
icon.png[狂贺] 贺贺贺贺 贺!岛村卯月!总选举NO.1
icon.png[难过] 羡慕白皮肤的女生
icon.png阅读文章
icon.png[黑特]
icon.png[问题] SBK S1安装於安全帽位置
icon.png[分享] 旧woo100绝版开箱!!
icon.pngRe: [无言] 关於小包卫生纸
icon.png[开箱] E5-2683V3 RX480Strix 快睿C1 简单测试
icon.png[心得] 苍の海贼龙 地狱 执行者16PT
icon.png[售车] 1999年Virage iO 1.8EXi
icon.png[心得] 挑战33 LV10 狮子座pt solo
icon.png[闲聊] 手把手教你不被桶之新手主购教学
icon.png[分享] Civic Type R 量产版官方照无预警流出
icon.png[售车] Golf 4 2.0 银色 自排
icon.png[出售] Graco提篮汽座(有底座)2000元诚可议
icon.png[问题] 请问补牙材质掉了还能再补吗?(台中半年内
icon.png[问题] 44th 单曲 生写竟然都给重复的啊啊!
icon.png[心得] 华南红卡/icash 核卡
icon.png[问题] 拔牙矫正这样正常吗
icon.png[赠送] 老莫高业 初业 102年版
icon.png[情报] 三大行动支付 本季掀战火
icon.png[宝宝] 博客来Amos水蜡笔5/1特价五折
icon.pngRe: [心得] 新鲜人一些面试分享
icon.png[心得] 苍の海贼龙 地狱 麒麟25PT
icon.pngRe: [闲聊] (君の名は。雷慎入) 君名二创漫画翻译
icon.pngRe: [闲聊] OGN中场影片:失踪人口局 (英文字幕)
icon.png[问题] 台湾大哥大4G讯号差
icon.png[出售] [全国]全新千寻侘草LED灯, 水草

请输入看板名称,例如:BabyMother站内搜寻

TOP