比如想获取XX公司XX部门XX用户的地址,设计的URL可能会是这样:
<code>GET: /companies/${id}/departments/${id}/users/${id}/address </code>
json方式的返回结果应该如何组织呢?
一些人不清楚问的是什么意思,我再多描述些。
比如返回结果可以是:
<code>{ "code": 200, "message": "xxx", "results": [ { "xxx": "xxx" // address的信息列表 } ] } </code>
因为是多个资源进行关联,有些对于results也可能会这样返回:
<code>{ "company": { "xxx": "xxx", // company的信息列表 "department": { "xxx": "xxx" // department的信息列表 "address": { // 最后是address的信息列表 "xxx": "xxx" } } } } </code>
还有使用Hypermedia API的设计方式(HATEOAS),也就是说对于company,他不返回${id}对应的信息,而是返回一个链接。(对于HATEOAS,我也是比较迷糊的状态)
所以...对于多个资源关联查询,结果应该以何种json结构返回呢?
比如想获取XX公司XX部门XX用户的地址,设计的URL可能会是这样:
<code>GET: /companies/${id}/departments/${id}/users/${id}/address </code>
json方式的返回结果应该如何组织呢?
一些人不清楚问的是什么意思,我再多描述些。
比如返回结果可以是:
<code>{ "code": 200, "message": "xxx", "results": [ { "xxx": "xxx" // address的信息列表 } ] } </code>
因为是多个资源进行关联,有些对于results也可能会这样返回:
<code>{ "company": { "xxx": "xxx", // company的信息列表 "department": { "xxx": "xxx" // department的信息列表 "address": { // 最后是address的信息列表 "xxx": "xxx" } } } } </code>
还有使用Hypermedia API的设计方式(HATEOAS),也就是说对于company,他不返回${id}对应的信息,而是返回一个链接。(对于HATEOAS,我也是比较迷糊的状态)
所以...对于多个资源关联查询,结果应该以何种json结构返回呢?
ls为毛会-1,说的有啥问题没
你的最终目的是get地址,响应把获取的地址返回给客户端不就可以了吗,怎么会需要在意请求的url?
不是很清楚在问什么
返回的json格式吗?
前端需要什么数据就返回什么数据呗
如果只需要用到地址
就直接返回{"address": address}
如果前端跟后端有约定返回格式,就按格式返回就好了
例如
<code>json</code><code>{ "status": STATUS, //可能为请求状态码,表示请求成功与否 "data": { "address": address,//主要获取的信息 "other": other//其他可能需要的信息 } } </code>
根据你的 URI,各对象的关系如下图(把地址做了展开):
从「资源」的角度来看,URI 已经很清晰,取「某人的地址」,那么直接返回即可(假设 MediaType 是 JSON):
<code>{ "province" : "上海市", "city" : "上海市", "district" : "黄浦区", "address" : "日月光广场" } </code>
目前我的设计原则如下(可能还不够规范,持续改进中):
关于 HATEOAS 还在理解中,不敢乱说 :P
开发中的产品基于 REST 架构,也在读下面的几本书,方便的话多交流:
<code>'address' </code>