Spring RestController 请求参数详解

Spring RestController 请求参数详解

在阅读以前,最好先了解http请求的get,post,以及各类head头类型,请求参数类型。html

  1. 无参数,设置RestController请求路径
  2. 查询字符串参数,可选和必选参数
  3. json参数,RestController用实体类型接受
  4. 路径参数
  5. body参数
  6. 文件流参数

1 无参数,设置RestController请求路径

下面是一个例子,例子无请求参数,经过@RequestMapping设置了请求的路由路径和请求方法。路由路由由类的mapping和方法的mapping组成,在后面的例子中,我就再也不写出RestApiRequestDemoController类的mapping了。记住,url里面有个demo在前面。java

@RestController
@RequestMapping("/demo")
public class RestApiRequestDemoController {

    ///方法说明: 普通查询
    ///示例请求:http://localhost:8091/demo/list
    @RequestMapping(value="/searchList",method = RequestMethod.POST)
    @ResponseBody
    public List<UserModel> searchList() {
        List list = new list();
        return list;
    }
}

2 查询字符串参数,可选和必选参数2. 查询字符串参数,可选和必选参数

下面是使用查询字符串的例子,required能够设置请求的字符串是否必填sql

///方法说明:url参数的使用-查询字符串 ,且name必填
///示例请求:http://localhost:8091/demo/searchListByName?name=liuyanwei
@RequestMapping(value="/listByName",method = RequestMethod.POST)
@ResponseBody
public List<TbUserModel> searchList(@RequestParam(value="name",required = true) String name) {

    Session context = DatabaseHelper.context();
    String sql = "select * from tb_user where name ='"+ name+"'" ;
    List list = context.createSQLQuery(sql)
            .setResultTransformer(Transformers.aliasToBean(TbUserModel.class))
            .list();
    return list;

}

3 json参数,RestController用实体类型接受

注意,须要设置application/json 不然数据库会返回。hibernate操做数据库代码暂时能够不用去管他。数据库

/* * 方法说明:添加数据 * 1:使用json数据提交,直接使用实体对象接收 * 2:hibernate 添加数据 * 请求参数: {"id":1,"userId":1,"pwd":"123","name":"123","pwd":"123","headPortait":"123","isEnable":"123","createDate":"2015-05-12","lastLogin":"2015-05-12"} * 请求头:Content-Type : application/json * 请求ur:http://localhost:8091/demo/addUser * */
@RequestMapping(value="/addUser",method = RequestMethod.POST)
@ResponseBody
public TbUserModel addUser(@RequestBody TbUserModel user) {

    Session context = DatabaseHelper.context();
    Transaction tran = context.beginTransaction();
    context.save(user);
    tran.commit();
    user.setId(user.getId());
    context.close();
    return user;


}

4 路径参数

路径参数不能设置是否必填,所有都是必须填,不能省略的json

///方法说明:url参数的使用
///示例请求:http://localhost:8091/demo/searchListById/2
@RequestMapping(value="/searchListById/{id}",method = RequestMethod.POST)
@ResponseBody
public List<TbUserModel> searchList(@PathVariable("id") int id) {

     Session context = DatabaseHelper.context();
    // String sql = "select * from tb_user where id ="+ id ;
     String sql = "select * from tb_user where tb_user.id = :id";
     System.out.println(sql);
     List list = context.createSQLQuery(sql).setInteger("id", id)
             .setResultTransformer(Transformers.aliasToBean(TbUserModel.class))
             .list();
     return list;

}

高级用法:路径参数能够自由设置本身的规则,好比,你有个请求须要两个参数,月和日,你能够写成{month}-{day}api

///方法说明:url参数的使用
///示例请求:http://localhost:8091/demo/searchListByDate/2-10
@RequestMapping(value="/searchListByDate/{month}-{day}",method = RequestMethod.POST)
@ResponseBody
public List<TbUserModel> searchList(@PathVariable("month") int month,
                                    @PathVariable("day") int day) {



}

5. 表单参数参数

注意,数组

  1. 这种方式传参数不能设置参数选填
  2. 注意,参数写在boby中,至关于表单参数,必须设置请求头为:application/x-www-form-urlencoded
  3. 若参数不正确,是没法进入控制器的。
/* * 方法说明:使用表单方式提交数据 * 请求参数:isEnable=1&name=cool * 配置 * 请求头:Content-Type : application/x-www-form-urlencoded * 请求url:http://localhost:8091/demo/findUsersByName * */
    @RequestMapping(value="/findUsersByName",method = RequestMethod.POST)
    @ResponseBody
    public void findUsersByName(boolean isEnable , String name)
    {
        System.out.println(isEnable);
        System.out.println(name);
    }

6. 文件流参数

  1. 单个文件经过这种方式 @RequestParam(“file”) MultipartFile file得到,这里是简单的写法,至关于 MultipartFile file = ((MultipartHttpServletRequest) request).getFile(“file”); 多个文件使用@RequestParam(“files”) MultipartFile[] files)app

  2. 表单中文件的name属性必须设置file(注意,不是文件名),例如,html中 &ltinput type="files" name="file" > </li>
  3. 这个是简单获取文件的方式,若不知道表单中文件的name属性,能够经过request获取文件

例子:ide

@RequestMapping("upload")
public Resp upload(HttpServletRequest request,
                   HttpServletResponse response, @RequestParam("file") MultipartFile file){

    try {
        //MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request;
        String filePath = FilesService.uploadFile(file, request);
        return Resp.succeedResp(filePath);
    }
    catch (Exception e){
        e.printStackTrace();
    }

    return Resp.failureResp("图片上传失败");
}


@RequestMapping("batchUpload")
public Resp batchUpload(HttpServletRequest request,
                   HttpServletResponse response,
                   @RequestParam("files") MultipartFile[] files) throws IOException {
    List<String> list = new ArrayList<String>();
    try {
        for (MultipartFile file :files) {
            String filePath = FilesService.uploadFile(file, request);
            list.add(filePath);
            System.out.println("filePath:" + filePath);
        }
        return Resp.succeedResp(list);
    }
    catch (Exception e){
        e.printStackTrace();
    }
    return  Resp.failureResp("文件上传失败");
}

总结

想要把Rest风格的api用好,合理利用参数是必须的。不一样功能的api使用不一样类型的参数接收方式。每一个人有不一样的习惯,个人习惯是:post

  1. 通常获取内容,不涉及加密的用get方法,设计加密的用post
  2. 提交内容,例如添加,删除,修改,使用post、delete、put方法
  3. 经过主键获取内容的,我习惯用url参数,例如:/news/details/1,参数不是不少,组合起来有意义的也会用url路径组合,例如前面的日期:/demo/searchListByDate/2-10
  4. 有时候接收参数组合起来用比较好,有的内容经过url参数,有的部分用表单内容。
  5. 全部的设计接收参数的原则就是,然你的api的url能读通,看起来合理。

好了,就到这了,后面有时间我会再写一些hibernate 数据操做的例子和hibernate获取实体参数验证的内容,有的问题我也还没彻底搞清楚,后面在研究看看。

相关文章
相关标签/搜索