目录

一、Postman 工具使用

1.1 Postman安装

1.2 Postman的使用

1.2.1 创建WorkSpace工作空间

1.2.2 创建请求

二、参数传递

2.1 添加 Slf4j 依赖

2.2 普通传参

知识点1:@RequestMapping

知识点2:@RequestParam

2.3 路径传参

知识点3:@PathVariable

2.4 Json数据传参

 知识点4:@RequestBody

三、响应

3.1 响应Json数据

3.2 跳转页面响应数据

3.3 ModelAndView 响应

四、页面跳转

4.1 转发(地址栏不变)

4.2 重定向(地址栏改变)

4.3 跳其它的controller

一、Postman 工具使用

在这之前先了解一下Postman工具,Postman是一款流行的API开发和测试工具,它提供了一个用户友好的界面,用于发送HTTP请求并查看响应。它可以帮助开发人员在开发和测试API时更加高效和方便。

我们在编写web程序的时候需要频繁的进行数据测试,发送的是GET请求可以直接使用浏览器,如果要求发送的是post请求,我们就得准备页面在页面上准备form表单,测试起来比较麻烦。所以我们就需要借助一些第三方工具,如Postman、Eolink...

1.1 Postman安装

Postman官方下载地址 https://www.postman.com/downloads/

双击自动安装,首次进入需要我们注册登入也可以选择跳过,如需要测试还得要登入一手。可以点可以按照提示进行注册,如下界面是我登入后的主界面。

1.2 Postman的使用

1.2.1 创建WorkSpace工作空间

创建新的工作空间并设置工作空间的名字:

1.2.2 创建请求

选择刚创建的工作空间并添加一个请求:

注意: 第一次请求需要创建一个新的目录,后面就不需要创建新目录,直接保存到已经创建好的目录即可。

二、参数传递

上一篇我们已经完成了入门案例相关的知识学习,我们知道SpringMVC是web层的框架,主要的作用是接收请求、接收数据、响应结果,所以这一章节是学习SpringMVC的重点内容。

2.1 添加 Slf4j 依赖

<log4j2.version>2.9.1</log4j2.version>
<log4j2.disruptor.version>3.2.0</log4j2.disruptor.version>
<slf4j.version>1.7.13</slf4j.version>

<!--4.log日志相关依赖-->

<!-- log4j2日志相关依赖 -->
<!-- log配置:Log4j2 + Slf4j -->
<!-- slf4j核心包-->
<dependency>
	<groupId>org.slf4j</groupId>
	<artifactId>slf4j-api</artifactId>
	<version>${slf4j.version}</version>
</dependency>
<dependency>
	<groupId>org.slf4j</groupId>
	<artifactId>jcl-over-slf4j</artifactId>
	<version>${slf4j.version}</version>
	<scope>runtime</scope>
</dependency>

<!--核心log4j2jar包-->
<dependency>
	<groupId>org.apache.logging.log4j</groupId>
	<artifactId>log4j-api</artifactId>
	<version>${log4j2.version}</version>
</dependency>
<dependency>
	<groupId>org.apache.logging.log4j</groupId>
	<artifactId>log4j-core</artifactId>
	<version>${log4j2.version}</version>
</dependency>
<!--用于与slf4j保持桥接-->
<dependency>
	<groupId>org.apache.logging.log4j</groupId>
	<artifactId>log4j-slf4j-impl</artifactId>
	<version>${log4j2.version}</version>
</dependency>
<!--web工程需要包含log4j-web,非web工程不需要-->
<dependency>
	<groupId>org.apache.logging.log4j</groupId>
	<artifactId>log4j-web</artifactId>
	<version>${log4j2.version}</version>
	<scope>runtime</scope>
</dependency>

<!--需要使用log4j2的AsyncLogger需要包含disruptor-->
<dependency>
	<groupId>com.lmax</groupId>
	<artifactId>disruptor</artifactId>
	<version>${log4j2.disruptor.version}</version>
</dependency>

