Spring boot学习(一)开启Spring boot之旅

介绍

Spring boot 是基于Spring的一个全新的框架,它的目的是用来简化Spring应用的初始搭建以及开发过程。若是你之前使用过相似于SSM这种框架,你应该清楚要搭建一个SSM框架须要哪些步骤,Spring boot就简化甚至消除了这些步骤,你会发现你基本上什么都不用作,只须要考虑业务逻辑方面的代码就能够了,极大的节省了咱们的开发时间,这是一个用了就不想换的框架!css

文章首发于我的博客:【www.xiongfrblog.cnhtml

搭建一个简单的Spring boot应用

不一样的开发工具备不一样的方式,其中IDEA已经集成了Spring boot的插件,直接新建就能够了,eclipse须要本身安装插件才能使用。这里我就只介绍经过http://start.spring.io/ 来构建一个Spring boot项目。java

生成项目文件

访问http://start.spring.io/ ,出现下面的页面:web

在这里插入图片描述

从图中能够看到默认是经过Maven构建项目,而且使用Java语言,Spring boot使用2.1.2版本,这些咱们根据本身实际需求更改,我这里就使用默认的,接下来完善页面信息,因为咱们只是搭建一个简单的Spring boot项目Demo,这里全部的信息使用默认的便可。点击页面上的 Switch to the full version,出现更多的配置以及让咱们选择的依赖项,配置咱们不用管,勾选上web依赖就能够了,以下图:spring

在这里插入图片描述

最后咱们点击generate project按钮生成项目文件,文件是一个压缩包,选择保存的路径下载到本地。后端

导入到开发工具

将咱们上一步下载的压缩包解压,而后以Maven项目的形式导入到咱们使用的开发工具中(我这里使用的eclipse),这个步骤可能会须要一下子时间,耐心等待便可,项目导入成功后项目的结构以下:浏览器

在这里插入图片描述

会发如今src/main/java目录下的com.example.demo包下为咱们生成了一个DemoApplication.java的文件,这是咱们项目的入口类,名字是按ArtifactId+Application的命名规则生成的。springboot

src/main/resources目录下生成了application.properties配置文件,之后项目有关的配置都写在这个文件里边。bash

src/main/resources目录下还为咱们建立了statictemplates文件夹(若是没有,也不用担忧,须要的时候本身手动添加便可,这里应该是根据咱们选择的Spring boot版本以及依赖有关)。static文件夹通常用来存放项目中的静态资源文件例如:css样式,js脚本,图片等,templates文件夹通常用来存放html文件,Spring boot为咱们建立这些文件夹的缘由下面会详细说明,这里只简单介绍。app

在根目录下生成了pom.xml文件,该文件是Maven管理项目依赖的文件。

重要的文件就这些,之后随着项目功能的增长还会本身添加一些文件,这里不作过多介绍。

简单演示

首先咱们在com.exanple.demo包下边新建一个controller包(注意包名统一小写),在该包下新建DemoController.java文件,文件内容以下:

package com.example.demo.controller;

import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

/** * @author Promise * @createTime 2019年1月13日 下午5:15:45 * @description */
@RestController
public class DemoController {

	@RequestMapping("/hello")
	public String hello() {
		return "Hello World!";
	}
}
复制代码

此时项目结构以下:

在这里插入图片描述

接下来须要启动项目,上边说过Spring boot为咱们自动生成了一个启动类DemoApplication.java咱们只须要右键点击该启动类,选择Run as 再选择Java Application便可,如图:

在这里插入图片描述

控制台打印出以下日志说明启动成功:

在这里插入图片描述

从日志看出启动端口为8080,此时打开浏览器访问localhost:8080/hello或者127.0.0.1:8080/hello便可出现以下内容:

在这里插入图片描述

到这一步,一个简单的Spring boot项目就完成了,是否是很简单呢。

访问页面

实际的web项目中咱们老是会访问html页面,那么在Spring boot中怎么访问页面呢?下面来介绍建立Spring boot的第一个页面index.html

在上面介绍过的src/main/resources目录下新建一个文件夹public,在public文件夹下新建index.html,内容以下(随便写都行):

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
		<h1>This is my first page!</h1>
</body>
</html>
复制代码

按照上边的步骤从新启动项目,必定要从新启动,此时咱们尚未配置Spring boot的热部署功能,Spring boot不会为咱们自动加载更新的内容,须要咱们手动启动,启动成功后,访问localhost:8080或者127.0.0.1:8080出现以下内容说明访问成功:

在这里插入图片描述

至此,咱们已经经过Spring boot成功访问到第一个页面了,到这里,细心的小伙伴也许会发现,上边我说过src/main/resources下的templates文件夹是用来存放html文件的,为何咱们这里要将index.html放在public文件夹下呢?

注意

由于这里咱们没有使用例如thymeleafFreeMakerVelocityJSP等模板引擎,因此咱们的html文件必须按照Spring boot的约定放在特定的目录下,例如public。可是在实际的项目中(先后端分离项目除外)咱们通常都会选择一个模板引擎来渲染页面数据以及作一些逻辑判断,好比笔者用的就是thymeleaf,项目中的html文件通常都放在templates目录下。

约定大于配置

Spring boot中有不少约定俗成的配置须要咱们遵照,否则会有很糟糕的体验,正所谓约定大于配置

  1. Spring boot默认提供静态资源目录位置需置于classpath下,即上面说的src/main/resources目录下,而且静态资源存放的目录必须符合如下规则(目录名字不能随意更改):
  • /META-INF/resources
  • /resources
  • /static
  • /public

而且他们的优先级从高到低,即/META-INF/resources>/resources>/static>/public,在访问静态资源时,Spring boot会按照优先级从上面的目录中寻找,验证这一点很简单,上边咱们在public目录下新建了index.html文件,如今咱们在static目录下一样新建index.html文件,写不一样的内容,重启项目,再次访问localhost:8080或者127.0.0.1:8080你会发现此时显示的就是static目录下的index.html文件中的内容。

  1. Spring boot默认的配置文件必须是,也只能是application或application-xxx命名的yml文件或者properties文件,固然咱们也能够本身建立额外的配置文件,但须要其余的配置,之后会介绍,这里不作过多概述。
  2. 在yml文件或者properties文件中配置Spring boot的某些功能时,必须指定特定变量的值,好比咱们想要修改项目启动的端口为1188,须要在properties配置文件中写入:
server.port=1188
复制代码

在yml文件中则是:

server: 
 port: 1188
复制代码

正是这些约定使得Spring boot变得如此简单。

结语

好了,到这里相信你已经对Spring boot有了一个大概的了解,关于Spring boot的更多内容博主会继续更新,bye~

相关文章
相关标签/搜索