springMVC

springMVC技术与servlet技术相同,均属于web层开发技术。

springMVC是一种基于Java实现MVC模型的轻量级web框架。springMVC中的bean仅仅指的是表现层的bean,不包括数据层和业务逻辑层的bean,为了避免springConfig错误的加载到springMVC的bean,我们需要在springConfig加载控制的bean时去掉springMVC控制的bean,也就是表现层的bean。

springConfig去掉表现层的bean的方法有俩种:

法一:不加载表现层的bean

java 复制代码
package org.example.config;

import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.FilterType;
import org.springframework.stereotype.Controller;

@Configuration
//在spring加载控制bean时,去掉加载的springMVC控制的bean
//法一:不加载表现层的bean
@ComponentScan({"org.example.dao","org.example.service"})
public class springConfig {
}

法二:把表现层的bean从扫描的范围中去掉

java 复制代码
package org.example.config;

import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.FilterType;
import org.springframework.stereotype.Controller;

@Configuration
//在spring加载控制bean时,去掉加载的springMVC控制的bean
//法二:把表现层的bean从扫描范围中去掉
@ComponentScan(value = "org.example",
excludeFilters = @ComponentScan.Filter(
   type = FilterType.ANNOTATION,  //按注解排除扫描的bean
   classes = Controller.class  //告诉它排除什么注解的bean
  )
)
public class springConfig {
}

然后是springMVCConfig的配置

java 复制代码
package org.example.config;

import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.EnableWebMvc;

@Configuration
@ComponentScan("org.example.Controller")

@EnableWebMvc
public class springMVCConfig {
}

@EnableWebMvc 接收json数据时,开启json数据转换为我们需要的数据类型对象 这仅仅是该注解的功能之一。

然后是Controller层的代码:

java 复制代码
package org.example.Controller;

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

@Controller
@RequestMapping("/postman")
public class userRequest {

}

@Controller 注解 表示该类为表现层的bean

@RequestMapping("/postman") 该注解用于声明访问该类的路径http://localhost:8080/postman/\* 可以访问该类中的所有方法。

表现层的方法:

传入简单类型的数据:

java 复制代码
package org.example.Controller;

import org.example.pojo.user;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;

@Controller
@RequestMapping("/postman")
public class userRequest {

    @RequestMapping("/postman1")
    @ResponseBody //作用是把return的返回值作为响应数据
    public String postman1(String name,int age){ //将get请求的参数作为形参输入就可以接收了。
        System.out.println("name==>"+name);
        System.out.println("age==>"+age);
        return "{'module':'postman1'}";
    }
}

@RequestMapping("/postman1")注解是声明该方法的访问路径,http://localhost:3306/postman/postman1?name=zhangsan\&age=18 就可以访问到该类中的该方法。并把参数传入,注意访问路径中的参数与方法中形参的名字要一致。

@ResponseBody 注解是把return的返回值作为响应数据。

请求路径参数名与形参名不一致时

java 复制代码
@RequestMapping("/postman2")
    @ResponseBody
    public String postman2(@RequestParam("name") String username, int age){

        System.out.println("name==>"+username);
        System.out.println("age==>"+age);
        return"{'module':'postman2'}";
    }

@RequestParam注解是把请求路径参数name的值对应到该形参。

传入引用类型的数据:对引用类型数据的默认处理是先把引用类型数据创建出一个对象,然后把获取的数据参数insert到对象中。

java 复制代码
@RequestMapping("/postman3")
    @ResponseBody
    public String postman3(user user){
        System.out.println("user==>"+user);
        return "{'module':'postman3'}";
    }

如果user对象中的有引用类型的数据时需要按图中所例进行传参

传入数组数据

java 复制代码
//数组参数
    @RequestMapping("/postman5")
    @ResponseBody
    public String postman5(String[] likes){
        System.out.println("likes==>"+ Arrays.toString(likes));
        return "{'module':'postman5'}";
    }

传入集合对象

java 复制代码
@RequestMapping("/postman6")
    @ResponseBody
    public String postman6(@RequestParam List<String> likes){
        System.out.println("likes==>"+likes);
        return "{'module':'postman6'}";
    }

因为引用类型数据list集合是个接口,没有构造方法所以不能创建对象,所以不能用默认的方法,

解决办法:加上@RequestParam注解,告诉它,是把获取的请求参数放入list集合中,而不是作为list集合的属性。

传入json格式的集合

java 复制代码
@RequestMapping("/postman7")
    @ResponseBody
    public String postman7(@RequestBody List<String> likes){
        System.out.println("likes==>"+likes);
        return "'module':'postman7'";
    }

因为此时数据我们写在了请求体中,不能用requestParam了,需要换成requestBody。

传入json格式的引用类型数据:

java 复制代码
    @RequestMapping("/postman8")
    @ResponseBody
    public String postman8(@RequestBody user user){
        System.out.println("user==>"+user);
        return "'module':'postman8'";
    }

传入日期类型数据:

java 复制代码
 @RequestMapping("/postman10")
    @ResponseBody
    public String postman10(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==>"+date1);
        System.out.println("date2==>"+date2);
        return "{;module':'postman10'}";
    }

日期,年月日之间的分隔符,/ 可以直接用; - 因为格式不匹配,需要加@DateTimeFormat注解来配格式。

相关推荐
Mr_Air_Boy1 小时前
SpringBoot使用dynamic配置多数据源时使用@Transactional事务在非primary的数据源上遇到的问题
java·spring boot·后端
豆沙沙包?1 小时前
2025年- H77-Lc185--45.跳跃游戏II(贪心)--Java版
java·开发语言·游戏
年老体衰按不动键盘2 小时前
快速部署和启动Vue3项目
java·javascript·vue
咖啡啡不加糖2 小时前
Redis大key产生、排查与优化实践
java·数据库·redis·后端·缓存
liuyang-neu2 小时前
java内存模型JMM
java·开发语言
UFIT2 小时前
NoSQL之redis哨兵
java·前端·算法
刘 大 望2 小时前
数据库-联合查询(内连接外连接),子查询,合并查询
java·数据库·sql·mysql
怀旧,2 小时前
【数据结构】6. 时间与空间复杂度
java·数据结构·算法
大春儿的试验田3 小时前
Parameter ‘XXX‘ not found. Available parameters are [list, param1]
java
程序员JerrySUN4 小时前
[特殊字符] 深入理解 Linux 内核进程管理:架构、核心函数与调度机制
java·linux·架构