在上篇文章的pom.xml配置文件中换掉log4j的依赖,在实际开发中通常会使用日志文件将数据信息进行保存。而 Slf4j(Simple Logging Facade for Java)是一个简单的Java日志门面框架,它提供了一种通用的日志接口,使开发人员能够在应用程序中使用不同的日志实现,而无需修改代码。Slf4j的目标是为Java应用程序提供一种简单、灵活和可扩展的日志解决方案。

2.2 普通传参

编写paramController类

package com.ycxw.web;

import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

/**
 * @author 云村小威
 * @site blog.csdn.net/Justw320
 * @create 2023-09-05 16:34
 */
@Slf4j
@Controller
@RequestMapping("/param")
public class ParamController {
    
    @RequestMapping("/hello1")
    public String toHello1(Integer bid,String bname){
        log.info("基础类型+String传参:bid:{},bname:{}",bid,bname);
        return "index";
    }
}

知识点1:@RequestMapping

@RequestMapping注解是一个用来处理请求地址映射的注解,可用于映射一个请求或一个方法,可以用在类或方法上。

  • @Slf4j注解表示该类使用Slf4j日志框架进行日志记录。
  • @Controller注解表示这是一个控制器类,用于处理HTTP请求。该类的请求映射路径为"/param"。
  • 在该类中,定义了一个名为ParamController的控制器类。它包含了一个名为toHello1的方法,该方法使用@RequestMapping注解来指定处理的URL路径为"/hello1"。该方法接受两个参数,一个是基本类型的整数bid,另一个是字符串类型的bname。
  • 在方法体内,使用log.info方法记录了一条日志信息。这条日志信息包含了两个参数bid和bname的值,使用{}占位符来表示参数的位置。
  • 最后,该方法返回了一个字符串"index",表示要渲染的视图名称。

  • 普通参数:url地址传参,地址参数名与形参变量名相同,定义形参即可接收参数。

打印结果:

注意:如果形参与地址参数名不一致会导致接收数据失败:

解决方案: 使用@RequestParam注解

知识点2:@RequestParam

@RequestParam主要用于将请求参数区域的数据映射到控制层方法的参数上

参数说明
value请求中传入参数的名称,如果不设置后台接口的value值,则会默认为该变量名。
required该参数是否为必传项。默认是true,表示请求中一定要传入对应的参数,否则会报404错误,如果设置为false时,当请求中没有此参数,将会默认为null,而对于基本数据类型的变量,则必须有值,这时会抛出空指针异常。如果允许空值,则接口中变量需要使用包装类来声明。
defaultValue参数的默认值,如果请求中没有同名的参数时,该变量默认为此值。注意默认值可以使用SpEL表达式,如"#{systemProperties[‘java.vm.version’]}"
    @RequestMapping("/hello2")
    public String toHello2(@RequestParam(required = false) Integer bid,
                           @RequestParam(value = "bhahaha") String bname) {
        log.info("基础类型+String传参:bid:{},bname:{}", bid, bname);
        return "index";
    }

这时利用@RequestParam注解设置前台传参名字,就可以用bhahaha传值成功。

2.3 路径传参

知识点3:@PathVariable

如果我要通过id进行删除某一项可以用PathVariable注释,示例:

    @RequestMapping("/hello3/{bid}")
    public String toHello3(@PathVariable("bid") Integer bid) {
        log.info("使用@PathVariable注解传递参数:{}", bid);
        return "index";
    }

运行结果:

2.4 Json数据传参

在实际开发中运用最多的就是通过Json数据进行传输,在本篇就没有演示对象、数组、以及集合传输,其传输方式与上普通传参略微有异。

SpringMVC默认使用的是jackson来处理json的转换,所以需要在pom.xml添加jackson依赖

 <jackson.version>2.9.3</jackson.version>
 
 <dependency>
      <groupId>com.fasterxml.jackson.core</groupId>
      <artifactId>jackson-databind</artifactId>
      <version>${jackson.version}</version>
    </dependency>
    <dependency>
      <groupId>com.fasterxml.jackson.core</groupId>
      <artifactId>jackson-core</artifactId>
      <version>${jackson.version}</version>
    </dependency>
    <dependency>
      <groupId>com.fasterxml.jackson.core</groupId>
      <artifactId>jackson-annotations</artifactId>
      <version>${jackson.version}</version>
    </dependency>

