IDEA下从零开始搭建SpringBoot工程

(1)它是Spring的升级版,Spring容器能作到的事情,它都能作到,并且更简便,从配置形式上来讲,SpringBoot彻底抛弃了繁琐的XML文件配置方式,而是替代性地用注解方式来实现,虽然本质来讲,是差很少的(相似包扫描,注解扫描,类加载之类)。 
(2)SpringBoot集成的插件更多,从而使用不少服务,都只是引入一个依赖,几个注解和Java类就能够用了,具体的参考相关手册。 
(3)在Web应用开发这一块,以前的应用通常来讲是打包成war包,再发布到相关服务器容器下(例如Tomcat),虽然SpringBoot也能够这么作,但在SpringBoot下更常见的形式是将SpringBoot应用打包成可执行jar包文件。之因此这么作,源于你能够直接将SpringBoot应用当作是一个Java Application,其Web应用能够没有webapp目录(更不用说web.xml了),它推荐使用html页面,并将其做为静态资源使用。 
下面具体记录一下,如何在IDEA下从零开始,一步步搭建SpringBoot Web应用,这里采用的是maven做依赖管理,新手起步,有任何疑问,请参考SpringBoot官网。 
须要说明的是SpringBoot依赖的JDK版本为1.8及以上。 
(1)File->new,选择maven,建立一个空项目,直接next. 
这里写图片描述
(2)填写工程名 
这里写图片描述
(3)next到底,成果建立一个基于maven的空Java项目,其目录结构是这样的: 
这里写图片描述
(4)在pom文件中引入SpringBoot相关依赖css

<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>1.5.1.RELEASE</version>
</parent>
<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
</dependencies>

(5)新建一个controller 包,用于存放全部的controller,这里跟官方的同样,使用SampleController为第一个测试用例。代码以下:html

/**
 *
 * 官方示例工程中的测试代码
 */
@Controller
@EnableAutoConfiguration
public class SampleController {
    @RequestMapping("/")
    @ResponseBody
    String home() {
        return "Hello World!";
    }

    public static void main(String[] args) throws Exception {
        SpringApplication.run(SampleController.class, args);
    }
}

注意到,这里有一个main函数,再联想到前面说的,SpringBoot应用通常是打包成可执行jar包来发布的,这个main函数就是整个项目的入口。而之因此能这么作,是由于SpringBoot连Tomcat8做为一个插件都集成进去了,因此就没必要跟以前的SSM架构下同样,还须要去在Tomcat下配置war包才能运行。直接点击运行该main函数,再浏览器连接栏,输入地址http://localhost:8080/,就能够看到打印的字符串”Hello World!”了。这就是官网提供的一个最基本的基于SpringBoot的Web应用,如此便捷。 
固然,一个基本的Web应用,结构确定不会这么简单。下面要说的是,如何在上面的基础上,搭建一个具备MVC结构的完整的Web应用,其中数据库采用的是Mysql,ORM采用的是Spring Data JPA,前端页面采用js+html5。(固然还有其余的方式,例如ORM框架采用mybatis等,本文暂未涉及。) 前端

启动成功html5

    
(6)在resource目录下新建一个application.properties文件(或yml文件),命名与位置为SpringBoot默认的配置文件。在该文件中,记录着全部的模块配置内容。例如Tomcat的端口(默认8080)以及编码方式等:java

server.port=8080
server.tomcat.uri-encoding=utf-8

(7)引入本项目中所须要的相关依赖(MySQL链接驱动 以及Spring Data JPA,thymeleaf模板引擎)mysql

<!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.39</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-thymeleaf -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-thymeleaf</artifactId>
            <version>1.4.0.RELEASE</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/org.springframework.data/spring-data-jpa -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jpa</artifactId>
            <version>1.5.1.RELEASE</version>
        </dependency>

(8)在application.properties中配置MySQL数据库链接信息 
这里的数据库为本地数据库test,用户名和密码改为本身的jquery

#MySQL
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/test?characterEncoding=utf8
spring.datasource.username=****
spring.datasource.password=****

(9)在application.properties中配置Spring Data JPA 
这一段的意思就是说,数据库类型为MYSQL,日志信息打印具体执行的sql语句,表更新策略以及Java类到数据库表字段的映射规则等,具体查看网络资料。web

#Spring Data JPA
spring.jpa.database=MYSQL
spring.jpa.show-sql=true
spring.jpa.hibernate.ddl-auto=update
# Naming strategy
spring.jpa.hibernate.naming-strategy = org.hibernate.cfg.ImprovedNamingStrategy
# stripped before adding them to the entity manager)
spring.jpa.properties.hibernate.dialect = org.hibernate.dialect.MySQL5Dialect

(10)编写一个实体类User 
@Table标签,指定数据库中对应的表名,id配置为主键,生成策略为自动生成spring

/**
 * 
 * Model 用户
 */
@Entity
@Table(name = "tbl_user")
public class User {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private long id;

    private String name;

    private String password;
}

(11)基于JPA,实现DAO层(即数据库数据的增删改查操做) 
新建UserRepositoty.java接口文件,源代码以下:sql

package com.test.dao;

import com.test.model.User;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Query;
import org.springframework.data.repository.query.Param;

