Java进阶之走进RESTful接口
一、什么是api
api (应用程序编程接口) 两种用法
1.类似jar的使用:a软件将功能打包成组件(功能块:比如java中的jar),让b软件导入直接使用
2.http请求方式:a项目(系统)提供一个映射方法路径,b项目(系统)发起http请求得到对应功能 (应用请求方式)
应用接口:很多情况下,需要把系统的部分功能(组件)作为服务暴露给外部的其他应用使用,所以就需要把系统中的服务作为api接口暴露出去,一般分为公共接口和私用接口(公司内部)
二、了解web技术的发展阶段
- 静态内容阶段:web 由大量的静态 html 文档组成
- cgi程序阶段:web 服务器增加了一些编程 api,可以提供一些动态的内容
- 脚本语言阶段:服务器端出现了 asp、php、jsp、coldfusion 等支持 session 的脚本语言技术,浏览器端出现了 java applet、javascript 等技术
- 瘦客户端应用阶段:服务器端出现了独立于 web 服务器的应用服务器。同时出现了 web mvc 开发模式
- ria 应用阶段:出现了多种 ria(rich internet application)技术,应用最为广泛的 ria 技术是 dhtml+ajax
- 移动 web 应用阶段:出现了大量面向移动设备的 web 应用开发技术 android、ios 、h5等
三、前后端分离模式
前后端分离,字面意思就是 前端+后端分离,传统的开发模式前后端耦合过高,不利于维护,一旦前后端任意一方换,不利于开发.
优点:
- 前后端责任分离,后端负责数据,前端负责页面
- 提高工作效率,无需等待对方开发工作结束
- 增强代码的可维护性
- 应对复杂的前端需求
四、restful风格
是一种规范,规范后端编写的逻辑. rest是一种设计api的模式(风格),常用json数据格式(能被js直接读取) , rest只是一种设计风格 , 而不是标准
五、restful规范与传统规范的区别
传统的请求映射方法(接口)设计考虑要点:
1.请求路径 : /employee/list
2.请求方法:get/post
3.请求参数: employee对象
4.请求响应值: jsonresult对象
restful风格接口约束的要点:
1.请求路径: 要求是操作资源(实体对象:domain)名称复数 /employees
2.请求方式: 使用请求方式替换资源crud操作 :post–新增 ,get–查询 ,delete–删除 ,put–更新
3.请求参数:跟之前一样,需求决定
4.请求响应值:跟之前一样,需求决定,但是建议返回值都是json格式
六、restful设计
网络上的所有事物都被抽象为资源
restful认为,每个资源都有自己唯一的资源定位符(uri), 每个uri都代表了一种资源,以一张图片为例:图片有自己的路径, 所以图片也是一种资源. 所以uri中不用动词,只用名词. 一般数据库的表都是记录同种的集合,所以为名词为复数 这就是为什么请求路径中的操作资源要加 s , 可以不遵循这个规范(看自己喜欢或者公司规范)
资源状态转换
当我们访问一个网站,必然代表客户端和服务端间的互动,这种互动,会涉及资源间的状态变化,http协议,是一个无状态协议,所以资源的状态保存在服务器中,如果需要改变状态,需要使用http方法去让服务器资源发生改变.简单的说就是,对应请求发生改变
新增 :从无到有 更新:从某个状态变成另一个状态 删除 :从有到无
使用统一接口
rest要求,必须通过统一的接口来对资源执行各种操作
- get: 查询全部list http://localhost:8080/employees
- get :查询单个 http://localhost:8080/employees/1 (1是id参数值,同时也是请求路径的一部分)
- post: http://localhost:8080/employees?新增的员工信息
- put: http://localhost:8080/employees?id=1 更新 id为1的员工信息
- delete: http://localhost:8080/employees?id=1 更新 id为2的员工信息
- head:获得一个资源的元数据,比如一个资源的hash值或者最后修改日期
- options:获得客户端针对一个资源能够实施的操作,获取该资源的api
员工列表查询与员工单个查询,使用相同映射路径" /employees 和相同请求方法:requestmethod.get, 导致请求路径(路径+请求方法)一样,报错 restful提供解决方案:使用参数路径方法 参数路径:将参数作为请求路径的一部分 /employee/{id} 还要加上注解@pathvariable,将id拿到 浏览器/postman发起请求时使用: http://localhost:8080/employee/1 其中1是id参数值,同时也是请求路径的一部分 另外,请求映射方法必须使用@pathvariable 进行参数读取 注意: 如果路径参数标记与请求参数名不一致时 ,怎么办? 可以使用@pathvariable("eid") value属性指定
七、例子:
@controller public class employeecontroller { @requestmapping(value = "employees",method = requestmethod.get) @responsebody public list<employee> list(){ list<employee> employees = arrays.aslist(new employee(1l, "小罗", 22), new employee(2l, "小轩", 18)); return employees; } @requestmapping(value = "employees/{id}",method = requestmethod.get) @responsebody public employee get(@pathvariable long id){ list<employee> employees = arrays.aslist(new employee(1l, "xxx", 22), new employee(2l, "qqq", 22)); return employees.get((int) (id-1)); } @requestmapping(value = "employees",method = requestmethod.post) @responsebody public employee save(employee employee){ employee.setid(1l); return employee ; } @requestmapping(value = "employees",method = requestmethod.delete) @responsebody public jsonresult delete(long id){ return new jsonresult(true,"删除成功"); } @requestmapping(value = "employees",method = requestmethod.put) @responsebody public jsonresult update(long id){ return new jsonresult(true,"更新成功"); } }
参数路径方法与传统方式对比
参数路径方式: 优点:可以隐藏参数,避免暴露参数,相对安全 缺点:如果参数较多,url过长 不建议使用 参数较少选用参数路径方法
同一资源具有多种表现形式
http请求的头信息中用accept和content-type字段表现形式
accept与content-type的区别
1.accept属于请求头, content-type属于实体头。
2.accept代表发送端(客户端)希望接受的数据类型。content-type代表发送端(客户端|服务器)发送的实体数据的数据类型。
accept:application/json :代表客户端希望接受得数据类型是json类型,后台返回json数据 content-type:application/json:代表发送端发送数据格式是json,后台要以这种格式类接收前端的数据
八、使用ajax发送请求
删除,更新操作 $.ajax({ url: 路径 , type: 类型 , data: 参数{id:111}, success:(回调函数)function(data){ } })
<script> $(function () { //查全部 $("#btn1").click(function () { $.get("/employees" ,function (data) { console.log(data); }) }); //查单个 $("#btn2").click(function () { $.get("/employees/1" ,function (data) { console.log(data); }) }); //新增 $("#btn4").click(function () { $.post("/employees" ,{name:"xiao",age:18},function (data) { console.log(data); }) }); //删除 $("#btn3").click(function () { $.ajax({ url:"/employees", type: "delete", data:{id:1}, success:function (data) { console.log(data); } }) }); //更新 $("#btn5").click(function () { $.ajax({ url:"/employees", type: "put", data:{id:1}, success:function (data) { console.log(data); } }) }) }) </script>
springmvc默认不支持put请求,需要额外处理put或patch请求方式的过滤器,springboot支持
<filter> <filter-name>httpputformcontentfilter</filter-name> <filter-class>org.springframework.web.filter.httpputformcontentfilter</filter-class> </filter> <filter-mapping> <filter-name>httpputformcontentfilter</filter-name> <servlet-name>springmvc</servlet-name> </filter-mapping>
九、相关注解
@getmapper、@postmapping、@deletemapping、@putmapping
等价于 method =requestmethod.get|post|delete|put
@restcontroller
等价于 @controller +@responsebody
@pathvariable
通过 @pathvariable 可以将 url 中占位符参数绑定到控制器处理方法参数中
url 中的 {xxx} 占位符可以通过@pathvariable(“xxx“) 绑定到操作方法的参数中。
@requestmapping标签属性
params :要求请求中必须携带指定名称的参数 params="name" :必须携带name参数 params="name=xuan" :必须携带name参数,并且name=xuan headers :请求头,限定要处理请求的请求头信息,只有匹配才会被方法处理 consume :等价于content-type value/path:映射路径 method:限定请求的方式
优化restful规范的 例子代码
@restcontroller @requestmapping("employees") public class employeecontroller { @getmapping public list<employee> list(){ list<employee> employees = arrays.aslist(new employee(1l, "小罗", 22), new employee(2l, "小轩", 18)); return employees; } @getmapping(value = "/{id}") public employee get(@pathvariable long id){ list<employee> employees = arrays.aslist(new employee(1l, "xxx", 22), new employee(2l, "qqq", 22)); return employees.get((int) (id-1)); } @postmapping public employee save(employee employee){ employee.setid(1l); return employee ; } @deletemapping public jsonresult delete(long id){ return new jsonresult(true,"删除成功"); } @putmapping public jsonresult update(long id){ return new jsonresult(true,"更新成功"); } }
api接口测试工具
postman, insomnia
restful开发框架
常见的有 springmvc , jersey , play
到此这篇关于java进阶之走进restful的文章就介绍到这了,更多相关java restful内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!