知识点4:@RequestBody

 @RequestBody 注解用于将HTTP请求的请求体内容绑定到方法的参数上。它告诉Spring MVC框架将请求体的内容转换为指定的参数类型,并将其传递给方法进行处理。

使用@RequestBody注解的参数可以是任何Java对象类型,包括自定义的POJO(Plain Old Java Object)类。Spring MVC会自动根据请求体的内容类型,使用适当的转换器将请求体的内容转换为指定的参数类型。

  • json对象({key1:value1,key2:value2,…})

请求和数据的发送:

{
    "bid": 1,
    "bname": "斗破苍穹",
    "price": 9.9
}

后端接收数据:

    @RequestMapping("/hello5")
    @ResponseBody
    public String toHello5(@RequestBody Book book) {
        System.out.println(book);
        return "index";
    }

  • json对象数组([{key1:value1,…},{key2:value2,…}])

 请求和数据的发送:

[{
    "bid": 1,
    "bname": "斗破苍穹",
    "price": 9.9
},
{
    "bid": 2,
    "bname": "斗破苍穹",
    "price": 10.9
}
]

后端接收数据:

    @RequestMapping("/hello6")
    @ResponseBody
    public String toHello6(@RequestBody List<Book> books) {
        System.out.println(books);
        return "index";
    }

@RequestBody与@RequestParam区别

区别:

  • @RequestParam用于接收url地址传参,表单传参【application/x-www-form-urlencoded】
  • @RequestBody用于接收json数据【application/json】

应用:

  • 后期开发中,发送json格式数据为主,@RequestBody应用较广
  • 如果发送非json格式数据,选用@RequestParam接收请求参数

三、响应

3.1 响应Json数据

1. 创建控制器:ReturnController类

package com.ycxw.web;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

/**
 * @author 云村小威
 * @site blog.csdn.net/Justw320
 * @create 2023-09-06 22:18
 */
@Controller
@RequestMapping("/rs")
public class ReturnController {

}

2. 编写响应数据

    @ResponseBody //响应Json数据
    @RequestMapping("/return1")
    public Map<String, Object> return1(HttpServletResponse response){
        Map<String,Object> maps = new HashMap<>();
        maps.put("code",200);
        maps.put("msg","响应成功");
        return maps;
    }

3. 测试:

3.2 跳转页面响应数据

1. 编写响应的jsp

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Title</title>
</head>
<body>
昵称:${name}
又爱又恨:${hobby}
</body>
</html>

2. 编写响应的数据

    @RequestMapping("/return2")
    public String return2(Model model, HttpServletRequest request){
        //填充模型数据
        model.addAttribute("name","云村小威");
        request.setAttribute("hobby","编程");
        //逻辑视图名
        return "index";
    }

3. 测试:

3.3 ModelAndView 响应

  1. ModelAndView是一个在Java Spring框架中使用的类,用于将数据模型和视图信息一起传递给前端页面。它是一种将数据和视图结合在一起的方式,方便开发人员在后端控制器中处理数据并将其传递给前端页面进行展示。
  2. 在ModelAndView中,"Model"表示数据模型,它是一个存储数据的对象,可以在后端控制器中设置数据,并将其传递给前端页面。开发人员可以使用键值对的方式将数据存储在模型中,然后在前端页面中使用这些数据进行展示或处理。
  3. 而"View"表示视图,它是前端页面的表示。在ModelAndView中,开发人员可以设置要展示的视图的名称或路径,以便在请求处理完成后,将数据模型传递给相应的视图进行渲染和展示。
  4. 通过使用ModelAndView,开发人员可以将数据和视图信息封装在一起,方便地传递给前端页面,实现数据的动态展示和交互。这种方式使得后端控制器和前端页面之间的数据传递更加灵活和方便。
    @RequestMapping("/return3")
    public ModelAndView return3(){
        ModelAndView mv = new ModelAndView();
        //填充模型数据
        mv.addObject("name","云村小威");
        mv.addObject("hobby","编程");
        //逻辑视图名
        mv.setViewName("index");
       
        return mv;
    }

