spring boot 基础框架组合起来,给开发者提高了效率且不用一一配置。
下面简单展示应用创建详细过程
-
使用idea创建
创建成功后
@SpringBootApplication
public class PrenApplication {
public static void main(String[] args) {
SpringApplication.run(PrenApplication.class, args);
}
}
这里主要关注@SpringBootApplication注释,它包括三个注释:
@Configuration:表示将该类作用springboot配置文件类。
@EnableAutoConfiguration:表示程序启动时,自动加载springboot默认的配置。
@ComponentScan:表示程序启动是,自动扫描当前包及子包下所有类。
-
新建 HelloApplication 类
- 我们只看红色框的地方
给类增加 @RestController 注释
相当于@Controller+@ResponseBody两个注释的结合,返回json数据不需要在方法前面加@ResponseBody注释了,但使用@RestController这个注释,就不能返回jsp,html页面,视图解析器无法解析jsp,html页面 - *学习spring学习注释很重要
在类中建立下面的代码
@RequestMapping(value="/hello" ,method=RequestMethod.GET)
public String say()
{
return "hello word";
}
浏览器中输入 http://127.0.0.1:8080/hello
hello word
@RequestMapping 这个注释会将 HTTP 请求映射到 MVC 和 REST 控制器的处理方法上,注释可以在控制器类的级别和/或其中的方法的级别上使用。
- resources下面配置文件
新建一个 application.yml 文件 内容如下图
在启动时候会自动加载 properties 和 yml文件,这里有优先级
application.yml 和 application.properties 两个文件的优先级
会优先加载 properties 文件内容 比如 2个文件都设置了
properties server.port =8085
yml server.port = 8081
会加载8085端口 后面的是摆设
上图中的类 有个 注释 @Value("${name}") 其实读取上一个图中配置文件里的 name的数据,我们在浏览器中看下
guojing正是我们配置文件里的内容,同样下图中
- 自动装配讲解
@Autowired 注释,它可以对类成员变量、方法及构造函数进行标注,完成自动装配的工作。 通过 @Autowired 的使用来消除 set ,get方法。在使用@Autowired之前,我们对一个bean配置起属性时,是这用用的
<property name="属性名" value=" 属性值"/>
我们先看2个图 4-1 ,4-2,4-3
图4-1
图4-2
图4-3
在application中添加 加载dev文件 否则dev不会被加载
spring:
profiles:
active: dev #注意这 : 中间有空格
注释 @ConfigurationProperties(prefix = "person")可以把同类的配置信息自动封装成实体类 图4-3中 person 中 name 和 age
通过图4-1 @Autowired 注释
浏览器中如下图
这里注意:
- 类中的方法名必须要和 配置文件中的名称一样 否则失效,但不影响整体类的使用。
-
数据库(当前只介绍了最简单的使用)
介绍前先看图 5-1图
pom.xml 文件中需要添加
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.34</version>
</dependency>
考虑到兼容性这里我使用了低一点的mysql驱动,因为测试机器有5.7版本和5.0版本
5-1图 配置 主要说下
jpa.hibernate.ddl-auto: 有五个属性
ddl-auto:create----每次运行该程序,没有表格会新建表格,表内有数据会清空
ddl-auto:create-drop----每次程序结束的时候会清空表
ddl-auto:update----每次运行程序,没有表格会新建表格,表内有数据不会清空,只会更新
ddl-auto:validate----运行程序会校验数据与数据库的字段类型是否相同,不同会报错
ddl-auto:none----运行程序什么不操作
show-sql:true 打印sql语句
5-2
对这个注释网上找了一段比较想详细
@Entity注释指名这是一个实体Bean,@Table注释指定了Entity所要映射带数据库表,其中@Table.name()用来指定映射表的表名。
如果缺省@Table注释,系统默认采用类名作为映射表的表名。实体Bean的每个实例代表数据表中的一行数据,行中的一列对应实例中的一个属性。
@Column注释定义了将成员属性映射到关系表中的哪一列和该列的结构信息,属性如下:
1)name:映射的列名。如:映射tbl_user表的name列,可以在name属性的上面或getName方法上面加入;
2)unique:是否唯一;
3)nullable:是否允许为空;
4)length:对于字符型列,length属性指定列的最大字符长度;
5)insertable:是否允许插入;
6)updatetable:是否允许更新;
7)columnDefinition:定义建表时创建此列的DDL;
8)secondaryTable:从表名。如果此列不建在主表上(默认是主表),该属性定义该列所在从表的名字。
@Id注释指定表的主键,它可以有多种生成方式:
1)TABLE:容器指定用底层的数据表确保唯一;
2)SEQUENCE:使用数据库德SEQUENCE列莱保证唯一(Oracle数据库通过序列来生成唯一ID);
3)IDENTITY:使用数据库的IDENTITY列莱保证唯一;
4)AUTO:由容器挑选一个合适的方式来保证唯一;
5)NONE:容器不负责主键的生成,由程序来完成。
@GeneratedValue注释定义了标识字段生成方式。
@Temporal注释用来指定java.util.Date或java.util.Calender属性与数据库类型date、time或timestamp中的那一种类型进行映射。
@Temporal(value=TemporalType.TIME)
运行我们的程序会在数据库中创建一个表