1.SpringBoot json支持
1.1创建实体bean Car
Lombok使用:
1、导入依赖库
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.6</version>
</dependency>
2、安装插件
继续:
3、在实体bean使用
@Data //get 、set
@AllArgsConstructor //所有参数的有参数构造函数
@NoArgsConstructor //无参数构造函数
package com.wf.po;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
@Data //get 、set toString
@AllArgsConstructor //所有参数的有参数构造函数
@NoArgsConstructor //无参数构造函数
public class Car {
private Integer id;
private String name;
private Float price;
@JsonFormat(pattern="yyyy-MM-dd HH:mm:ss",timezone="GMT+8")
private Date createdate;
}
4.创建Controller CarController
package com.wf.controller;
import com.wf.po.Car;
import org.springframework.cache.CacheManager;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;
import java.util.ArrayList;
import java.util.List;
@RestController
@RequestMapping("/car")
public class CarController {
@RequestMapping("/findone")
public Car findOneCar(){
Car car = new Car(1, "toyo", 1999.99F,new Date(),"13567890001");
return car;
}
}
说明:@RestController 注解,等于@Controller 与 @ResponseBody 一起使用
@requestBody注解常用来处理content-type不是默认的application/x-www-form-urlcoded编码的内容,比如说:application/json或者是application/xml等。
一般情况下来说常用其来处理application/json类型
1.2、SpringBoot 请求传递参数
2.1. 第一类:请求路径传参
@RequestParam 获取查询参数。即url?name=value 这种形式
@PathVariable 获取路径参数。即url/{id} 这种形式
代码应用:
(1)修改Controller CarController新增接收参数,返回单个对象方法
package com.wf.springbootdemo.controller;
import com.wf.springbootdemo.po.Car;
import org.springframework.web.bind.annotation.*;
import java.util.Date;
@RestController
@RequestMapping("/car")
public class CarController {
@RequestMapping("/findOne")
public Car Demo1(){
Car car=new Car(1,"小奔驰",1000,new Date());
return car;
}
// http://localhost:8080/car/findTwo/kkk?id=10
@RequestMapping("/findTwo/{name}")
public Car Demo2(@RequestParam(name = "id") Integer id, @PathVariable(name = "name") String name){
Car car=new Car();
car.setId(id);
car.setName(name);
car.setPrice(1999);
car.setCreatedate(new Date());
return car;
}
// @PathVariable占位符 @RequestParam问号后面的参数
//http://localhost:8080/car/findThree/10?name=%E5%A4%A7%E5%AE%9D%E9%A9%AC
@RequestMapping("/findThree/{id}")
public Car Demo3(@PathVariable(name = "id") Integer id, @RequestParam(name = "name") String name){
Car car=new Car();
car.setId(id);
car.setName(name);
car.setPrice(1999);
car.setCreatedate(new Date());
return car;
}
}
测试传递参数获取单个对象json
请求地址:
http://localhost:8080/car/findTwo/kkk?id=10或
http://localhost:8080/car/findThree/10?name=%E5%A4%A7%E5%AE%9D%E9%A9%AC(注意那么后面的不是乱码,是汉字转换成utf-8后的效果)
utf-8编码转换器
https://utf8.supfree.net/
1.3、SpringBoot 静态资源
(1)Spring Boot 对静态资源映射提供了默认配置
Spring Boot 默认将 /** 所有访问映射到以下目录:
classpath:/static
classpath:/public
classpath:/resources
classpath:/META-INF/resources
如:在resources目录下新建 public、resources、static 三个目录,并分别放入 a.jpg b.jpg c.jpg 图片
效果图展示:
(2)、自定义静态资源访问
第一种方式:
1、配置类
package com.wf.springbootdemo.config;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
//自定义配置类
@Configuration
public class WebMvcConfig implements WebMvcConfigurer {
@Override
public void addResourceHandlers(ResourceHandlerRegistry registry) {
//将某个磁盘下的资源映射到浏览器上
//将所有E:\springboot\pic\访问都映射到/myPhoto/** 路径下
registry.addResourceHandler("/myPhoto/**").addResourceLocations("file:E:\springboot\pic\");
}
}
访问的时候使用此路径:http://localhost:8080/myPhoto/1.jpg
效果图演示:
第二种方式:
首先,我们配置application.properties
web.upload-path=E:/springboot/pic
spring.mvc.static-path-pattern=/**
spring.resources.static-locations=classpath:/META-INF/resources/,
classpath:/public/,classpath:/static/,file:${web.upload-path}
注意:
web.upload-path:这个属于自定义的属性,指定了一个路径,注意要以/结尾;
spring.mvc.static-path-pattern=/**:表示所有的访问都经过静态资源路径;
spring.resources.static-locations:在这里配置静态资源路径,前面说了这里的配置是覆盖默认配置,所以需要将默认的也加上否则static、public等这些路径将不能被当作静态资源路径,在这个最末尾的file:${web.upload-path}之所有要加file:是因为指定的是一个具体的硬盘路径,其他的使用classpath指的是系统环境变量。
例如,在D:/springboot/pic/中有一张8.png图片
在浏览器输入:http://localhost:8080/8.png 即可访问
1.4、WebJars
WebJars实践:
1、在src/main/resouces路径下创建META-INF/resources/webjars/demo/0.0.1目录,同时为了演示效果,拷贝一个图片到此目录下。
2.
编写一个简单的html页面,放在在src/main/resources/static下(当然也可以直接放在webjar下了,只需要后面加个映射关系即可),内容如下
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>访问静态资源</title>
</head>
<body>
<!--webjars/demo/0.0.1/8.png此路径对应刚才创建的路径-->
<img src="webjars/demo/0.0.1/8.png" alt="映射地址">
</body>
</html>
3、编写配置类,添加一个资源映射关系.其实也可以不写,因为第4节也有说过,springboot默认的四个资源路径里面就包含了/META-INF/resources/了
package com.wf.springbootdemo.config;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
//自定义配置类
@Configuration
public class WebMvcConfig implements WebMvcConfigurer {
@Override
public void addResourceHandlers(ResourceHandlerRegistry registry) {
//配置映射关系(后边的路径和前边的路径拼接即为对应的资源文件路径)
registry.addResourceHandler("/webjars/**").addResourceLocations("classpath:/META-INF/resources/webjars/");
}
}
4.访问对应的html即可