测试:

四、页面跳转

转发(forward:path)和重定向(redirect:path)这两种跳转方式将会绕开视图解析器的前缀后缀;还有就是如果是在同一controller中则不用使用"/"从根目录开始,而如果是在不同的controller则一定要从根目录开始。

4.1 转发(地址栏不变)

    @RequestMapping("/helloPage1")
    public String toHelloPage1(){
        System.out.println("helloPage1...");
        return "forward:return1";
    }

它相当于“request.getRequestDispatcher("url").forward(request,response)”。使用转发,既可以转发到jsp, 也可以转发到其他的控制器方法。

4.2 重定向(地址栏改变)

    @RequestMapping("/helloPage2")
    public String toHelloPage2(){
        System.out.println("helloPage2...");
        return "redirect:return1";
    }

它相当于“response.sendRedirect(url)”, 也可以转发到其他的控制器方法。

4.3 跳其它的controller

    /*转发*/
    @RequestMapping("/helloPage3")
    public String toHelloPage3(){
        System.out.println("helloPage3...");
        return "forward:/param/hello1";
    }
    
    /*重定向*/
    @RequestMapping("/helloPage4")
    public String toHelloPage4(){
        System.out.println("helloPage4...");
        return "redirect:/param/hello1";
    }

测试重定向:redirect:/param/hello1

如果是在同一controller中则不用使用 "/" 从根目录开始,而如果是在不同的controller则一定要从根目录开始。

相关文章

【Vue3】使用ref与reactive创建响应式对象

先来简单介绍一下ref,它可以定义响应式的变量let xxx = ref(初始值)。**返回值:**一个RefImpl的实例对象,简称ref对象或refref对象的value属性是响应式的。JSxxx.value,但模板中不需要.value,直接使用即可。对于let name = ref('张三')来说,name不是响应式的,name.value是响应式的。下面我们看一看上图红框中代表的意思是,我们哪里需要响应就在哪个里面导入上述代码即可。

如何设置页面恢复运行事件触发回调

由于 Android 原生的 resume 和 pause 事件不能区分是压后台导致还是页面切换导致,所以 pageResume 和 pagePause 事件是通过 JSAPI 调用记录回调的,仅适用于同一个 session 内 Window 之间的互相切换。当一个 WebView 界面重新回到栈顶时,例如从后台被唤起、锁屏界面恢复、从下个页面回退,会触发页面恢复运行(resume)事件。如果这个界面是通过 popWindow 或 popTo 到达,且传递了 data 参数,则此页可以获取到这些参数。

日常遇到Maven出现依赖版本/缓存问题通用思路。

如果怀疑是本地仓库中缓存的依赖有问题,可以手动删除本地仓库(默认位置在用户的.m2/repository目录下),但这是一个较为极端的做法,因为这会删除所有项目的所有本地依赖,之后Maven将不得不重新下载这些依赖。针对于这样的问题 首先我们的第一思路 就是怀疑到是缓存的问题,那么我在这里去描述一下 我们遇到这类通用类的问题如何解决。检查项目的pom.xml文件,确认依赖声明正确无误,没有冲突的版本号或不正确的依赖范围。版本问题导致的,但是我确认过了一下的一些操作 依然没有解决我的问题。

什么是tomcat?tomcat是干什么用的?

Tomcat是一个开源的、轻量级的应用服务器,是Apache软件基金会的一个项目。它实现了Java Servlet、JavaServer Pages(JSP)和Java Expression Language(EL)等Java技术,用于支持在Java平台上运行的动态Web应用程序。AJP是用于Apache服务器与Tomcat之间进行通信的协议,通常用于将动态生成的内容传递给Apache服务器进行处理。它能够运行Servlet和JSP,提供了一个环境,使得开发者能够构建和运行基于Java的Web应用。

C# winfrom中excel文件导入导出

在C#交流群里,看到很多小伙伴在excel数据导入导出到C#界面上存在疑惑,所以今天专门做了这个主题,希望大家有所收获!环境:win10+vs2017界面:主要以演示为主,所以没有做优化,然后主界面上添加两个按钮,分别命名为ExportExcel和ImportExcel,添加两个dataGridView,分别是dataGridView1和dataGridView2然后在窗体加载程序中给dataGr...

