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内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Java 调用Restful API接口的几种方式(HTTPS)

    摘要:最近有一个需求,为客户提供一些Restful API 接口,QA使用postman进行测试,但是postman的测试接口与java调用的相似但并不相同,于是想自己写一个程序去测试Restful API接口,由于使用的是HTTPS,所以还要考虑到对于HTTPS的处理.由于我也是首次使用Java调用restful接口,所以还要研究一番,自然也是查阅了一些资料. 分析:这个问题与模块之间的调用不同,比如我有两个模块front end 和back end,front end提供前台展示,back

  • Java源码解析之接口List

    前言 List接口是Collection接口的三大接口之一,其中的数据可以通过位置检索,用户可以在指定位置插入数据.List的数据可以为空,可以重复.我们来看看api文档是怎么说的: 一.List特有的方法 我们这里就只关注和Collection不同的方法,主要有以下这些: //在指定位置,将指定的集合插入到当前的集合中 boolean addAll(int index, Collection<? extends E> c); //这是一个默认实现的方法,会通过Iterator的方式对每个元素

  • 最好的8个Java RESTful框架

    过去的每一year,涌现出越来越多的Java框架.就像JavaScript,每个人都认为他们知道一个好的框架的功能应该是怎么样的.连我的老祖母现在也使用 一个我从来没有听说过而且可能永远不会使用的框架.玩笑归玩笑,可以做几乎任何事的臃肿的框架市场已经饱和,,但是如何评判呢?这篇文章旨在提供目前最好的 Java RESTfulful 框架.我只介绍轻量级的产品, 略过了那些臃肿的过度设计的框架.同时,我只想要他们稳定和成熟,提供简单,轻量级的特点.我只在介绍Play frameworks时打破这条

  • 浅谈java调用Restful API接口的方式

    摘要:最近有一个需求,为客户提供一些RestfulAPI接口,QA使用postman进行测试,但是postman的测试接口与java调用的相似但并不相同,于是想自己写一个程序去测试RestfulAPI接口,由于使用的是HTTPS,所以还要考虑到对于HTTPS的处理.由于我也是首次使用Java调用restful接口,所以还要研究一番,自然也是查阅了一些资料. 分析:这个问题与模块之间的调用不同,比如我有两个模块frontend和backend,frontend提供前台展示,backend提供数据支

  • Java MongoDB实现REST过程解析

    导入依赖 application.properties spring.data.mongodb.host=127.0.0.1 spring.data.mongodb.authentication-database=admin spring.data.mongodb.username=root spring.data.mongodb.password=root spring.data.mongodb.port=27017 spring.data.mongodb.database=test publ

  • IDEA中WebService生成Java代码并调用外部接口实现代码

    最近一个Spring项目中需要调用其他第三方系统的接口对接数据,对方只给了一个wsdl地址,我们需要根据给的wsdl地址,自己来生成里边的接口等调用接口所需要的类,来调用接口实现数据获取,进行自己的业务处理. 通过wsdl文件生成java代码 我们根据wsdl地址生成所需接口的代码,方式很多.可以用jdk自带的wsimport,我是用的idea开发工具生成的. 根据对方提供的地址,在浏览器中输入能调用得到xml格式文件,证明对方服务开启并能访问,然后右键网页保存xml文件,修改后缀名为wsdl.

  • Java基于rest assured实现接口测试过程解析

    背景 java程序员一般写的是后端服务是JavaWeb类型的项目,主要包括Http接口和dubbo接口,Http接口一般采用的rest风格,那么如何快速的对rest接口在第三方的测试框架上进行测试呢? rest-assured框架是一个不错的工具. 使用之前,需要熟悉一下最基础的使用方法,在写完几个接口的测试用例之后,好比你可以使用你的三棱军刺熟练的进行基础的攻击了. 快速的来一个hello world吧! 假设你写了一个接口:lotto,访问路径是: http://localhost:8080

  • Java源码解析之超级接口Map

    前言 我们在前面说到的无论是链表还是数组,都有自己的优缺点,数组查询速度很快而插入很慢,链表在插入时表现优秀但查询无力.哈希表则整合了数组与链表的优点,能在插入和查找等方面都有不错的速度.我们之后要分析的HashMap就是基于哈希表实现的,不过在JDK1.8中还引入了红黑树,其性能进一步提升了. 今天我们来说一说超级接口Map. 一.接口Map Map是基于Key-Value的数据格式,并且key值不能重复,每个key对应的value值唯一.Map的key也可以为null,但不可重复. 在看Ma

  • Java源码解析之接口Collection

    一.图示 二.方法定义 我们先想一想,公司如果要我们自己去封装一些操作数组或者链表的工具类,我么需要封装哪些功能呢?不妨就是统计其 大小,增删改查.清空或者是查看否含有某条数据等等.而collection接口就是把这些通常操作提取出来,使其更全面.更通用,那现在我们就来看看其源码都有哪些方法. //返回集合的长度,如果长度大于Integer.MAX_VALUE,返回Integer.MAX_VALUE int size(); //如果集合元素总数为0,返回true boolean isEmpty(

  • java使用Feign实现声明式Restful风格调用

    一.Feign简介 Feign是netflix开发的声明式.模板化的http客户端,在使用时就像调用本地(服务消费者自己)的方法一般,帮助我们更加优雅的调用服务提供者的API.Feign自身支持springMVC,还整合了Eureka.Ribbon,极大的简化了Feign的使用.就整合Euraka而言,只需和普通的服务配置Eureka server的信息即可.整合Ribbon,就意味着不再需要通过标注@LoadBalanced的实例化后的RestTemplate去调用服务提供者方法了.Feign

随机推荐