SpringMVC修炼之旅(2)基础入门

一、第一个程序

1.1环境配置

1.2代码实现

package com.itheima.controller;

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

//定义表现层控制器bean
@Controller
public class UserController {

    //设置映射路径为/save,即外部访问路径
    @RequestMapping("/save")
    //设置当前操作返回结果为指定json数据(本质上是一个字符串信息)
    @ResponseBody
    public String save(){
        System.out.println("user save ...");
        return "{'info':'springmvc'}";
    }

    //设置映射路径为/delete,即外部访问路径
    @RequestMapping("/delete")
    @ResponseBody
    public String delete(){
        System.out.println("user save ...");
        return "{'info':'springmvc'}";
    }
}

1.3注解解析

@Controller

类型:类注解

位置:SpringMVC控制器类定义上方

作用:用于标记控制器类。当一个类被@Controller注解标记时,Spring会自动将该类识别为一个控制器类,并负责处理与该类相关的HTTP请求。

@Controller
public class UserController 
{

}

@RequestMapping

类型:方法注解

位置:SpringMVC控制器方法定义上方

作用:用于映射HTTP请求到特定的处理方法。它可以应用于类、方法或参数上。当一个类被@RequestMapping注解标记时,Spring会自动将该类中的所有带有@RequestMapping注解的方法识别为处理特定URL路径的处理器。:

@Controller
public class UserController {

    @RequestMapping(value = "/save")
    public void save() {
        System.out.println("user save ...");
    }
}

 相关属性 value(默认):请求访问路径

@ResponseBody

 类型:方法注解

位置:SpringMVC控制器方法定义上方

作用:用于将控制器方法的返回值直接写入HTTP响应体中。这样,当客户端发起请求时,服务器端会将处理结果以指定的格式(如JSON、XML等)发送给客户端

1.4bean加载控制

Spring控制的bean

  • 业务bean(Service)
  • 功能bean(DataSource等)

@Configuration

`@Configuration`注解是Spring框架中的一个注解,用于标记一个类作为配置类。配置类通常用于定义Bean的创建和依赖关系,以便在应用程序中进行依赖注入。

 @ComponentScan

类型:类注解

位置:应该放在Spring配置文件的类上,通常是在配置类中

作用:用于指定要扫描的包路径,以便自动注册该包及其子包中的组件。当使用@ComponentScan注解时,Spring会自动扫描指定的包路径下的所有类,并将带有@Component、@Service、@Repository或@Controller等注解的类注册为Spring容器中的Bean。

@Configuration
@ComponentScan(value = "com.com.example",
    excludeFilters = @ComponentScan.Filter(
        type = FilterType.ANNOTATION,
        classes = Controller.class
    )
)
public class SpringConfig {
}

 excludeFilters:排除扫描路径中加载的bean,需要指定类别(type)与具体项(classes) includeFilters:加载指定的bean,需要指定类别(type)与具体项(classes)

@EnableAutoConfiguration

是Spring Boot框架提供的一个注解,用于自动配置Spring应用程序的配置。它会根据应用程序的依赖和配置自动配置Spring应用程序的配置。这样可以减少开发人员的配置工作,提高开发效率。@EnableAutoConfiguration注解通常与@SpringBootApplication注解一起使用,用于启用Spring Boot自动配置功能。

@SpringBootApplication

`@SpringBootApplication`注解是Spring Boot框架中的一个注解,用于标记`@SpringBootApplication`注解是Spring Boot框架中的一个注解,用于标记一个类作为Spring Boot应用程序的主入口。它包含了`@Configuration`、`@EnableAutoConfiguration`和`@ComponentScan`三个注解的组合,可以自动配置Spring Boot应用程序的组件扫描路径、自动配置和其他相关设置。 

 二、请求和响应

2.1请求映射路径

多个控制器类处理相同的请求路径

可以通过以下方法解决