Java 与 JavaScript 的区别与联系

Java 和 JavaScript 两种编程语言在软件开发中扮演着重要的角色。尽管它们都以“Java”命名,但实际上它们是完全不同的语言,各有其独特的特点和用途。本文将深入探讨 Java 和 JavaScript 的区别与联系,帮助大家更好地理解它们在编程世界中的作用。

C语言中的作用域与生命周期

但是全局变量被 static 修饰之后,外部链接属性就变成了内部链接属性,只能在自己所在的源文件内部使用了,其他源文件,即使声明了,也是无法正常使用的。结论:static修饰局部变量改变了变量的生命周期,生命周期改变的本质是改变了变量的存储类型,本来一个局部变量是存储在内存的栈区的,但是被 static 修饰后存储到了静态区。extern 是用来声明外部符号的,如果一个全局的符号在A文件中定义的,在B文件中想使用,就可以使用extern进行声明,然后使用。全局变量的生命周期是:整个程序的生命周期。

Python和Java的区别(不断更新)

运行效率:一般来说,Java的运行效率要高于Python,这主要是因为Java是编译型语言,其代码在执行前会进行预编译,而Python是解释型语言,边解释边执行。而Python没有类似的强大虚拟机,但它的核心是可以很方便地使用C语言函数或C++库,这使得Python可以轻松地与底层硬件进行交互。**类型系统:**Java是一种静态类型语言,所有变量需要先声明(类型)才能使用,且类型在编译时就已经确定。总的来说,Python和Java各有其优势和特点,选择哪种语言取决于具体的项目需求、开发环境以及个人偏好。

服务器与电脑的区别?

服务器是指一种专门提供计算和存储资源、运行特定软件服务的物理或虚拟计算机。服务器主要用于接受和处理来自客户端(如个人电脑、手机等)的请求,并向客户端提供所需的服务或数据。服务器在网络环境中扮演着中心节点的角色,负责存储和管理数据、提供网络服务、处理计算任务等。

windows下ngnix自启动(借助工具winSw)

在windows下安装nginx后,不想每次都手动启动。本文记录下windows下ngnix自启动(借助工具winSw)的操作流程提示:以下是本篇文章正文内容,下面案例可供参考本文记录下windows下ngnix自启动(借助工具winSw)的操作流程。

synchronized 和 Lock 有什么区别?synchronized 和 ReentrantLock 区别是什么?说一下 atomic 的原理?

例如,AtomicInteger 的 incrementAndGet() 方法就是通过 CAS 操作实现的,它首先尝试原子地将共享变量加 1,如果操作成功,则返回新的值,否则重试直到操作成功为止。CAS 操作的原理是,当 V 的值等于 A 时,将 V 的值更新为 B,否则什么也不做。synchronized 和 Lock 都是 Java 中用于实现线程同步的关键字/类库,它们都能够提供对共享资源的安全访问和防止数据竞争的功能,但是在实现方式、特性、适用场景等方面存在一些差异。

SpringBoot security 安全认证(二)——登录拦截器

本节内容:实现登录拦截器,除了登录接口之外所有接口访问都要携带Token,并且对Token合法性进行验证,实现登录状态的保持。核心内容:1、要实现登录拦截器,从Request请求中获取token,从缓存中获取Token并验证登录是否过期,若验证通过则放行;2、实现对拦截器配置,SpringBoot 安全模块使用HttpSecurity 来完成请求安全管理。

MySQL 处理JSON字符串

现在很多数据会以json格式存储,如果你还在用like查询json字符串,那你就OUT了, MySQL从5.6版本就开始支持json字符串查询了~下面来看看MySQL中支持的json处理函数吧!MySQL支持定义的原生JSON数据类型 由RFC 7159支持高效访问JSON数据 (JavaScript Object Notation)文档。的JSON数据类型提供了这些优势, 在字符串列中存储JSON格式的字符串:自动验证存储在JSON列。无效的文档将生成 错误.优化存储格式。JSON文档存储在。

