Spring Boot项目搭建

1. 创建项目,在pom.xml中添加依赖配置



    spring-boot-starter-parent
    org.springframework.boot
    2.2.6.RELEASE



 
    1.8




    
        org.springframework.boot
        spring-boot-starter-web
    

2. 创建Application入口类

/**
 * spring boot工程都有一个启动引导类,这是工程的入口类
 * 并在引导类上添加@SpringBootApplication
 */
@SpringBootApplication
public class Application {
    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }
}

3. 创建处理器Controller

@RestController
public class HelloController {

    @RequestMapping(value = "/hello", method = RequestMethod.GET)
    public String hello(){
        return "Hello, Spring Boot!";
    }
}

4. 使用Java代码配置数据库连接池,并在处理器Controller中注入并使用

4.1 添加依赖



    com.alibaba
    druid
    1.1.23

4.2 创建数据库

4.3 创建配置数据库连接参数的配置文件(.properties)

jdbc.driverClassName=com.mysql.cj.jdbc.Driver
jdbc.url=jdbc:mysql://127.0.0.1:3306/springboot_test
jdbc.username=root
jdbc.password=HT408706th

4.4 编写配置类

@Configuration
@PropertySource("classpath:jdbc.properties")//指定配置文件路径
public class JdbcConfig {
    //从配置文件中读取配置项
    @Value("${jdbc.url}")
    String url;
    @Value("${jdbc.driverClassName}")
    String driverClassName;
    @Value("${jdbc.username}")
    String username;
    @Value("${jdbc.password}")
    String password;

    //注册数据源到IOC容器中
    @Bean
    public DataSource dataSource() {
        DruidDataSource dataSource = new DruidDataSource();
        dataSource.setDriverClassName(driverClassName);
        dataSource.setUrl(url);
        dataSource.setUsername(username);
        dataSource.setPassword(password);
        return dataSource;
    }
}

4.5将注册的DataSource注入处理器(测试是否配置成功)

@Autowired
private DataSource dataSource;

5. 使用@ConfigurationProperties实现Spring Boot配置文件配置项读取和应用

5.1 创建配置项类JdbcProperties类,在该类名上面添加@ConfigurationProperties;

/**
 * ConfigurationProperties从applicationp配置文件中读取配置项
 * prefix表示配置项的前缀
 * 配置项类中的类变量名必须要与前缀之后的配置项名称保持 松散绑定(相同)
 */
@ConfigurationProperties(prefix = "jdbc")
public class JdbcProperties {

    private String url;
    private String driverClassName;
    private String username;
    private String password;

    public String getUrl() {
        return url;
    }

    public void setUrl(String url) {
        this.url = url;
    }

    public String getDriverClassName() {
        return driverClassName;
    }

    public void setDriverClassName(String driverClassName) {
        this.driverClassName = driverClassName;
    }

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }
}
  • 5.1.1 添加依赖

    org.springframework.boot
    spring-boot-configuration-processor
    
    true

5.2 将jdbc.properties修改名称为application.properties;

5.3 将JdbcProperties对象注入到JdbcConfig;

@Configuration
@EnableConfigurationProperties(JdbcProperties.class)
public class JdbcConfig {
    @Bean
    public DataSource dataSource(JdbcProperties jdbcProperties) {
        DruidDataSource dataSource = new DruidDataSource();
        dataSource.setDriverClassName(jdbcProperties.getDriverClassName());
        dataSource.setUrl(jdbcProperties.getUrl());
        dataSource.setUsername(jdbcProperties.getUsername());
        dataSource.setPassword(jdbcProperties.getPassword());
        return dataSource;
    }
}

5.4 在方法上面使用@ConfigurationProperties;

@Configuration
public class JdbcConfig {
    @Bean
    @ConfigurationProperties(prefix = "jdbc")
    public DataSource dataSource() {
        return new DruidDataSource();
    }
}

6. springboot整合ssm

6.1 使用lombok插件对实体类进行简化

  • 6.1.1 安装lombok插件
  • 6.1.2 添加lombok对应的依赖
  • 6.1.3 改造实体类,使用lombok注解
/**
 * 在编译阶段会根据注解自动生成对应的方法;data包含get/set/hashCode/equals/toString等方法
 */
