这玩意学了两天没理顺……先写一份博客记录下。
本文适用于看了网课但是没看懂的人用于补充知识点/忘记某些操作的人简单回顾一下以前的知识点,不适用于刚学完Java的小白直接来看。
同时也给我这种学完就忘的人看(
零、目录结构
一、属性配置
我们可以针对SpringBoot项目写配置文件(格式为.properties或.yml)。通过配置文件,我们可以对项目的某些属性进行配置,也可以初始化某些值。
创建项目时,IDEA会自动在resources目录下添加一个空白的application.properties。我们可以自行添加application.yml。受限于学习时间,本文目前为止仅以yml进行范例操作。
(一)默认配置文件简述
SpringBoot可以存在多个application.properties/application.yml。运行项目时,将按照以下优先级加载配置文件:
file:当前项目根目录;classpath:resources目录
运行时,若存在多个配置文件,将按照优先级从高到低的顺序进行项目运行的属性调整。当文件1与文件2之间配置不同内容时,共同生效;配置相同内容时,高优先级文件的相关配置将先生效,低优先级文件的相关配置不生效。
(二)多环境配置文件
如上图中的application-{profile}.properties,profile可以用于区分不同环境的配置,方便程序员调试。我们可以写以下四种配置文件以方便应用于不同环境中:
application.yml //主配置文件
application-dev.yml //开发环境配置文件
application-test.yml //测试环境配置文件
application-prod.yml //生产环境配置文件
这些文件既可以在目录中分开写,又可以写在一起。
1、分开书写
分开书写即在目录中创建这四个文件,每一个进行相关配置。在后三个配置文件写完后,我们可以在application.yml进行激活:
spring
profiles:
active: dev #激活开发环境配置
2、写在一起
写在一起的意思就是可以将四个文档统统写进application.yml,学名叫做文档块模式。不理解可以去看YAML语法。
写法举例(摘自Spring Boot Profile(多环境配置) (biancheng.net)
):
#默认配置
server:
port: 8080
#切换配置
spring:
profiles:
active: test
---
#开发环境
server:
port: 8081
spring:
config:
activate:
on-profile: dev
---
#测试环境
server:
port: 8082
spring:
config:
activate:
on-profile: test
---
#生产环境
server:
port: 8083
spring:
config:
activate:
on-profile: prod
这样就成功激活test环境的配置文件了。
(三)server配置简述
server有以下对象:port和context-path。
port就是端口,context-path相当于TomCat虚拟目录的映射地址。
举例:
server:
port: 8080
context-path: wuhu
那么在项目运行时,访问localhost:8080/wuhu即可访问到该项目。
(四)自定义属性与配置绑定
懒得写了……指个链接吧:
YAML教程(快速入门版) (biancheng.net)
Spring Boot配置绑定 (biancheng.net)(不要看@PropertySource)
二、Controller控制器
Controller用于处理客户端的请求。介绍以下注解:
@Controller //处理http请求
@RestController //@ResponseBody与@Controller的组合注解
@RequestMapping //配置url映射
@GetMapping //以Get方式请求时,url映射地址
@RequestParam //获取请求参数中的值
@PathVariable //获取url中的数据
简单介绍一下。
(一)@Controller
用于类上,标志一个控制器组件。同样的组件有@Component,@Configuration等等等等。
(二)@ResponseBody
用于类/方法上,将Java对象转换为json格式数据。不用理解那么多,一般返回对象的时候一股脑在类上用@RestController就行。
(三)@RequestMapping与@GetMapping
用于类或方法,告诉Controller可以处理哪些url的请求。以下面一行代码为例:
@RequestMapping(value = {"/hello"}, method = RequestMethod.GET)
这行代码的意思是:以GET方式访问配置的url(xxx/hello)时,就调用下述类/方法。
@GetMapping省略了上述的method,只需要填入value就能实现相同功能。类似的,我们可以写出@PostMapping等等等等。
(四)@RequestParam
用在类或方法上,获取http请求中传递参数的值。例如:
public String hello(@RequestParam(value = "id") Integer userId){
//方法体
}
在以GET方式请求xxx.com/hello?id=300时,变量userId就赋值为300了。
要想获取多个参数,加个逗号就行,如
public String hello(@RequestParam(value = "ID") Integer id, @@RequestParam(value = "wuhu") String wuhu)
在@RequestParam中,还有两个变量:required与defaultValue。
语法:@RequestParam(value=”参数名”,required=”true/false”,defaultValue=””)
value:参数名
required:是否包含该参数,默认为true,表示该请求路径中必须包含该参数,如果不包含就报错。
defaultValue:默认参数值,如果设置了该值,required=true将失效,自动为false,如果没有传该参数,就使用默认值
(五)@PathVariable
该注解用于接收请求路径中占位符的值。占位符用大括号括起来,形如{xxx}。
@PathVariable("xxx")
通过 @PathVariable 可以将URL中占位符参数{xxx}绑定到处理器类的方法形参中@PathVariable("xxx")
@RequestMapping(value=”user/{id}/{name}”)
请求路径:http://localhost:8080/hello/show5/1/james
例:
@GetMapping(value = "/hello/{userName}")
public String hello(@PathVariable("userName") String userName){
return userName;
}
访问xxx/hello/wuhu时,就会返回"wuhu"了。