Kafka常见生产问题详解

比如,在原有Topic下,可以调整Producer的分区策略,让Producer将后续的消息更多的发送到新增的Partition里,这样可以让各个Partition上的消息能够趋于平衡。思路是可行的,但是重试的次数,发送消息的数量等都是需要考虑的问题。PageCache缓存中的消息是断电即丢失的。因为如果业务逻辑异步进行,而消费者已经同步提交了Offset,那么如果业务逻辑执行过程中出现了异常,失败了,那么Broker端已经接收到了消费者的应答,后续就不会再重新推送消息,这样就造成了业务层面的消息丢失。

深入理解 Java 变量类型、声明及应用

Java 变量 变量是用于存储数据值的容器。在 Java 中,有不同类型的变量,例如: String - 存储文本,例如 &amp;quot;你好&amp;quot;。字符串值用双引号引起来。 int - 存储整数(全数字),没有小数,例如 123 或 -123。 float - 存储浮点数,带有小数,例如 19.

Zookeeper分布式队列实战

ZooKeeper实现队列步骤1.创建队列根节点:在Zookeeper中创建一个持久节点,用作队列的根节点。所有队列元素的节点将放在这个根节点下。2.实现入队操作:当需要将一个元素添加到队列时,可以在队列的根节点下创建一个临时有序节点。节点的数据可以包含队列元素的信息。3.实现出队操作:当需要从队列中取出一个元素时,先获取根节点下的所有子节点。再找到具有最小序号的子节点,获取该节点的数据,删除该节点,然后返回节点的数据。

SpringMVC校验注解不生效

用来实现参数校验功能。Spring使用hibernate-validator作为它的默认实现,我们只需要进行一些简单的注解声明,就可以达到参数校验的功能。但是在实际使用场景中,经常会出现校验没生效的问题。

为什么Java中的String类被设计为final类?

String类作为Java中不可或缺的类之一,被设计成final类带来了不可变性、安全性、可靠性和性能优势。不可变的特性使得String对象在多线程环境下安全共享,提高了应用程序的并发性和性能。此外,String类的设计还符合Java类库的一致性和规范,确保了整个语言的稳定性和可靠性。因此,String类被设计成final类是出于多方面的考虑,以提供最佳的使用体验和编程效率。

bat脚本打开多个黑窗口并执行不同的命令

在使用java -jar运行jar包之前,需要先启动redis,而redis的安装目录与jar包不在同一目录下,所以每次启动项目的时候都需要来回的切换目录。现写了一个bat脚本,用来一键启动redis和jar包。start cmd /k &quot;cd /d redis安装目录 &amp;&amp; redis-server redis.windows.conf&quot;其中,cmd /k命令是不关闭黑窗口的命令,timeout /T 3表示等待3秒,/NOBREAK表示键盘输入不会中断等待。

鸿蒙(ArkUI)开发:实现二级联动

列表的二级联动(Cascading List)是指根据一个列表(一级列表)的选择结果,来更新另一个列表(二级列表)的选项。这种联动可以使用户根据实际需求,快速定位到想要的选项,提高交互体验。例如,短视频中拍摄风格的选择、照片编辑时的场景的选择,本文即为大家介绍如何开发二级联动。

Vue和React的区别 | | React函数式写法和类写法的区别

React 更多的是一个库而不是框架,它更专注于视图层的管理,通过社区和第三方库来进行补充和扩展。类式组件: 类式组件是 ES6 中引入的 class 类的一种用法,它继承自 React.Component,拥有完整的生命周期和内部状态管理能力。它是无状态的,没有生命周期和内部状态。而在 React 中,我们使用 JSX 语法,它是一种 JavaScript 的扩展语法,可以在 JavaScript 中直接编写类似 HTML 的结构。在 React 中,我们可以定义组件的两种方式,即函数式组件和类式组件。

SpringBoot:详解Bean生命周期和作用域

前面我们讲诉了将Bean正确地装配到IoC容器,却未讲诉IoC如何装配和销毁Bean。本篇文章主要讲诉一下Bean的生命周期和作用域。以上就是Bean生命周期和作用域的讲解。
返回
顶部