1.使用idea创建项目
1.打开IDEA,点击 +Create New Project. 开始创建一个新项目。
2.在左侧菜单找到并点击 Spring Initializr,点击next。注意,这里idea默认使用https://start.spring.io提供的在线模板,所以需要保证网络畅通。
3.按实际情况依次填写项目信息。其中Type属性可以下拉选择project或者pom,Packaging属性可下拉选择jar或者war,我们不用tomcat来部署,而是直接用jar包启动,这样跟之前的学习就可以无缝对接啦!
下一步......
4.最激动人心的界面来了!!!你可以从左面选择大类,然后在窗口中间勾选需要的依赖。右边可以看到已选择的依赖项。
就选这两样吧,其他的到时候再说,下一步,直接点击完成。
项目就建好了。
idea右下角会出现这个:
不用担心,这是maven在自动下载jar包。maven就是一个本地仓库,帮你管理所有的jar包和项目之间的依赖关系的。如果本地仓库没有,就去中央仓库帮你下载,太方便了,这也是现在为什么maven这么流行的原因。
找到这个类,运行之。
启动完毕,很漂亮的日志打印。
他说:Tomcat started on port(s): 8080 (http) with context path ''
意思就是项目已经启动好了,正在监听8080端口。
这些概念和术语,你现在都不需要去深究,你只要知道,现在项目跑起来了,然后你打开浏览器就可以访问。
网址是:http://localhost:8080/
能看到这个,就说明没问题了。404是因为现在这个项目是一个空壳子,什么服务都没有,当然是空啦。
虽然用eclipse也不错,但是现在都流行IDEA了,所以站长也只好顺应时代发展的潮流。
IDEA有个好处就是自动集成了Maven,不用再另外单独配置maven了,而且maven下载的速度也是很快的。
2.快速搭建自己的第一个服务
这里创建一个包,叫controller,代表控制器的意思。然后在里面新建一个ViewController,代表视图控制器。
代码如下:
package com.java18.vipmgr.controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
@Controller
public class ViewController {
@RequestMapping("hello")
@ResponseBody
public String Hello(){
return "Hello SpringBoot!";
}
}
重新启动项目,即运行这个类:
浏览器访问:http://localhost:8080/hello
即可看到:
成功访问了控制器。
3.springboot 读取 yml 配置的几种方式
- yml文件的好处,天然的树状结构,一目了然,实质上跟properties是差不多的。
- 不支持tab缩进
- 可以使用 "-小写字母" 或 "_小写字母"来 代替 "大写字母",如 userName 与 user-name ,user_name 含义是一样的
key: value 格式书写
key 后面跟着冒号,再后面跟着一个空格,然后是值
几种数据格式的表示方式
- 1.普通的值(数字,字符串,布尔)
- 2.对象、Map (属性和值) (键值对)
- 3.数组 (List、Set)
普通的值(数字,字符串,布尔)
直接就是 key: value ,如:
age: 18
name: mysgk
注:
字符串默认不用加上单引号或者双引号;
"":双引号;不会转义字符串里面的特殊字符;特殊字符会作为本身想表示的意思
name: "zhangsan \n lisi":输出;zhangsan 换行 lisi
'':单引号;会转义特殊字符,特殊字符最终只是一个普通的字符串数据
name: ‘zhangsan \n lisi’:输出;zhangsan \n lisi
对象、Map(属性和值)(键值对)
对象还是k: v的方式
k: v:在下一行来写对象的属性和值的关系;注意缩进(不支持tab,使用空格),如:
person:
age: 18
name: mysgk
数组(List、Set)
用- 值表示数组中的一个元素,如:
hands:
- left
- right
如果我们只需要配置文件中的一两个值,@Value 是最简单方便的方式.
server:
port: 8081
我们在代码中可以这样取值
@Value("${server.port}")
public String port;
注:此处的prot 所在的类需要是一个组件,如果是实体类需要加上@Component
如果需要一个JavaBean 来专门映射配置的话,我们一般会使用@ConfigurationProperties来读取.
student:
age: 18
name: mysgk
javabean:
@Component
@ConfigurationProperties(prefix = "student")
public class Student {
private String name;
private Integer age;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Integer getAge() {
return age;
}
public void setAge(Integer age) {
this.age = age;
}
@Override
public String toString() {
return "Student{" +
"name='" + name + '\'' +
", age=" + age +
'}';
}
}
使用@ConfigurationProperties,需要配置一个prefix (前缀) 参数, 即写上 key 就可以了.
第三种读取方式@Environment
这种方法好像用的比较少,基本没用过...
test:
msg: aaa
代码:
@Autowired
private Environment env
@RequestMapping(value = "index2", method = RequestMethod.GET)
public String index2() {
System.out.println(env.getProperty("test.msg"));
return "The Way 2 : "+ env.getProperty("test.msg");
}
}
验证1.@Value方式
在启动类同级目录添加一个pojo包,里面新建一个Cat类。
创建application.yml文件
Cat类结构如下
public class Cat {
private String name;
private int sex;
private List<String> hobbies;
}
对应的yml配置文件
cat:
name: 机器猫
sex: 1
hobbies:
- 吃铜锣烧
- 和小咪聊天
- 用竹蜻蜓飞天
给Cat类加上自动注入
@Component
public class Cat {
@Value("${cat.name}")
private String name;
@Value("${cat.sex}")
private int sex;
private List<String> hobbies;
@Override
public String toString() {
return "Cat{" +
"name='" + name + '\'' +
", sex=" + sex +
", hobbies=" + hobbies +
'}';
}
}
测试:
@SpringBootTest
class VipMgrApplicationTests {
@Autowired
Cat cat;
@Test
void contextLoads() {
System.out.println(cat);
}
}
结果:
Cat{name='机器猫', sex=1, hobbies=null}
list类型的用这种方式注入有点复杂,推荐下一种方式。
验证2 @ConfigurationProperties方式
@Component
@ConfigurationProperties(prefix = "cat" )
public class Cat {
private String name;
private int sex;
private List<String> hobbies;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getSex() {
return sex;
}
public void setSex(int sex) {
this.sex = sex;
}
public List<String> getHobbies() {
return hobbies;
}
public void setHobbies(List<String> hobbies) {
this.hobbies = hobbies;
}
@Override
public String toString() {
return "Cat{" +
"name='" + name + '\'' +
", sex=" + sex +
", hobbies=" + hobbies +
'}';
}
}
注意,这种方式一定要加上对应的get set方法,不然注入不了。
很明显,这种方式比@Value清爽太多了。
spring boot Configuration Annotation Proessor not found in classpath
上面那种方法,会提示这个错误
打开右上角的文档,又提示404,无语。
Springboot1.5以上版本,在使用 @ConfigurationProperties注解的时候会提示“Spring Boot Configuration Annotation Processor not found in classpath”,
这是因为新版本已经取消了对location的支持,替代方案是使用
@Configuration和@PropertySource进行组合使用,例如:
@Primary
@Configuration
@PropertySource(value = "classpath:application.properties", ignoreResourceNotFound = true)
如果要使用指定属性前缀”Prefix“,这时候还会使用到@ConfigurationProperties,提示依然会存在
解决办法是添加这个依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
</dependency>
然后maven -- reload,解决问题!
yml文件提供很多强大的特性,推荐使用。
1. 变量复用
就是在配置文件中用${xxx}调用其他变量,如
cat:
name: 机器猫
sex: 1
hobbies:
- 吃铜锣烧
- 和小咪聊天
- 用竹蜻蜓飞天
nameAndSex: ${cat.name},性别是${cat.sex}
增加nameAndSex属性
private String nameAndSex;
public String getNameAndSex() {
return nameAndSex;
}
public void setNameAndSex(String nameAndSex) {
this.nameAndSex = nameAndSex;
}
测试
@SpringBootTest
class VipMgrApplicationTests {
@Autowired
Cat cat;
@Test
void contextLoads() {
System.out.println(cat.getNameAndSex());
}
}
结果:机器猫,性别是1
2. 随机函数
yml文件中可生成很多随机数,如UUID,随机数字等。
例:
name: 机器猫${random.int[1,100]}
得到的就是这样的: 机器猫91,性别是1
3.设置默认值
cat:
name: 机器猫${random.int[1,100]}
#sex:
hobbies:
- 吃铜锣烧
- 和小咪聊天
- 用竹蜻蜓飞天
nameAndSex: ${cat.name},性别是${cat.sex:男}
sex被注掉了,${cat.sex:男}就代表如果sex没有,就默认是男。
SpringBoot自动配置原理
SpringBoot自动配置是指,很多组件SpringBoot已经帮你准备好了。哪怕你不配置,都是没问题的,因为已经帮你自动配置了。
如果你想要改变一些配置的属性,只需要在application.yml中进行修改即可。
比如,我现在要改一下启动的端口,只需要加上这句话。
server:
port: 8888
大家有没有想过一个问题,我们会这么写,是因为百度到了。大家写文章都是这么说的,随便一百度,就能百度到这个配置。
其实原理很简单,我们找到这个依赖。
里面有一个叫做spring.factories的文件,打开有惊喜。
发现里面有一大堆自动配置类,我们找到Server的配置类
org.springframework.boot.autoconfigure.web.servlet.ServletWebServerFactoryAutoConfiguration
里面有这么一个注解
@EnableConfigurationProperties({ServerProperties.class})
对应的属性配置类是ServerProperties:
这不就是上面讲的属性注入方式吗?所以,我们写server.port,就可以对应到这个属性配置类的port字段。
这下就很清楚了吧。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· .NET10 - 预览版1新功能体验(一)