前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >RestFul风格详解

RestFul风格详解

作者头像
全栈程序员站长
发布2022-07-04 08:41:48
7130
发布2022-07-04 08:41:48
举报
文章被收录于专栏:全栈程序员必看

大家好,又见面了,我是你们的朋友全栈君。

文章目录

一、前言

该技术博客总结与狂神说SpringMVC课程

二、什么是RestFul风格

Restful就是一个资源定位、资源操作的风格。不是标准也不是协议,只是一种风格。基于这个风格设计的软件可以更简洁,更有层次,更易于实现缓存等机制。

资源:互联网所有的事物都可以被抽象为资源 资源操作:分为POST、DELETE、PUT、GET四种方法,使用不同方法对资源进行操作(增、删、改、查)

在这里插入图片描述
在这里插入图片描述

三、传统风格与RestFul风格对比

1. 传统方式操作资源

通过不同的参数来实现不同的效果!方法单一!

http://127.0.0.1/item/queryItem.action?id=1 (查询,GET) http://127.0.0.1/item/saveItem.action (新增,POST) http://127.0.0.1/item/updateItem.action (更新,POST) http://127.0.0.1/item/deleteItem.action?id=1 (删除,GET或POST)

2. RestFul方式操作资源

可以通过不同的请求方式来实现不同的效果! 如下:请求地址一样,但是功能可以不同!

http://127.0.0.1/item/1 (查询,GET) http://127.0.0.1/item (新增,POST) http://127.0.0.1/item (更新,PUT) http://127.0.0.1/item/1 (删除,DELETE)

四、RestFul代码演示

1.代码展示

在进行代码演示之前,需要配置好环境!

首先导入依赖:

代码语言:javascript
复制
<!--springmvc注解-->
<dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-webmvc</artifactId>
    <version>5.1.9.RELEASE</version>
</dependency>

接着创建springmvc.xml配置文件:

代码语言:javascript
复制
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xmlns:mvc="http://www.springframework.org/schema/mvc" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context https://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/mvc https://www.springframework.org/schema/mvc/spring-mvc.xsd">


    <!-- 自动扫描指定的包,下面所有注解类交给IOC容器管理 -->
    <context:component-scan base-package="com.xu.controller"/>
    <!--处理器映射器 + 处理器适配器注入-->
    <mvc:annotation-driven />

    <!--视图解析器-->
    <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <property name="prefix" value="/WEB-INF/jsp/"/>
        <property name="suffix" value=".jsp"/>
    </bean>
</beans>

接着配置web.xml文件:

代码语言:javascript
复制
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd" version="4.0">

    <!--注册DispatcherServlet-->
    <servlet>
        <servlet-name>DispatcherServlet</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
        <!--关联一个springmvc配置文件:springmvc.xml-->
        <init-param>
            <param-name>contextConfigLocation</param-name>
            <param-value>classpath:springmvc.xml</param-value>
        </init-param>
        <!--启动级别:1-->
        <load-on-startup>1</load-on-startup>
    </servlet>
    <servlet-mapping>
        <servlet-name>DispatcherServlet</servlet-name>
        <url-pattern>/</url-pattern>
    </servlet-mapping>
</web-app>

然后在WEB-INF下创建jsp/test.jsp文件,用于接收值:

代码语言:javascript
复制
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Test</title>
</head>
<body>
${msg}
</body>
</html>

最后创建RestFulController类:

代码语言:javascript
复制
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.servlet.ModelAndView;

@Controller
public class RestFulController { 
   
    //映射访问路径
    @RequestMapping("/commit/{p1}/{p2}")
    //在SpringMVC中可以使用 @PathVariable,让方法参数的值对应绑定到一个URI模板变量上
    public ModelAndView index(@PathVariable int p1, @PathVariable int p2, ModelAndView mv){ 
   
        int result = p1 + p2;
        //实例化一个ModelAndView对象用于向视图中传值
        mv.addObject("msg","结果:" + result);
        //返回视图
        mv.setViewName("test");
        return mv;
    }
}

搭建好Tomcat服务器并运行,输入请求进行测试:

在这里插入图片描述
在这里插入图片描述

2.拓展情景

通过路径变量的类型可以约束访问参数,如果类型不一样,则访问不到对应的请求方法,如果这里访问是的路径是 /commit/1/a,则路径与方法不匹配,而不会是参数转换失败。

在这里插入图片描述
在这里插入图片描述

解决方式:将RestFulController类中方法第二个参数类型改成String

五、使用method属性指定请求类型

用于约束请求的类型,可以收窄请求范围。 指定请求谓词的类型如:GET, POST, HEAD, OPTIONS, PUT, PATCH, DELETE, TRACE等

代码展示:

代码语言:javascript
复制
//在RestFulController类中增加一个方法
//映射访问路径,必须是POST请求
@RequestMapping(value = "/hello",method = { 
   RequestMethod.POST})
public String index2(Model model){ 
   
   model.addAttribute("msg", "hello!");
   return "test";
}

发送请求后,显示如下结果:

在这里插入图片描述
在这里插入图片描述

原因:我们使用浏览器地址栏进行访问默认是Get请求,会报错405!

解决方式:将POST修改为GET就正常了

代码语言:javascript
复制
//映射访问路径,必须是Get请求
@RequestMapping(value = "/hello",method = { 
   RequestMethod.GET})
//我们一般采用这种方式:@GetMapping("/hello")
public String index2(Model model){ 
   
   model.addAttribute("msg", "hello!");
   return "test";
}

成功显示!

在这里插入图片描述
在这里插入图片描述

六、总结

所有的地址栏请求默认都会是GET类型的。

针对章节五的问题,我们也可以通过组合注解来解决:

代码语言:javascript
复制
@GetMapping:扮演的是@RequestMapping(method =RequestMethod.GET) 的快捷方式。
@PostMapping
@PutMapping
@DeleteMapping
@PatchMapping

项目结构:

在这里插入图片描述
在这里插入图片描述

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/148647.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 文章目录
  • 一、前言
  • 二、什么是RestFul风格
  • 三、传统风格与RestFul风格对比
    • 1. 传统方式操作资源
      • 2. RestFul方式操作资源
      • 四、RestFul代码演示
        • 1.代码展示
          • 2.拓展情景
          • 五、使用method属性指定请求类型
          • 六、总结
          相关产品与服务
          容器服务
          腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档