这篇文章主要介绍一下springboot入门项目的创建基本步骤,这里采用的是IDEA编译器maven工程创建的。编辑器界面new一个空项目就可以了,在maven工程的pom.xml添加如下依赖
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.6.RELEASE</version>
</parent>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
</dependencies>
先建立一个Java代码类,编写一个HelloControlle,
@RestController
public class HelloController {
@GetMapping(“show”)
public String test(){
return “hello Spring Boot!”;
}
接着在项目结构中文件夹resources中创建一个application.yml文件,添加代码如下:
@SpringBootApplication
public class TestApplication {
public static void main(String[] args) {
SpringApplication.run(TestApplication.class, args);
} }
因为没有配置端口,默认就是8080,此时我们来浏览器访问一下:输入localhost:8080/show,显示如下:
这里解释一下@RestController和@SpringBootApplication两个注解,这两个都是组合注解:@RestController包括@ResponseBody + @Controller合在一起的作用。简单来说使用@RestController返回的就是return里面的内容,如上图**return “hello Spring Boot!”;**而如果需要返回到指定页面,则需要用 @Controller,
例如:return “user”则是对应resources文件夹下面的user.html页面
@SpringBootApplication包含的注解则是较多的,有兴趣可以翻阅源码看看,这里说一下重点的三个:
- @SpringBootConfiguration
- @EnableAutoConfiguration:开启自动配置
- @ComponentScan:开启注解扫描
这里基本上springboot入门程序就创建并且运行完成了。
接下来说说springboot整合ssm框架。这里我们采用的是mysql数据库以及Thymeleaf模板引擎。这里说明一下,由于springboo并不支持JSP,并且 Thymeleaf 是一个跟 Velocity、FreeMarker 类似的模板引擎,它可以完全替代 JSP 。相较于其他的模板引擎,它有如下四个极吸引人的特点:
- 动静结合:Thymeleaf 在有网络和无网络的环境下皆可运行,即它可以让美工在浏览器查看页面的静态效果,也可以让程序员在服务器查看带数据的动态页面效果。这是由于它支持html 原型,然后在 html 标签里增加额外的属性来达到模板+数据的展示方式。浏览器解释 html 时会忽略未定义的标签属性,所以
thymeleaf 的模板可以静态地运行;当有数据返回到页面时,Thymeleaf 标签会动态地替换掉静态内容,使页面动态显示。- 开箱即用:它提供标准和spring标准两种方言,可以直接套用模板实现JSTL、 OGNL表达式效果,避免每天套模板、改jstl、改标签的困扰。同时开发人员也可以扩展和创建自定义的方言。
- 多方言支持:Thymeleaf 提供spring标准方言和一个与 SpringMVC 完美集成的可选模块,可以快速的实现表单绑定、属性编辑器、国际化等功能。
- 与SpringBoot完美整合,SpringBoot提供了Thymeleaf的默认配置,并且为Thymeleaf设置了视图解析器,我们可以像以前操作jsp一样来操作Thymeleaf。代码几乎没有任何区别,就是在模板语法上有区别。
这里我们建立一个通用mapper接口和实体类User,如图:
userMapper代码如下:
package cn.itcast.mapper;
import cn.itcast.pojo.User;
import org.apache.ibatis.annotations.Mapper;@Mapper
public interface UserMapper extends
tk.mybatis.mapper.common.Mapper{ }
User实体类代码如下:
package cn.itcast.pojo;
import javax.persistence.GeneratedValue; import
javax.persistence.GenerationType; import javax.persistence.Id; import
javax.persistence.Table; import java.util.Date;@Table(name = “tb_user”) public class User {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;private String username; private String password; private String phone; private Date created; private String salt;
这里需要注意的是**@Table(name = “tb_user”)** 中tb_user代表的是mysql数据库中的表,
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)表示表主键是id,get和set用idea自己生成即可。同时user类中定义的字段必须和数据库一致。
接下来看看业务层和视图层的代码,先建立两个类Usercontroller和UserService如图:
分别看看两个类代码UserController:
@Controller
@RequestMapping(“user”)
public class UserController {
@Autowired
private UserService userService;
@GetMapping(“all”)
public String queryAll(ModelMap model){
List users = this.userService.queryAll();
model.addAttribute(“users”,users);
return “users”;
} }
UserService:
@Service
public class UserService {
@Autowired
private UserMapper userMapper;
public List queryAll() {
return this.userMapper.selectAll();
} }
到这步,视图层,业务层和持久层代码基本就完成了,剩下就是连接数据库的配置文件和编写html页面就好了。
分别在resources下建立一个配置文件application.properties和文件夹templates,templates下放置的就是html文件,也就是访问浏览器渲染的页面。需要注意的是html页面的名字必须和UserController返回值一致。配置文件及html代码如下:
application.properties:
spring.datasource.url=jdbc:mysql://localhost:3306/****
spring.datasource.username=****
spring.datasource.password=****
#指向pojo下的User实体类
mybatis.type-aliases-package=cn.itcast.pojo
#开发阶段关闭thymeleaf模板缓存
spring.thymeleaf.cache=false
user.html
启动项目访问浏览器,渲染页面如下:
最后附上整个项目的依赖,
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.6.RELEASE</version>
</parent>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>1.3.2</version>
</dependency>
<dependency>
<groupId>tk.mybatis</groupId>
<artifactId>mapper-spring-boot-starter</artifactId>
<version>2.0.2</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>
</dependencies>