@Data
public class User {
    private Long id;
    private  String userName;
    private String password;
    private String name;
    private Integer age;
    private Integer sex;
    private Date birthday;
    private String note;
    private Date created;
    private Date updated;
}

6.2 springboot整合springmvc端口和静态资源

  • 6.2.1 修改项目Tomcat端口
#修改Tomcat端口
server.port=80
  • 6.2.2 springboot项目中静态资源可以放置在如下目录

{"classpath:/META-INF/resources/", "classpath:/resources/", "classpath:/static/", "classpath:/public/"};

6.3 在springboot项目中配置自定义springmvc拦截器

  • 6.3.1 编写拦截器(实现HandlerInterceptor)
@Slf4j
public class MyInterceptor implements HandlerInterceptor {
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        log.debug("这是MyInterceptor的preHandle方法");
        return true;
    }

    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        log.debug("这是MyInterceptor的postHandle方法");
    }

    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
        log.debug("这是MyInterceptor的afterCompletion方法");
    }
}
  • 6.3.2 编写配置类,实现WebMvcConfigurer,在该类中添加各种组件
@Configuration
public class MvcConfig implements WebMvcConfigurer {

    // 注册拦截器
    public MyInterceptor myInterceptor(){
        return new MyInterceptor();
    }

    // 添加拦截器到spring mvc拦截器
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(myInterceptor()).addPathPatterns("/*");
    }
}

6.4. springboot整合事务和连接池

  • 6.4.1 事务配置
    添加事务相关启动器依赖,mysql相关依赖


    org.springframework.boot
    spring-boot-starter-jdbc



    mysql
    mysql-connector-java

编写业务类UserService使用事务注解@Transactional

@Service
public class UserService {

    //根据id查询
    public User queryById(Long id){
        return new User();
    }

    //新增保存用户 添加事务注解
    @Transactional
    public void saveUser(User user){
        System.out.println("新增用户...");
    }
}
  • 6.4.2 数据库连接池hikari配置(hikari是springboot自带的默认数据库连接池)
    在application配置文件中指定数据库相关参数
#配置数据库连接池
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/springboot_test
spring.datasource.username=root
spring.datasource.password=root

6.5 springboot整合mybatis

  • 6.5.1 添加启动器依赖


    org.mybatis.spring.boot
    mybatis-spring-boot-starter
    2.0.1

  • 6.5.2 配置Mybatis:实体类别名包、日志、映射文件等
#配置mybatis
# 实体类别名包路径
mybatis.type-aliases-package=com.emar.pojo
# 映射文件路径
#mybatis.mapper-locations=classpath:mappers/*.xml
# 日志
mybatis.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl
  • 6.5.3 配置MappperScan
/**
 * spring boot工程都有一个启动引导类,这是工程的入口类
 * 并在引导类上添加@SpringBootApplication
 */
@SpringBootApplication
// 扫描mybatis所有的业务mapper接口
@MapperScan("com.emar.mapper")
public class Application {
    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }
}

6.6 springboot整合通用mapper

通用mapper可以实现自动拼接SQL语句;所有mapper都不需要编写SQL语句,提高开发效率。

  • 6.6.1 添加启动器依赖


    tk.mybatis
    mapper-spring-boot-starter
    2.1.5

  • 6.6.2 改造UserMapper集成Mapper
public interface UserMapper extends Mapper {
}
  • 6.6.3 修改启动引导类Application中的Mapper扫描注解
/**
 * spring boot工程都有一个启动引导类,这是工程的入口类
 * 并在引导类上添加@SpringBootApplication
 */
@SpringBootApplication
// 扫描mybatis所有的业务mapper接口
//@MapperScan("com.emar.mapper")
@MapperScan("com.emar.mapper")
public class Application {
    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }
}
  • 6.6.4 修改User实体类添加jpa注解
/**
 * 在编译阶段会根据注解自动生成对应的方法;data包含get/set/hashCode/equals/toString等方法
 */
@Data
@Table(name = "tb_user")
public class User {
    @Id
    //主键回填
    @KeySql(useGeneratedKeys = true)
    private Long id;