使用@RequestMapping注解的value属性指定请求路径的具体值,可以在不同的控制器类中使用不同的请求路径来区分不同的处理方法。

@Controller
@RequestMapping("/example")
public class ExampleController1 {
    @RequestMapping("/test")
    public String test() {
        //处理逻辑
        return "test";
    }
}

@Controller
@RequestMapping("/example2")
public class ExampleController2 {
    @RequestMapping("/test")
    public String test() {
        //处理逻辑
        return "test2";
    }
}
使用@RequestMapping注解的params属性来区分不同的请求处理方法,可以根据请求参数的不同来调用不同的处理方法。
@Controller
@RequestMapping("/example")
public class ExampleController {
    @RequestMapping(value = "/test", params = "param1")
    public String test1() {
        //处理逻辑
        return "test1";
    }

    @RequestMapping(value = "/test", params = "param2")
    public String test2() {
        //处理逻辑
        return "test2";
    }
}

使用@RequestMapping注解的headers属性来区分不同的请求处理方法,可以根据请求头的不同来调用不同的处理方法。

@Controller
@RequestMapping("/example")
public class ExampleController {
    @RequestMapping(value = "/test", headers = "header1=value1")
    public String test1() {
        //处理逻辑
        return "test1";
    }

    @RequestMapping(value = "/test", headers = "header2=value2")
    public String test2() {
        //处理逻辑
        return "test2";
    }
}

 2.2请求方式

  • Get请求
  • Post请求

Get请求传参

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

@RequestMapping("/commonParam")
    @ResponseBody
    public String handleCommonParam(String name,Integer age) {
        System.out.println("Name: " + name + ", age: " + age);
        return "{'module':'common param'}";
    }
GET http://localhost:8080/commonParam?name=11&age=11

 Post请求参数

POST http://localhost:8080/commonParam
Content-Type: application/x-www-form-urlencoded

name=11&age=18

Get请求和 Post请求的区别

GET和POST是HTTP协议中两种最常被使用的请求方法,它们在原理、使用、速度和安全性等方面都有所区别。具体来说:

  1. 参数传递方式:GET方法将参数包含在URL中,而POST方法通过request body传递参数。这意味着,使用GET提交的数据会显示在URL上,而POST提交的数据则不会显示在URL上。

  2. 数据用途:GET请求通常用于从服务器获取数据,而POST请求则主要用于向服务器提交数据,例如提交表单数据。

  3. 缓存与历史记录:GET请求可以被浏览器缓存,同时也会保存在浏览器的历史记录中。相反,POST请求不会被缓存,且不会保存在历史记录中。

  4. 安全性:由于GET请求将参数直接暴露在URL中,因此可能存在安全隐患。相反,POST请求通过加密的request body传递参数,因此在安全性方面相对较高。

  5. 数据量限制:GET方法由于数据量受限于URL的长度,因此对于大量数据的提交不太适用。而POST方法没有这方面的限制。

  6. 影响刷新和回退:当使用GET请求时,刷新页面或回退操作不会影响之前的数据。但是,使用POST请求时,回退可能会导致数据被重新提交。

2.3请求参数

参数种类

  • 普通参数
  • POJO类型参数
  • 嵌套POJO类型参数
  • 数组类型参数
  • 集合类型参数 

普通参数:

  • url地址传参,地址参数名与形参变量名相同,定义形参即可接收参数 
  • 请求参数名与形参变量名不同,使用@RequestParam绑定参数关系
 @RequestMapping("/commonParam")
    @ResponseBody
    public String handleCommonParam(@RequestParam("name") String name1,Integer age) {
        System.out.println("Name: " + name1 + ", age: " + age);
        return "{'module':'common param'}";
    }

@RequestParam 注解

类型:形参注解

位置:SpringMVC控制器方法形参定义前面

作用:用于将请求参数绑定到方法的参数上。它可以用于处理 GET 和 POST 请求中的查询参数和表单数据。使用 @RequestParam 注解可以将请求参数的值绑定到方法的参数上

