热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

初学SpringBootch06接口架构风格RESTful

ch06-接口架构风格RESTful1.1认识RESTful1.1.1RESTful架构风格1.2RESTful注解1.3RESTful风格的使用1.3.1加入Maven依赖1.3


ch06-接口架构风格 RESTful

  • 1.1 认识 RESTful
    • 1.1.1 RESTful架构风格
  • 1.2 RESTful 注解
  • 1.3 RESTful 风格的使用
    • 1.3.1 加入Maven依赖
    • 1.3.2 修改 application.properties 文件
    • 1.3.3 编写Controller
    • 1.3.4 查询测试
    • 1.3.5 添加测试
    • 1.3.6 修改测试
    • 1.3.7 删除测试
  • 1.4 RESTful 优点
  • 1.5 RESTful 总结
    • 1.5.1 请求路径冲突
    • 1.5.2 注意事项

接口: API(Application Programming Interface,应用程序接口)是一些预先定义的接口(如函数、HTTP接口),或指软件系统不同组成部分衔接的约定。 用来提供应用程序与开发人员基于某软件或硬件得以访问的一组例程,而又无需访问源码,或理解内部工作机制的细节。

接口(API): 可以指访问 servlet, controller 的 url, 调用其他程序的 函数

架构风格: api组织方式
就是一个传统的:

http://localhost:9002/mytrans/addStudent?name=lisi&age=26

在地址上提供了 访问的资源名称addStudent, 在其后使用了get方式传递参数。


1.1 认识 RESTful


1.1.1 RESTful架构风格

REST :(英文:Representational State Transfer , 中文:表现层状态转移)。
REST:是一种接口的架构风格和设计的理念,不是标准。
优点: 更简洁,更有层次

表现层状态转移: 表现层就是视图层, 显示资源的, 通过视图页面,jsp等等显示操作资源的结果。
状态: 资源变化
转移: 资源可以变化的。 资源能创建,new状态, 资源创建后可以查询资源, 能看到资源的内容,
这个资源内容 ,可以被修改, 修改后资源 和之前的不一样。


1.2 RESTful 注解

Spring Boot 开发 RESTful 主要是几个注解实现

@PathVariable:获取 url 中的数据。
该注解是实现 RESTful 最主要的一个注解

@GetMapping:接收 get 方式的请求,等同于 @RequestMapping( method=RequestMethod.GET)。

@PostMapping :接收和处理 Post 方式的请求,等同于 @RequestMapping( method=RequestMethod.POST)。

@PutMapping:接收 put 方式的请求,可以用 PostMapping 代替,等同于 @RequestMapping( method=RequestMethod.PUT)。

@DeleteMapping:接收 delete 方式的请求,可以使用 GetMapping 代替,等同于 @RequestMapping( method=RequestMethod.DELETE)。

@RestController: 符合注解, 是@Controller 和@ResponseBody组合。
在类的上面使用@RestController , 表示当前类者的所有方法都加入了 @ResponseBody


1.3 RESTful 风格的使用


1.3.1 加入Maven依赖

<dependencies><dependency><groupId>org.springframework.bootgroupId><artifactId>spring-boot-starter-webartifactId>dependency><dependency><groupId>org.springframework.bootgroupId><artifactId>spring-boot-starter-testartifactId><scope>testscope>dependency>dependencies>

1.3.2 修改 application.properties 文件

server.port&#61;9001
server.servlet.context-path&#61;/

1.3.3 编写Controller

package co.suyv.controller;import org.springframework.web.bind.annotation.*;&#64;RestController
public class MyRestController {/*** rest 中&#xff0c; url 要使用占位符&#xff0c;表示传递的数据。* 占位符叫做路径变量&#xff0c; 在 url 中的数据** 格式&#xff1a; 在&#64;RequestMapping 的 value 属性值中&#xff0c;使用 {自定义名称}* http://localhost:8080/myboot/student/1001/bj2009** &#64;PathVariable: 路径变量注解&#xff0c;作用是获取 url 中的路径变量的值* 属性&#xff1a; value &#xff1a; 路径变量名称* 位置&#xff1a; 在逐个接收参数中&#xff0c;在形参定义的前面** 注意&#xff1a;路径变量名和形参名一样&#xff0c; value 可以不写**/// 查询id&#61;1001的学生&#64;GetMapping("/student/{studentId}")public String queryStudent(&#64;PathVariable(value &#61; "studentId") Integer id){return "查询学生 studentId&#xff1a;" &#43; id;}// 增加学生&#64;PostMapping("/student/{name}/{age}")public String creatStudent(&#64;PathVariable("name") String name,&#64;PathVariable("age") Integer age){return "创建student&#xff1a;姓名&#xff1a;"&#43; name &#43; ",年龄&#xff1a;" &#43;age;}// 修改学生&#64;PutMapping("/student/{id}/{age}")public String modifyStudent(&#64;PathVariable Integer id,&#64;PathVariable Integer age){return "修改student&#xff1a;id&#61;"&#43; "id" &#43; ",age&#61;" &#43; age;}// 删除学生&#64;DeleteMapping("/student/{id}")public String removeStudentById(&#64;PathVariable Integer id){return "删除student&#xff1a;id&#61;" &#43; id;}
}

1.3.4 查询测试

在这里插入图片描述


1.3.5 添加测试

在这里插入图片描述


1.3.6 修改测试

在这里插入图片描述


1.3.7 删除测试

在这里插入图片描述


1.4 RESTful 优点


1.轻量&#xff0c;直接基于 http&#xff0c;不再需要任何别的诸如消息协议&#xff1a;get/post/put/delete 为 CRUD 操作
2.面向资源&#xff0c;一目了然&#xff0c;具有自解释性。
3.数据描述简单&#xff0c;一般以 xml&#xff0c;json 做数据交换。
4.无状态&#xff0c;在调用一个接口&#xff08;访问、操作资源&#xff09;的时候&#xff0c;可以不用考虑上下文&#xff0c;不用考虑当前状态&#xff0c;极大的降低了复杂度。
5. 简单、低耦合



1.5 RESTful 总结


1.5.1 请求路径冲突

&#64;GetMapping(value &#61; "/student/{studentId}/{classname}")
&#64;GetMapping(value &#61; "/student/{studentId}/{schoolname}")

这样的路径访问会失败&#xff0c; 路径有冲突。


解决&#xff1a;设计路径&#xff0c;必须唯一&#xff0c; 路径 uri 和 请求方式必须唯一。



1.5.2 注意事项


1.增 post 请求、删 delete 请求、改 put 请求、查 get 请求



2.请求路径不要出现动词 例如&#xff1a;查询订单接口
/boot/order/1021/1&#xff08;推荐&#xff09;
/boot/queryOrder/1021/1&#xff08;不推荐&#xff09;



3.分页、排序等操作&#xff0c;不需要使用斜杠传参数 例如&#xff1a;订单列表接口
/boot/orders?page&#61;1&sort&#61;desc 一般传的参数不是数据库表的字段&#xff0c;可以不采用斜杠



推荐阅读
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • http:my.oschina.netleejun2005blog136820刚看到群里又有同学在说HTTP协议下的Get请求参数长度是有大小限制的,最大不能超过XX ... [详细]
  • Skywalking系列博客1安装单机版 Skywalking的快速安装方法
    本文介绍了如何快速安装单机版的Skywalking,包括下载、环境需求和端口检查等步骤。同时提供了百度盘下载地址和查询端口是否被占用的命令。 ... [详细]
  • 搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的详细步骤
    本文详细介绍了搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的步骤,包括环境说明、相关软件下载的地址以及所需的插件下载地址。 ... [详细]
  • ZSI.generate.Wsdl2PythonError: unsupported local simpleType restriction ... [详细]
  • 本文介绍了在使用Python中的aiohttp模块模拟服务器时出现的连接失败问题,并提供了相应的解决方法。文章中详细说明了出错的代码以及相关的软件版本和环境信息,同时也提到了相关的警告信息和函数的替代方案。通过阅读本文,读者可以了解到如何解决Python连接服务器失败的问题,并对aiohttp模块有更深入的了解。 ... [详细]
  • springmvc学习笔记(十):控制器业务方法中通过注解实现封装Javabean接收表单提交的数据
    本文介绍了在springmvc学习笔记系列的第十篇中,控制器的业务方法中如何通过注解实现封装Javabean来接收表单提交的数据。同时还讨论了当有多个注册表单且字段完全相同时,如何将其交给同一个控制器处理。 ... [详细]
  • 本文介绍了南邮ctf-web的writeup,包括签到题和md5 collision。在CTF比赛和渗透测试中,可以通过查看源代码、代码注释、页面隐藏元素、超链接和HTTP响应头部来寻找flag或提示信息。利用PHP弱类型,可以发现md5('QNKCDZO')='0e830400451993494058024219903391'和md5('240610708')='0e462097431906509019562988736854'。 ... [详细]
  • 解决nginx启动报错epoll_wait() reported that client prematurely closed connection的方法
    本文介绍了解决nginx启动报错epoll_wait() reported that client prematurely closed connection的方法,包括检查location配置是否正确、pass_proxy是否需要加“/”等。同时,还介绍了修改nginx的error.log日志级别为debug,以便查看详细日志信息。 ... [详细]
  • Spring常用注解(绝对经典),全靠这份Java知识点PDF大全
    本文介绍了Spring常用注解和注入bean的注解,包括@Bean、@Autowired、@Inject等,同时提供了一个Java知识点PDF大全的资源链接。其中详细介绍了ColorFactoryBean的使用,以及@Autowired和@Inject的区别和用法。此外,还提到了@Required属性的配置和使用。 ... [详细]
  • 本文介绍了使用AJAX的POST请求实现数据修改功能的方法。通过ajax-post技术,可以实现在输入某个id后,通过ajax技术调用post.jsp修改具有该id记录的姓名的值。文章还提到了AJAX的概念和作用,以及使用async参数和open()方法的注意事项。同时强调了不推荐使用async=false的情况,并解释了JavaScript等待服务器响应的机制。 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • 网络请求模块选择——axios框架的基本使用和封装
    本文介绍了选择网络请求模块axios的原因,以及axios框架的基本使用和封装方法。包括发送并发请求的演示,全局配置的设置,创建axios实例的方法,拦截器的使用,以及如何封装和请求响应劫持等内容。 ... [详细]
author-avatar
手机用户2502874905
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有