“REST” 代表 “Representational State Transfer”,是一种架构风格和通信协议,通常用于构建分布式网络应用和服务。RESTful 风格的架构强调了资源的概念,资源可以用唯一的标识符(通常是URL)来访问,而对资源的操作则通过标准的HTTP方法(如GET、POST、PUT、DELETE等)来完成。
以下是 REST 架构风格的关键特点:
资源(Resources):在 REST 中,所有的数据都被视为资源,每个资源都有一个唯一的标识符(通常是URL)。资源可以是实际的数据对象、文档、服务等。
HTTP 方法:RESTful 服务使用标准的 HTTP 方法来对资源执行操作。常用的 HTTP 方法包括 GET(获取资源)、POST(创建资源)、PUT(更新资源)、DELETE(删除资源)等。
状态无关性(Stateless):每个请求都应该包含足够的信息以便服务器理解,而服务器不应该依赖于之前的请求来处理当前请求。这使得服务可以水平扩展,因为每个请求都是独立的。
表示(Representation):资源的状态可以通过多种表示形式来表示,例如 JSON、XML、HTML 等。客户端可以根据需要选择合适的表示形式。
无状态通信:通信是无状态的,每个请求都包含了所有必要的信息,服务器不需要维护客户端的会话状态。
统一接口(Uniform Interface):RESTful 服务的接口应该是简单和统一的,以便客户端容易理解和使用。
RESTful 架构常用于构建 Web API,以便不同应用程序和服务之间进行通信。它的设计原则使得系统具有可伸缩性、可维护性和松耦合性,并且易于理解和使用。许多互联网服务,如社交媒体平台的API、移动应用的后端服务等,都采用了 RESTful 架构。
一般我们在使用Rest风格的controller的时候如果是在url中的参数,在写函数的时候直接写了和url中参数名一样,那么spring就会直接帮你进行对应配对注入值,但有时候这样子直接用的话不一定会注入成功,这个时候我们有必要了解spring处理这些的问题的注解,来解决问题;
这里只有一些简单的注解使用,对于平时的开发是完全够用的。
@RequestBody:
用途:用于接收请求体中的JSON或表单数据,并将其映射到Java对象。通常用于处理POST请求等需要传递数据体的请求。
示例:
@RestController
public class UserController {
@PostMapping("/create-user")
public ResponseEntity<String> createUser(@RequestBody User user) {
// 处理用户创建逻辑
return ResponseEntity.ok("User created: " + user.getUsername());
}
}
在上述示例中,@RequestBody
用于接收JSON或表单数据,并将其映射到名为user
的User
对象中。
@PathVariable:
用途:用于从URL路径中提取变量值,通常用于RESTful风格的URL。
示例:
@RestController
public class ProductController {
@GetMapping("/products/{productId}")
public ResponseEntity<String> getProductDetails(@PathVariable Long productId) {
// 使用productId获取产品详情
return ResponseEntity.ok("Product ID: " + productId);
}
}
在上述示例中,@PathVariable
用于提取URL路径中的productId
变量值。访问路径如:/products/123
。
@RequestParam:
用途:用于获取URL查询参数。
示例:
@RestController
public class SearchController {
@GetMapping("/search")
public ResponseEntity<String> search(@RequestParam String query) {
// 使用查询参数执行搜索
return ResponseEntity.ok("Search Query: " + query);
}
}
在上述示例中,@RequestParam
用于获取名为query
的查询参数值。访问路径如:/search?query=example
。
@RequestHeader:
用途:用于获取HTTP请求头信息。
示例:
@RestController
public class HeaderController {
@GetMapping("/user-agent")
public ResponseEntity<String> getUserAgent(@RequestHeader("User-Agent") String userAgent) {
// 获取User-Agent头信息
return ResponseEntity.ok("User-Agent: " + userAgent);
}
}
在上述示例中,@RequestHeader
用于获取User-Agent
头信息的值。
@CookieValue:
用途:用于获取Cookie的值。
示例:
@RestController
public class CookieController {
@GetMapping("/get-cookie")
public ResponseEntity<String> getCookieValue(@CookieValue("myCookie") String cookieValue) {
// 获取名为myCookie的Cookie的值
return ResponseEntity.ok("Cookie Value: " + cookieValue);
}
}
在上述示例中,@CookieValue
用于获取名为myCookie
的Cookie的值。