它有以下两个参数:

  1. required:布尔类型,表示该参数是否为必传参数。如果设置为 true,则在请求中必须包含该参数;如果设置为 false,则可以不包含该参数,此时参数的默认值为 null

  2. defaultValue:字符串类型,表示当请求中没有提供该参数时使用的默认值。如果不设置此参数,或者设置为空字符串,那么在请求中没有提供该参数时,参数的值将为 null

@RequestMapping("/commonParam")
    @ResponseBody
    public String handleCommonParam(@RequestParam(value = "name", required = false, defaultValue = "defaultValue1") String name1,Integer age) {
        System.out.println("Name: " + name1 + ", age: " + age);
        return "{'module':'common param'}";
    }

POJO参数:

请求参数名与形参对象属性名相同,定义POJO类型形参即可接收参数

pojo类

@RequestMapping("/pojoParam")
    @ResponseBody
    public String pojoParam(User user){
        System.out.println("pojo参数传递 user ==> "+user);
        return "{'module':'pojo param'}";
    }

嵌套POJO参数:

POJO对象中包含POJO对象

请求参数名与形参对象属性名相同,按照对象层次结构关系即可接收嵌套POJO属性参数

 @RequestMapping("/pojoContainPojoParam")
    @ResponseBody
    public String pojoContainPojoParam(User user){
        System.out.println("pojo嵌套pojo参数传递 user ==> "+user);
        return "{'module':'pojo contain pojo param'}";
    }
GET http://localhost:8080//pojoContainPojoParam?name1=11&age=11&Address.province=12&Address.city=12

 数组参数:

同名请求参数可以直接映射到对应名称的形参数组对象中

//数组参数:同名请求参数可以直接映射到对应名称的形参数组对象中
    @RequestMapping("/arrayParam")
    @ResponseBody
    public String arrayParam(String[] likes){
        System.out.println("数组参数传递 likes ==> "+ Arrays.toString(likes));
        return "{'module':'array param'}";
    }
GET http://localhost:8080/arrayParam?likes=1&likes=2

集合保存普通参数:

请求参数名与形参集合对象名相同且请求参数为多个,@RequestParam绑定参数关系 

 //集合参数:同名请求参数可以使用@RequestParam注解映射到对应名称的集合对象中作为数据
    @RequestMapping("/listParam")
    @ResponseBody
    public String listParam(@RequestParam List<String> likes){
        System.out.println("集合参数传递 likes ==> "+ likes);
        return "{'module':'list param'}";
    }

 集合参数:json格式

 @RequestMapping("/listParamForJson")
    @ResponseBody
    public String listParamForJson(@RequestBody List<String> likes){
        System.out.println("list common(json)参数传递 list ==> "+likes);
        return "{'module':'list common for json param'}";
    }
POST http://localhost:8080//listParamForJson
Content-Type: application/json

["like1", "like2", "like3"]

POJO参数:json数据

json数据与形参对象属性名相同,定义POJO类型形参即可接收参数

@RequestMapping("/pojoParamForJson")
    @ResponseBody
    public String pojoParamForJson(@RequestBody User user){
        System.out.println("pojo(json)参数传递 user ==> "+user);
        return "{'module':'pojo for json param'}";
    }
POST http://localhost:8080/pojoParamForJson
Content-Type: application/json

{
"name": "John Doe", "age": 25,"address": {"province": "Ontario", "city": "Toronto"}
}

POJO集合参数:json

json数组数据与集合泛型属性名相同,定义List类型形参即可接收参数

//集合参数:json格式
    //1.开启json数据格式的自动转换,在配置类中开启@EnableWebMvc
    //2.使用@RequestBody注解将外部传递的json数组数据映射到形参的保存实体类对象的集合对象中,要求属性名称一一对应
    @RequestMapping("/listPojoParamForJson")
    @ResponseBody
    public String listPojoParamForJson(@RequestBody List<User> list){
        System.out.println("list pojo(json)参数传递 list ==> "+list);
        return "{'module':'list pojo for json param'}";
    }