public interface UserRepositoty extends JpaRepository<User,Long> {


    @Query("select t from User t where t.user_name = :name")
    User findByUserName(@Param("name") String name);



}

须要解释的是,Spring Data JPA提供了不少持久层接口,例如Repository,CrudRepositoty,PagingAndSortingRepository 以及JpaRepository 接口。其中Repository为基类,JpaRepository继承自PagingAndSortingRepository接口,两个泛型参数分别表明Java POJO类以及主键数据类型。咱们建立本身的数据库操做接口时,只需继承上述JPA提供的某个接口,便可自动继承相关数据操做方法,而不须要再次实现。例如CrudRepositoty提供了对增删改查操做的实现,PagingAndSortingRepository提供了分页查询方法的实现。另外JPA提供了一套命名规则例如readBy**()等,这些方法也只须要用户申明而由JPA自动实现了。若是这仍不能知足业务需求,也能够自定义SQL查询语句,例如上述代码所示,采用@Query标签, 其中 :*语法为引用下面用@Param标识的变量,须要注意的是其中User不是表面而是Java POJO类名。具体使用参考JPA使用手册。 
(12)设计Service层业务代码 
新建UserService类,其源代码以下:

/**
 * 
 * User业务逻辑
 */
@Service
public class UserService {
    @Autowired
    private UserRepositoty userRepositoty;

    public User findUserByName(String name){
        User user = null;
        try{
            user = userRepositoty.findByUserName(name);
        }catch (Exception e){}
        return user;
    }
}

(13)设计Controller层 
新建UserController.java,提供两个接口,/user/index 返回页面,/user/show返回数据。其源代码以下:

/**
 * 
 * User控制层
 */
@Controller
@RequestMapping(value = "/user")
public class UserController {
    @Autowired
    private UserService userService;

    @RequestMapping(value = "/index")
    public String index(){
        return "user/index";
    }

    @RequestMapping(value = "/show")
    @ResponseBody
    public String show(@RequestParam(value = "name")String name){
        User user = userService.findUserByName(name);
        if(null != user)
            return user.getId()+"/"+user.getName()+"/"+user.getPassword();
        else return "null";
    }
}

(14)在application.properties文件中配置页面引擎。这里采用SpringMVC(SpringBoot还提供thymeleaf,freemaker等)。这里须要配置其静态资源(js、css文件、图片文件等)路径,以及html页面文件路径,参考SpringMVC在Spring下的配置。

#视图层控制
spring.mvc.view.prefix=classpath:/templates/
spring.mvc.view.suffix=.html
spring.mvc.static-path-pattern=/static/**

(15)在resource目录下新建templates以及static目录,分别用于存放html文件以及(js、css文件、图片)文件。在(13)中返回了一个“user/index”页面,因此在templates下新建user目录,在user目录下新建index.html页面,这里就不写什么了,默认页面,经过相对路径引入js文件,js文件里只作示意,弹出一个alert()。 
user/index.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8"/>
    <script src="../static/scripts/jquery.min.js"></script>
    <script src="../static/scripts/test.js"></script>
    <title>Title</title>

</head>
    <h1>TEST PAGE</h1>
<body>

</body>
</html>

static/scripts/test.js

$(document).ready(function (){
    alert("OK TEST");
});

(16)配置JPA 
新建一个configuration包,用于存放项目配置类。相似SSM架构下,spring须要配置Java POJO类包路径以及DAO层接口路径,以自动扫描相关注解,这里一样须要配置这两项,不一样的是Spring采起的是xml配置方式,这里用Java代码+注解方式配置。新建一个JpaConfiguration.java类,其代码以下:

package com.test.configuration;

import org.springframework.boot.autoconfigure.domain.EntityScan;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.core.Ordered;
import org.springframework.core.annotation.Order;
import org.springframework.dao.annotation.PersistenceExceptionTranslationPostProcessor;
import org.springframework.data.jpa.repository.config.EnableJpaRepositories;
import org.springframework.transaction.annotation.EnableTransactionManagement;

/**
 *
 * JPA 配置类
 */
@Order(Ordered.HIGHEST_PRECEDENCE)
@Configuration
@EnableTransactionManagement(proxyTargetClass = true)
@EnableJpaRepositories(basePackages = "com.test.dao")
@EntityScan(basePackages = "com.test.model")
public class JpaConfiguration {
    @Bean
    PersistenceExceptionTranslationPostProcessor persistenceExceptionTranslationPostProcessor(){
        return new PersistenceExceptionTranslationPostProcessor();
    }
}

(17)配置项目启动入口 
到这一步就能够删掉(5)中官方示例给出的SampleController.java了,因为咱们的工程结构已经发生了改变,咱们须要告诉SpringBoot框架去扫描哪些包从而加载对应类,因此这里从新编写main函数。新建一个Entry.java类,其代码以下(其中@SpringBootApplication是一个复合注解,就理解为自动配置吧):

 

(18)运行main函数,访问http://localhost:8080/user/index 会显示测试页面,并弹出alert(),访问http://localhost:8080/user/show?name=**(数据表里存在的数据)会显示user信息。最终的工程文件结构以下: