Springboot一窥

这玩意学了两天没理顺……先写一份博客记录下。
本文适用于看了网课但是没看懂的人用于补充知识点/忘记某些操作的人简单回顾一下以前的知识点,不适用于刚学完Java的小白直接来看。
同时也给我这种学完就忘的人看(

零、目录结构

SpringBoot文件目录结构

一、属性配置

我们可以针对SpringBoot项目写配置文件(格式为.properties或.yml)。通过配置文件,我们可以对项目的某些属性进行配置,也可以初始化某些值。
创建项目时,IDEA会自动在resources目录下添加一个空白的application.properties。我们可以自行添加application.yml。受限于学习时间,本文目前为止仅以yml进行范例操作。

(一)默认配置文件简述

SpringBoot可以存在多个application.properties/application.yml。运行项目时,将按照以下优先级加载配置文件:


配置文件优先级 摘自C语言中文网

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"了。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。