POST http://localhost:8080/listPojoParamForJson
Content-Type: application/json

[
  {
    "name": "John Doe", "age": 25,"address": {"province": "Ontario", "city": "Toronto"}
  },
  {
    "name": "John Doe", "age": 25,"address": {"province": "Ontario", "city": "Toronto"}
  }
]

@RequestBody与@RequestParam区别

区别

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

应用

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

日期类型参数传递

//日期参数
//使用@DateTimeFormat注解设置日期类型数据格式,默认格式yyyy/MM/dd
@RequestMapping("/dataParam")
@ResponseBody
public String dataParam(Date date,
                        @DateTimeFormat(pattern="yyyy-MM-dd") Date date1,
                        @DateTimeFormat(pattern="yyyy/MM/dd HH:mm:ss") Date date2){
    System.out.println("参数传递 date ==> "+date);
    System.out.println("参数传递 date1(yyyy-MM-dd) ==> "+date1);
    System.out.println("参数传递 date2(yyyy/MM/dd HH:mm:ss) ==> "+date2);
    return "{'module':'data param'}";
GET http://localhost:8080/dataParam?date1=2023-12-06&date2=2023/12/06 10:10:10

想要将日期作为查询参数传递,因此你应该使用GET请求而不是POST请求。此外,由于日期值需要按照指定的格式进行设置,你需要对日期2的值进行编码,因为URL中的空格是不允许的

2.4响应 

响应页面

@RequestMapping("/toJumpPage")
public String toJumpPage(){
    System.out.println("跳转页面");
    return "redirect:/page.jsp";
}

响应数据

  • 文本数据
  • json数据 
文本数据
//响应文本数据
    //返回值为String类型,设置返回值为任意字符串信息,即可实现返回指定字符串信息,需要依赖@ResponseBody注解
    @RequestMapping("/toText")
    @ResponseBody
    public String toText(){
        System.out.println("返回纯文本数据");
        return "response text";
    }

 

json数据 
 @RequestMapping("/toJsonPOJO")
    @ResponseBody
    public User toJsonPOJO(){
        System.out.println("返回json对象数据");
        User user = new User();
        user.setName("itcast");
        user.setAge(15);
        return user;
    }
 @RequestMapping("/toJsonList")
    @ResponseBody
    public List<User> toJsonList(){
        System.out.println("返回json集合数据");
        User user1 = new User();
        user1.setName("烟雨");
        user1.setAge(15);

        User user2 = new User();
        user2.setName("平生");
        user2.setAge(12);

        List<User> userList = new ArrayList<User>();
        userList.add(user1);
        userList.add(user2);

        return userList;
    }

HttpMessageConverter接口

// 定义一个名为HttpMessageConverter的接口,泛型参数为T
public interface HttpMessageConverter<T> {
    // 判断是否可以读取指定类型的数据,参数为类对象和媒体类型(可以为空)
    boolean canRead(Class<?> clazz, @Nullable MediaType mediaType);
    // 判断是否可以写入指定类型的数据,参数为类对象和媒体类型(可以为空)
    boolean canWrite(Class<?> clazz, @Nullable MediaType mediaType);
    // 获取支持的媒体类型列表
    List<MediaType> getSupportedMediaTypes();
    // 从输入消息中读取指定类型的数据,参数为类对象和输入消息对象
    T read(Class<? extends T> clazz, HttpInputMessage inputMessage)
        throws IOException, HttpMessageNotReadableException;
    // 将指定类型的数据写入输出消息,参数为数据对象、内容类型(可以为空)和输出消息对象
    void write(T t, @Nullable MediaType contentType, HttpOutputMessage outputMessage)
        throws IOException, HttpMessageNotWritableException;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/223851.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

MySQL联合查询、最左匹配、范围查询导致失效

服务器版本 客户端&#xff1a;navicat premium16.0.11 联合索引 假设有如下表 联合索引就是同时把多列设成索引&#xff0c;如(empno&#xff0c;ename)在查询的时候就会先按照empno进行查询&#xff0c;再按照ename进行查询其中empno是全局有序&#xff0c;ename是局部有…

【银行测试】支付类测试关注点与异常点+支付平台...

目录&#xff1a;导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09; 前言 1、支付类的测试关…

Django回顾 - 6 Ajax

【1】Ajax 定义&#xff1a; 异步Javscript和XML 作用&#xff1a; Javascript语言与服务器(django)进行异步交互&#xff0c;传输的数据为XML&#xff08;当然&#xff0c;传输的数据不只是XML,现在更多使用json数据&#xff09; 同步交互和异步交互&#xff1a; 1、同步交互&…

Web server failed to start. Port 8081 was already in use.

netstat -aon|findstr "8081" taskkill /pid 20824 /f

现代雷达车载应用——第2章 汽车雷达系统原理 2.1节

经典著作&#xff0c;值得一读&#xff0c;英文原版下载链接【免费】ModernRadarforAutomotiveApplications资源-CSDN文库。 2.1 基本雷达功能 雷达系统通过天线或天线阵列向空间辐射电磁能量。辐射的电磁能量“照亮”周围的目标。“被照亮”的目标拦截一些辐射能量&#xff0…

开发步骤、Java开发工具

目录 一、开发步骤 二、Java开发工具 JDK安装完毕&#xff0c;我们就可以开始开发第一个Java程序了&#xff0c;习惯性的成为HelloWorld。 一、开发步骤 Java程序开发三步骤&#xff1a;编写、编译、运行 -将Java代码编写到扩展名为.java的源文件中 -通过javac.exe命令对…

Kontakt v7.7.2(音频采样器)

Native Instruments Kontakt 7是一款强大的软件采样器&#xff0c;它允许用户从各种来源采样音频并进行编辑和处理。它包含大量预设采样库&#xff0c;包括乐器、合成器、鼓组和声音效果等。此外&#xff0c;Kontakt 7还允许用户创建自己的采样库&#xff0c;以便根据自己的需要…

CTF特训日记day7

复现华为杯研究生国赛的adv_lua题目 从题目描述来看&#xff0c;漏洞应该和bytearray相关 用IDA逆向一下然后直接字符串搜索bytearray 只有这里有bytearray字样&#xff0c;继续查找交叉引用&#xff1a; 可以看到一系列方法&#xff0c;显然都是为bytearray所注册的吗&am…

Xilinx FPGA平台DDR3设计详解(三):DDR3 介绍

本文介绍一下常用的存储芯片DDR3&#xff0c;包括DDR3的芯片型号识别、DDR3芯片命名、DDR3的基本结构等知识&#xff0c;为后续掌握FPGA DDR3的读写控制打下坚实基础。 一、DDR3芯片型​号 电路板上的镁光DDR3芯片上没有具体的型号名。 ​如果想知道具体的DDR3芯片型号&#…

电力智慧运维系统

电力智慧运维系统是以提高用户侧电力运行安全&#xff0c;降低运维成本为目标&#xff1b;采用智能化运维管理工具—“电易云”&#xff0c;帮助企业建立电力运维体系全方位的信息化、数字化平台&#xff0c;实现设备运行的数字化在线监控与线下维护处理的有机融合&#xff0c;…

【海思SS528 | VO】MPP媒体处理软件V5.0 | VO模块编程总结

&#x1f601;博客主页&#x1f601;&#xff1a;&#x1f680;https://blog.csdn.net/wkd_007&#x1f680; &#x1f911;博客内容&#x1f911;&#xff1a;&#x1f36d;嵌入式开发、Linux、C语言、C、数据结构、音视频&#x1f36d; &#x1f923;本文内容&#x1f923;&a…

Netty中Channel的isWritable方法理解

目录 初见 深入 需要注意 对待超SIZE情况开源项目怎么做 1、seata中 2、SUMMER中 3、一些资料中 总结 初见 以下是包中注释 Returns true if and only if the I/O thread will perform the requested write operation immediately. Any write requests made when t…

如何解决syntaxerror: more than 255 arguments 报错

如何解决syntaxerror: more than 255 arguments 报错 问题背景解释解决方案 问题背景 今天拼接特征的时候&#xff0c;突然代码报错syntaxerror: more than 255 arguments &#xff0c;看了一下感觉这个报错非常有意思&#xff0c;估计平时也是没机会碰到&#xff0c;和大家分…

线程基础介绍

什么是线程&#xff1f; linux内核中是没有线程这个概念的&#xff0c;而是轻量级进程的概念&#xff1a;LWP。一般我们所说的线程概念是C库当中的概念。 1.1线程是怎样描述的&#xff1f; 线程实际上也是一个task_struct&#xff0c;工作线程拷贝主线程的task_struct&#…

推出ASM2824 PCIe交换机,预计M.2插槽将增加,E3SB40E00004EE、E2SB40E00000JE 40MHz晶振

一、ASM2824 PCIe交换机&#xff0c;预计M.2插槽将增加 ASM2824 PCI-Express Gen 3.0 x24交换机采用PCI-Express 3.0 x8&#xff0c;并提供四个PCI-Express 3.0 x4连接&#xff0c;其结构为PLX PEX8747的一半。从理论上讲&#xff0c;这将允许主板设计人员从英特尔Z390芯片组的…

C++类和对象——(8)类的组合

归纳编程学习的感悟&#xff0c; 记录奋斗路上的点滴&#xff0c; 希望能帮到一样刻苦的你&#xff01; 如有不足欢迎指正&#xff01; 共同学习交流&#xff01; &#x1f30e;欢迎各位→点赞 &#x1f44d; 收藏⭐ 留言​&#x1f4dd; 人生就像骑单车&#xff0c;想保持平衡…

香港科技大学广州|机器人与自主系统学域博士招生宣讲会—北京专场!!!(暨全额奖学金政策)

在机器人和自主系统领域实现全球卓越—机器人与自主系统学域 硬核科研实验室&#xff0c;浓厚创新产学研氛围&#xff01; 教授亲临现场&#xff0c;面对面答疑解惑助攻申请&#xff01; 一经录取&#xff0c;享全额奖学金1.5万/月&#xff01; 时间&#xff1a;2023年12月09日…

Python实现广义线性回归模型(statsmodels GLM算法)项目实战

说明&#xff1a;这是一个机器学习实战项目&#xff08;附带数据代码文档视频讲解&#xff09;&#xff0c;如需数据代码文档视频讲解可以直接到文章最后获取。 1.项目背景 广义线性模型(Generalized Linear Model&#xff0c;简称GLM)是一种广泛应用于回归分析和分类问题的统…

MySql概述及其性能说明

MySQL是一种开源的关系型数据库管理系统&#xff0c;由瑞典MySQL AB公司开发&#xff0c;现属于Oracle公司。MySQL是最流行的开源数据库之一&#xff0c;被广泛地应用于Web开发中。MySQL提供了一个高度稳定可靠的数据存储解决方案&#xff0c;同时也可以很容易地跨平台运行。My…

前端十几年后的变迁:从代码编织者到创新驱动者

十几年前的前端开发&#xff0c;是一个被大多数人忽视的领域。那时的网页设计简陋&#xff0c;功能单一&#xff0c;前端开发的工作也相对简单。然而&#xff0c;随着科技的发展和互联网的普及&#xff0c;前端开发已经从一个边缘角色成长为一个关键的创新驱动力。那么&#xf…