API设计二

1 GET接口

get请求通常表达获取某种资源。

(1)获取多个资源。针对多个资源的获取我们可以使用url中的名词为复数形式进行标记为获取多个,具体示例如下:

    //获取多个用户信息
    @GetMapping(value="/users")
    public List<User> getUsers(){
        ... ...
    }

(2)获取单个资源,并且按照田间进行筛选。这里我们就需要使用到url参数来传递筛选条件。具体示例如下:

    //获取单个用户信息
    @GetMapping("/user")
    public User getUser(
            @RequestParam(value = "name",defaultValue = "liutao")String name,
            @RequestParam(value = "age",defaultValue = "10") int age) {
 
            ... ...
    }

上面例子的name和age就为筛选条件,具体url类似http://locahost:8888/api-demo/user?name=XXXX&age=10

当我们想要参数的合法性,如果不合法的时候,我们就返回错误状态码及错误信息。这里需要注意,我们不直接在响应内容中返回错误信息,这样会加重对响应内容的封装负担。我们直接在响应头中添加错误信息,具体如下:

if(age < 0){
            HttpServletResponse response = ((ServletRequestAttributes)RequestContextHolder.getRequestAttributes()).getResponse();
            response.setStatus(10004);
            response.addHeader("Error-Message","Parameter is invalid");
            return null;
        }

这个时候如果请求传入的age < 0,响应的结果就会如下:


image

我们就可以根据响应状态码来获取请求状态,如果请求错误,我们就可以从请求头获取Error-Message来得到错误信息。

(3)如果我们想要限定用户所属部门,但是这个时候我们又不想要使用路径参数,咋办呢?这个时候就应该能想到Spring中有一个注解PathVariable,具体示例如下:

    /**
     * 获取某个部门下的某个用户
     * 这里针对部门的限制使用了路径参数,使用PathVariable标签来获取部门信息
     *
     * @param dept
     * @param name
     * @return
     */
    @GetMapping("/{dept}/user")
    public User getUserOfDept(
            @PathVariable("dept") String dept,
            @RequestParam(value = "name")String name,
            HttpServletRequest request
    ){
            ... ...
     }

这个时候请求路径可以是这样的 http://locahost:8888/api-demo/finance/user?name=XXXX。
然后我们就可以获取到部门信息(dept)为finance。

在我们通常的API中涉及到权限认证token的问题,我们可以直接将token存放在请求头里面,然后在接口里面获取请求头里面的token,进行权限认证,如下:

String token = request.getHeader("token");

当然针对上面这一步建议直接在拦截器里面做处理。

2 POST接口

post请求表达对某种资源的创建。
(1)针对Restful API我们建议数据传递使用json格式。示例如下:

    //添加用户信息
    @PostMapping("/json/user")
    public int addUserToSpecialDepart(
            @RequestParam("dept") String dept,
            @RequestBody User user
    ){
        ... ... 
    }

RequestBody标签会自动将json格式的数据转换成对象。
(2)上面我们看了post接口如何接收json格式,那么如果我们要接收form表单数据呢?这个时候就需要将RequestBody注解换成ModelAttribute,示例如下:

    /**
     * 添加用户信息
     * 请求参数支持表单数据
     * @param user
     * @return
     */
    @PostMapping("/form/user")
    public int addUserByForm(@ModelAttribute User user){
        ... ... 
    }

3 PUT接口

put请求表示对某种资源的修改,但是我们需要注意put的修改与patch相比,put需要传入修改对象的全部数据,二patch仅仅需要传递部分数据。

   //修改用户信息(传入被修改对象的全部)
   @PutMapping("user")
   public int updateUser(@RequestBody User user){
       ... ...
   }

4 PATCH接口

patch接口表示修改,需要传入修改对象的部分内容。

    /**
     * 修改用户名(传入被修改对象的部分信息)
     * @param id
     * @param name
     * @return
     */
    @PatchMapping("user/{id}")
    public int updateUserName(
            @PathVariable("id")String id,
            @RequestParam("name") String name
    ){
        ... ...
    }

5 DELETE接口

delete请求表示删除某个资源,其实delete请求和get请求的使用方式是相同的,不同的仅仅是请求动词。

    /**
     * 删除用户信息
     * @return
     */
    @DeleteMapping("user")
    public int getUser(
            @RequestParam(value = "name",defaultValue = "liutao")String name,
            @RequestParam("age") int age) {
        ... ...
    }

上面就是对SpringBoot中常遇到的Restful API的接口类型的总结,当然在我们接口设计时还会涉及到接口数据传递的安全性问题,这个时候我们就需要对接口数据进行加密,目前最安全的加密方式时RSA加密,针对RSA解密接口数据和加密返回数据,博主利用SpringBoot写了一个自动加密工具,可以参考TOOL_SpringBootSecurityStater 查看源码。

作者:ONROAD0612
来源:CSDN
原文:https://blog.csdn.net/ONROAD0612/article/details/82256505
版权声明:本文为博主原创文章,转载请附上博文链接!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,904评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,581评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,527评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,463评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,546评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,572评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,582评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,330评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,776评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,087评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,257评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,923评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,571评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,192评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,436评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,145评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容

  • 去年有段时间得空,就把谷歌GAE的API权威指南看了一遍,收获颇丰,特别是在自己几乎独立开发了公司的云数据中心之后...
    骑单车的勋爵阅读 20,497评论 0 41
  • API 参考文档 本文档基于 go-ipfs v0.4.11-dev 版本,发布于2017年8月23日。 这是一篇...
    汤办阅读 8,787评论 0 8
  • 一说到REST,我想大家的第一反应就是“啊,就是那种前后台通信方式。”但是在要求详细讲述它所提出的各个约束,以及如...
    时待吾阅读 3,421评论 0 19
  • 还记得五年前的愿望么?那时候常常说:五年后的自己要成为什么样的人。可是光是说不去行动,永远停留在昨天。 把昨天丢掉...
    映月黑珍珠阅读 376评论 8 8
  • 在雅思口语备考过程中,考生对口语的恐惧要远胜于其他三科,主要体现在无从下手。大部分问题用中式思维的因果介绍都显得特...
    蔓蔓longre阅读 591评论 0 0