SpringBoot入门之工程搭建(IDEA版)
**Spring-Boot Spring的春天**在之前我们一直使用Spring、SpringMVC进行开发,的确,Spring让我们认识到了项目开发原来可以这么方便。但是大量的配置文件却是令人头痛的,即使我们想写一个简单的请求映射并在浏览器上发送Get请求测试,那么需要:1.在web.xml中配置DispatcherServlet; 2.在application.xml中配置注解扫描、注解驱动。可以看到:虽然Spring是轻量级的,但是Spring的配置却是重量级的。并且搭建每个Spring项目我们都需要考虑依赖版本是否冲突的问题...
So,SpringBoot将这一切都解决了。SpringBoot提供了一种固定的、约定优于配置风格的框架,让开发者能更快的创建基于Spring的应用程序和服务。
对应的SpringBoot整合Mybatis实现CRUD的项目和笔记请看我的Github仓库:[教你优雅的入门Spring Boot框架](https://github.com/TyCoding/spring-boot)
**如果觉得不错就点击右上角star鼓励一下笔者吧(#^.^#)**
**SpringBoot**有如下特性:
1. 更高效的创建基于Spring的应用服务
2. 无需XML配置,可以修改默认值来满足特定的需求
3. 提供了一些大型项目中常见的非功能性特性,如嵌入式服务器、安全...
4. Spring Boot并不是对Spring功能上的增强,而是提供了一种快速使用Spring的方式
# SpringBoot项目搭建
**这里我选择使用IDEA来创建SpringBoot项目**:
> 1.选择Spring Initializr,并选择本地的JDK版本
!(http://upload-images.jianshu.io/upload_images/12613204-b6eda10871ce2c70.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
> 2.Next,指定Group和Artifact名称,并选择本机JDK版本
!(http://upload-images.jianshu.io/upload_images/12613204-70d4d0f9e72a3391.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
> 3.选择项目所需依赖
!(http://upload-images.jianshu.io/upload_images/12613204-42b92f9b59cb010a.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
**解释**
`devtools`: SpringBoot提供的热部署插件,可以避免每次修改代码都要重新启动项目。。
`lomback`: 使用Lomback可以减少项目中很多重复代码的书写,比如getter/setter/toString等方法的书写(虽然这些可能我们都是用的快捷键生成的代码)。具体用法可以参考博文:(https://blog.csdn.net/motui/article/details/79012846)
`Thymeleaf`: 语法的支持
**注意:** 以上依赖非必选,如果仅仅想尝试一下Spring Boot-HelloWorld,只需要选择其中的`web`依赖即可。
<br/>
# SpringBoot起步
!(http://upload-images.jianshu.io/upload_images/12613204-78ac42dc178c155c.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
以上是新创建的Spring Boot项目。在SpringBoot中有一个启动器(引导类)的概念,我们首先看一下`SpringbootApplication.java`:
```java
@SpringBootApplication
public class SpringbootApplication {
public static void main(String[] args) {
SpringApplication.run(SpringbootApplication.class, args);
}
}
```
如上,仅是一个简单的main方法,其中最核心的就是`@SpringBootApplication`注解,它是一下三个注解的总和:
1. `@Configuration`: 用于定义一个配置类。
2. `@EnableAutoConfiguration`: SpringBoot会自动根据你的jar包依赖来自动配置项目。
3. `@ComponentSacn`: 告诉Spring哪个packages的用注解标识的类会被Spring自动扫描并且转入Bean容器。
通过以上三个注解你就应该了解到了SpringBoot的作用:自动化配置项目。之前我们要手动进行的XML配置在这里仅需要这一个注解就完成了。且SpringBoot项目不需要单独部署到Tomcat中才能启动,通过这个启动器,SpringBoot会自动构建一个web容器,并将项目部署到其中。
So,
```
Run SpringBootApplication
```
!(http://upload-images.jianshu.io/upload_images/12613204-332bce9039c15b07.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
发现报错,说`DataSource`数据源的url地址没有配置。之前我们提到了SpringBoot的特性就是自动化配置,它会根据你的依赖文件来配置项目,我们再看一下我们的`pom.xml`:
!(http://upload-images.jianshu.io/upload_images/12613204-2cb144052461292e.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
其中最上层的`<parent>`节点约束了整个下面所有spring-boot依赖的版本,即这里使用了SpringBoot-2.0.5。然后关注`<dependencies>`节点下的前四个依赖:
```xml
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>1.3.2</version>
</dependency>
```
**Spring Boot应用启动器**
`spring-boot-starter`: Spring Boot的核心启动器,包含了自动配置、日志和YAML。
`spring-boot-starter-jdbc`: 支持JDBC数据库。
`spring-boot-starter-thymeleaf`: 支持Thymeleaf模板引擎,包括与Spring的集成。
`spring-boot-starter-web`: 支持全栈式开发,包括Tomcat和Spring-WebMVC。
`mybatis-spring-boot-starter`: 整合spring-mybatis依赖。
前面我们强调的一点是Spring Boot能实现自动化配置,那么项目的依赖就决定了Spring Boot将如何自动配置项目,Spring Boot的启动器就决定了项目会以什么样的配置启动项目;如此,我们会明白这个报错是为什么了。
因为我们配置配置JDBC连接的数据库,所以报错,注释掉`spring-boot-starter-jdbc`和`mybatis-spring-boot-starter`依赖,再次启动`SpringBootApplication`:
!(http://upload-images.jianshu.io/upload_images/12613204-4599bd536781e87e.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
启动成功。
## 测试
在`src/main/java/cn/tycoding/springboot/`下创建`controller`文件夹并创建`LoginController.java`类:
```java
@RestController
public class LoginController {
@RequestMapping("/login")
public String login(@RequestParam("username") String username, @RequestParam("password") String password) {
System.out.println("username:" + username + ", password:" + password);
return null;
}
}
```
如上就完成了在SSM阶段一个最基本的SpringMVC Controller映射方法的书写,那么测试一下:
在浏览器上访问:
```
localhost:8080/login?username=tycoding&password=123
```
后端即可接收到username和password参数。
这时你会发现,SpringBoot内置的Web容器默认访问地址就是8080端口,如果想改变这个默认端口,修改`src/main/resources/application.properties`:
```xml
server.port=8088
```
重启`SpringbootApplication`,访问:`localhost:8088/login?username=tycoding&password=123`
## 读取配置文件信息
在`src/main/resources/application.properties`中添加配置:
```
url=http://www.tycoding.cn
```
在`LoginController.java`中添加映射方法:
```java
@RestController
public class LoginController {
@Autowired
private Environment environment;
@RequestMapping("/blog")
public String login(){
return environment.getProperty("url");
}
}
```
Spring提供的`Environment`类用户读取配置文件中参数,访问:`localhost:8088/blog`即可得到。 谢谢分享 正在学习 谢谢分享
不错的细致教程,谢谢楼主分享教程 不错,有时间了学习一下。 谢谢分享 非常不错的一个简单实例说明:lol 谢谢共享
页:
[1]