    //user_name --> userName,若数据库字段名和属性名不一致,可使用@Column注解
//    @Column(name = "adc")
    private  String userName;
    private String password;
    private String name;
    private Integer age;
    private Integer sex;
    private Date birthday;
    private String note;
    private Date created;
    private Date updated;
}
  • 6.6.5 改造UserService实现业务功能
@Service
public class UserService {

    @Autowired
    private UserMapper userMapper;

    //根据id查询
    public User queryById(Long id){
        return userMapper.selectByPrimaryKey(id);
    }

    //新增保存用户 添加事务注解
    @Transactional
    public void saveUser(User user){
        System.out.println("新增用户...");
        userMapper.insertSelective(user);
    }
}

7. springboot整合测试

7.1 改造HelloController,注入UserService利用其方法实现查询

@RestController
public class HelloController {

    @Autowired
    private DataSource dataSource;

    //注入业务对象
    @Autowired
    private UserService userService;

    /**
     * 根据用户id查询用户
     * @param id 用户id
     * @return 用户
     */
    @GetMapping("/user/{id}")
    public User queryById(@PathVariable Long id){
        return userService.queryById(id);
    }

    @RequestMapping(value = "/hello", method = RequestMethod.GET)
    public String hello(){
        System.out.println(dataSource);
        return "Hello, Spring Boot!";
    }
}

7.2 启动项目测试http://localhost/user/用户id

8. springboot整合Junit

8.1 添加启动器依赖spring-boot-starter-test



    org.wildfly.swarm
    spring-boot-starter-test
    1.0.0.Alpha2

8.2 在springBoot项目中编写测试类,则必须要在类上面添加@SpringBootTest注解

9. spring Boot整合redis

9.1 添加启动器依赖spring-boot-starter-data-redis



    org.springframework.boot
    spring-boot-starter-data-redis

9.2 application配置文件中修改redis的连接参数(redis需要启动)

#配置redis
spring.redis.host=localhost
spring.redis.port=6379

9.3 编写测试类应用RedisTemplate操作redis中的5种数据类型(string、hash、list、set、sorted set)

@RunWith(SpringRunner.class)
@SpringBootTest
public class RedisTest {

    @Autowired
    private RedisTemplate redisTemplate;

    @Test
    public void test(){
        //string 字符串
//        redisTemplate.opsForValue().set("str", "emar");
        redisTemplate.boundValueOps("str").set("emar");
        System.out.println("str = " + redisTemplate.opsForValue().get("str"));

        //hash 散列
        redisTemplate.boundHashOps("e_key").put("name", "emar");
        redisTemplate.boundHashOps("e_key").put("age", 24);
        //获取所有域
        Set set = redisTemplate.boundHashOps("e_key").keys();
        System.out.println("hash散列的所有域:" + set);
        //获取所有值
        List list = redisTemplate.boundHashOps("e_key").values();
        System.out.println("hash散列的所有域的值:" + list);

        //list列表
        redisTemplate.boundListOps("l_key").leftPush("c");
        redisTemplate.boundListOps("l_key").leftPush("b");
        redisTemplate.boundListOps("l_key").leftPush("a");
        //获取全部元素
        List list1 = redisTemplate.boundListOps("l_key").range(0, -1);
        System.out.println("list列表的所有元素:" + list1);

        //set集合
        redisTemplate.boundSetOps("s_key").add("a", "b", "c");
        Set set1 = redisTemplate.boundSetOps("s_key").members();
        System.out.println("set集合中的所有元素:" + set1);

        //sorted set有序集合
        redisTemplate.boundZSetOps("z_key").add("a", 30);
        redisTemplate.boundZSetOps("z_key").add("b", 20);
        redisTemplate.boundZSetOps("z_key").add("c", 10);
        Set set2 = redisTemplate.boundZSetOps("z_key").range(0, -1);
        System.out.println("zset有序集合中的所有元素:" + set2);
    }
}

10. spring Boot项目部署

10.1 需要添加打包组件,将项目中的资源、配置、依赖包打到一个jar包中;可以使用maven的package;


    
        
        
            org.springframework.boot
            spring-boot-maven-plugin
        
    

10.2 部署:java -jar 包名

在项目目录的target下找到jar包,启动命令行:java -jar jar包文件

你可能感兴趣的:(Spring Boot项目搭建)