Spring技术内幕之Restful(01)-Restful风格

2024-06-14 16:32

本文主要是介绍Spring技术内幕之Restful(01)-Restful风格,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Restful
REST概述:
一种软件架构风格,设计风格而不是标准,只是提供了一组设计原则和约束条件。它主要用于客户端和服务器交互类的软件。基于这个风格设计的软件可以更简洁,更有层次,更易于实现缓存等机制。


REST创始人:Roy Fielding博士在2000年他的博士论文中提出来的一种软件架构风格




REST使用程度:
目前在三种主流的Web服务实现方案中,因为REST模式的Web服务与复杂的SOAP和XML-RPC对比来讲明显的更加简洁,越来越多的web服务开始采用REST风格设计和实现。例如,Amazon.com提供接近REST风格的Web服务进行图书查找;雅虎提供的Web服务也是REST风格的


REST目的:
REST 从资源的角度来观察整个网络,分布在各处的资源由URL确定,而客户端的应用通过URL来获取资源的表征。获得这些表征使这些应用程序转变了其状态。随着不断获取资源的表征,客户端应用不断地在转变着其状态,所谓表述性状态转移(Representational State Transfer)。
这一观点不是凭空臆造的,而是通过观察当前Web互联网的运作方式而抽象出来的。
Roy Fielding 认为,
“设计良好的网络应用表现为一系列的网页,这些网页可以看作的虚拟的状态机,用户选择这些链接导致下一网页传输到用户端展现给使用的人,而这正代表了状态的转变”


Rest标准
需要注意的是,REST是设计风格而不是标准。REST通常基于使用HTTP,URL,和XML以及HTML这些现有的广泛流行的协议和标准。
1.资源是由URL来指定。
2.对资源的操作包括获取、创建、修改和删除资源,这些操作正好对应HTTP协议提供的GET、POST、PUT和DELETE方法。
3.通过操作资源的表现形式来操作资源。
4.资源的表现形式则是XML或者HTML,取决于读者是机器还是人,是消费web服务的客户软件还是web浏览器。当然也可以是任何其他的格式。


Rest的要求
1.客户端和服务器结构
2.连接协议具有无状态性
3.能够利用Cache机制增进性能
4.层次化的系统




REST状态
应该注意区别应用的状态和连接协议的状态。REST对于连接的无状态性实际上要求每次经过无状态的连接协议传送的信息必须包含应用中所有的状态信息。


RESTful Web 服务
RESTful Web 服务(也称为 RESTful Web API)是一个使用HTTP并遵循REST原则的Web服务。它从以下三个方面资源进行定义:
1.URL,比如:http://example.com/resources/。
2.Web服务接受与返回的互联网媒体类型,比如:JSON,XML ,YAML 等。
3.Web服务在该资源上所支持的一系列请求方法(比如:POST,GET,PUT或DELETE)。


Rest的优势
1.可以利用缓存Cache来提高响应速度
2.通讯本身的无状态性可以让不同的服务器的处理一系列请求中的不同请求,提高服务器的扩展性
3.浏览器即可作为客户端,简化软件需求
4.相对于其他叠加在HTTP协议之上的机制,REST的软件依赖性更小
5.不需要额外的资源发现机制
6.在软件技术演进中的长期的兼容性更好


Rest例子:
/user/1 HTTP GET =>  得到id = 1的user
/user/1 HTTP DELETE => 删除 id = 1的user
/user/1 HTTP PUT =>  更新id = 1的user
/user  HTTP POST =>  新增user

Spring 构建Rest的DEMO:

@Controller
@RequestMapping("/user")
public class SysUserController {//查看------>/user/1@RequestMapping(value = "/{id}", method = RequestMethod.GET)public @ResponseBody DemoUser view(@PathVariable String id){return demoUserService.findById(id);}//新增------>/user@RequestMapping(method = RequestMethod.POST)public @ResponseBody Message create(DemoUser demoUser){demoUser.setProcessState(ProcessBizEngineService.PROCESS_NEW_STATE);demoUserService.save(demoUser);return MessageUtil.message("demoUser.create.success");}//更新----->/user/1@RequestMapping(value = "/{id}", method = RequestMethod.PUT)public @ResponseBody Message create(@PathVariable String id, DemoUser demoUser){demoUser.setId(id);demoUserService.update(demoUser);return MessageUtil.message("demoUser.update.success");}//删除---->/user/1@RequestMapping(value = "/{id}", method = RequestMethod.DELETE)public @ResponseBody Message delete(@PathVariable String id){demoUserService.deleteById(id);return MessageUtil.message("demoUser.delete.success");}//批量删除---->/user/1@RequestMapping(method = RequestMethod.DELETE)public @ResponseBody Message batchDelete(@RequestParam("ids[]") String[] ids){demoUserService.deleteById(ids);return MessageUtil.message("demoUser.delete.success");}//查询全部数据@RequestMapping(value = "/all", method = RequestMethod.GET)public @ResponseBody List<DemoUser> getAll(){return demoUserService.findAll(new Sort(Direction.DESC, "createDate"));}}





这篇关于Spring技术内幕之Restful(01)-Restful风格的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1060927

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听

【专题】2024飞行汽车技术全景报告合集PDF分享(附原数据表)

原文链接: https://tecdat.cn/?p=37628 6月16日,小鹏汇天旅航者X2在北京大兴国际机场临空经济区完成首飞,这也是小鹏汇天的产品在京津冀地区进行的首次飞行。小鹏汇天方面还表示,公司准备量产,并计划今年四季度开启预售小鹏汇天分体式飞行汽车,探索分体式飞行汽车城际通勤。阅读原文,获取专题报告合集全文,解锁文末271份飞行汽车相关行业研究报告。 据悉,业内人士对飞行汽车行业