SpringBoot入门学习记录(一)

    最近,SpringBoot、SpringCloud、Dubbo等框架非常流行,作为Coder里的一名小学生,借着改革开放的东风,自然也是需要学习学习的,于是将学习经历记录于此,以备日后查看。

  官网:https://start.spring.io/

  可以在官网直接下载demo项目导入到开发工具中,在官网下载只能选择JDK8和JDK11(似乎2.0以上已经不支持1.7了),如果从官网下载项目而本地环境JDK版本是1.7,需要指定prom.xml里的版本,也可自行构建maven项目,因为初次学习,此处自行新建maven项目配置SpringBoot框架。

项目目录如下:

SpringBoot入门学习记录(一)

一、目录结构

如上图所示,Spring Boot的基础结构共三个文件:

l src/main/java  程序开发以及主程序入口

l src/main/resources  模板、js、css、图片、配置等静态文件

l src/test/java  测试程序

而在src/main/java 目录 ,主要程序结构是

----------com.hyblogs

    -----Application.java

    -----controller

      -----------HyBlogsController.java

     ------mode

        -----------User.java

     ------service

        -----------GetUserService.java

   ------dao

   ------utils

------constant

        

Application.java 程序作为入口,所在的位置是在controller、model、service包的同一级,同一级,同一级,重要的事情说三遍。

SpringBoot入门学习记录(一)

①、Application.java 墙裂建议放到根目录下面,主要用于做一些框架配置

②、model目录主要用于实体

③、service 层主要是业务类代码

④、controller 负责页面访问控制

⑤、dao用于数据访问

⑥、constant用于存放常量

⑦、utils用于存放常用工具

这个目录结构让我想起世界上最好的语言PHP,真的好像ThinkPHP里的路由,有木有?既然是maven构建的项目,自然少不了porm.xml文件了。现将内容贴出,再来分析。

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<!--   
spring-boot-starter-parent是Spring Boot的核心启动器,
包含了自动配置、日志和YAML等大量默认的配置,大大简化了我们的开发。
引入之后相关的starter引入就不需要添加maven 里jar包的 version配置,
   spring boot会自动选择最合适的版本进行添加。
   -->
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.5.4.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent> <!--项目的基本描述信息-->
<groupId>com.hyblogs</groupId>
<artifactId>SpringBooT</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>SpringBoot_1</name>
<description>Hyblogs Spring Boot 1</description> <!--指定当前的jdk版本和字符编码,开发、编译jdk版本要一致 -->
<properties>
<java.version>1.7</java.version>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties> <dependencies>
<!--Springboot核心,通过starter来启动 核心模块,包括自动配置支持、日志和YAML -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<!-- 添加测试模块 ,包括JUnit、Hamcrest、Mockito-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency> <!--包含了Spring Boot预定义的一些Web开发的常用依赖包如: spring-webmvc,Tomcat等 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!-- 热部署,修改代码后不需要手动重启tomcat -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>springloaded</artifactId>
<version>1.2.7.RELEASE</version><!--$NO-MVN-MAN-VER$-->
</dependency>
<!-- 应用支持热部署,提高开发者的开发效率,无需手动重启Spring Boot应用 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<version>1.5.4.RELEASE</version><!--$NO-MVN-MAN-VER$-->
</dependency>
</dependencies> <build>
<plugins>
<!--在Maven中提供Spring Boot支持,允许打包可执行jar或war和运行应用程序 -->
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build> </project>

建议将maven的远程仓库改为阿里云,第一次下载jar包的速度会快很多,下载完jar包,新建目录,SpringBoot的基本结构就完成了。

二、入口程序Application.java

  执行Application中的main()方法,启动SpringBoot程序。

  @SpringBootApplication:表明这个是SpringBoot的入口文件,这是SpringBoot的启动程序。

  @RunWith(SpringRunner.class)  @RunWith是指定运行器,而(SpringRunner.class)是Spring的运行器,指定用Spring容器的方式来运行。

 package com.hyblogs;

 import org.junit.runner.RunWith;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.test.context.junit4.SpringRunner; @SpringBootApplication
@RunWith(SpringRunner.class)
public class Application { public static void main(String[] args) {
SpringApplication.run(Application.class, args);
} }

三、Controller层

  在com.hyblogs.controller包下创建HyBlogsController.java

  此处说一下这两个Controller的区别

  @RestController:表明此控制器内的方法的返回值会以json格式显示,返回的内容就是return 里的内容

  @Controller:表明此控制器的的返回值会映射一个页面,浏览器会转到return里的页面中。如果要返回json,不跳转到返回的页面中,需要在方法上添加@ResponseBody。

  @RequestMapping():指定请求的路径

 package com.hyblogs.controller;

 import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController; import com.hyblogs.model.User; @RestController
public class HyBlogsController {
@RequestMapping("/hello")
public String index() {
return "Hello World";
}
@RequestMapping("/hyblogs")
public String hi() {
return "hyblogs 666";
} }

由于还没有编写jsp和html页面,就先使用@RestController来体验一把SpringBoot的威力,直接运行入口文件Application.java。

SpringBoot入门学习记录(一)

根本没有部署程序到Tomcat,Tomcat已经成功加载程序并运行了。在浏览器地址栏输入:http://127.0.0.1:8080/hello

SpringBoot入门学习记录(一)

结果出来的,真的方便,不用部署,不用配置xml,不用启动Tomcat,有了SpringBoot简直美滋滋。既然配置了@RestController控制器,自然也要体验一把json的效果。

在com.hyblogs.model包下新建一个User.java

 package com.hyblogs.model;

 public class User {
private String userName;
private String passWord;
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;
}
}

HyBlogsController.java中添加

 package com.hyblogs.controller;

 import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController; import com.hyblogs.model.User; @RestController
public class HyBlogsController {
@RequestMapping("/hello")
public String index() {
return "Hello World";
}
@RequestMapping("/hyblogs")
public String hi() {
return "hyblogs 666";
}
@RequestMapping("/getUser")
public User getUser() {
User user=new User();
user.setUserName("小明你还记得我吗");
user.setPassWord("7890");
return user;
}
}

将对象属性转为json数据,在保存的那一刻,控制台显示Tomcat自动restart。在地址栏输入:http://127.0.0.1:8080/getUser

SpringBoot入门学习记录(一)

SpringBoot配置JSP

  体验了@RestController的效果,再来看看@Controller,使用@Controller返回一个jsp页面。在Spring MVC里面也可以很方便的将JSP与一个View关联起来,返回一个字符串,就能对应上jsp页面。但是SpringBoot官方不推荐使用JSP,推荐使用模板Thymeleaf,对jsp的使用不太友好,所以这一点拿出来单独纪录,坑有几个,踩上就是404,得花时间调试一会。先来分析一下SpringBoot的资源目录:

    SpringBoot入门学习记录(一)

在resource目录中新建了config、static、templates三个文件。

  config里存放的各种配置文件,注意:如果在config里有一个配置文件,在resource目录下也有一个配置文件,那么会以config下的为准,会覆盖掉外层的配置;

  static里有css,js,images的目录,这无需多言,而HTML作为静态文件,也是放在这里的,通过地址栏可以直接访问到的;

  templates 里主要放动态文件,Thymeleaf模板文件就在这里。

SpringBoot入门学习记录(一)

既然如此,就需要给jsp安排地方了,在resources同级目录,新建一个webapp目录,在webapp里新建一个WEB-INF目录,WEB-INF中建一个jsp目录,把jsp文件放在这里。

SpringBoot入门学习记录(一)

MyJsp.jsp

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>My JSP </title>
</head>
<body>
测试jsp的页面内容</br>
<hr>
不建议使用jsp
</body>
</html>

现在创建一个Controller,并返回指向MyJsp.jsp的页面(使用@Controller注解,而非RestController注解,返回的地址写webapp地址的全路径):

TestController.java

package com.hyblogs.controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller
public class TestController {
@RequestMapping("/testControl")
public String testControl(){
System.out.println("!!!!!");
return "/WEB-INF/jsp/MyJsp.jsp";
} }

运行发现出现404:

SpringBoot入门学习记录(一)

原因是还没配置jsp的支持,于是在pom.xml中添加jsp的jar包支持:

<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
</dependency> <dependency>
<groupId>javax.servlet</groupId>
<artifactId>jstl</artifactId>
</dependency>
<!-- tomcat的支持.-->
<dependency>
<groupId>org.apache.tomcat.embed</groupId>
<artifactId>tomcat-embed-jasper</artifactId>
</dependency>

配置后,再次运行:

SpringBoot入门学习记录(一)

此时已经成功运行处jsp页面了,当然也可以使用配置文件,配置Controller返回的前缀和后缀,这样就可以省去每次写jsp路径和".jsp"。

打开src.main.resources.config中的application.properties

添加2行

spring.mvc.view.prefix=/WEB-INF/jsp/
spring.mvc.view.suffix=.jsp

prefix是前缀,后面跟webapp后的每一层目录,suffix是后缀,后面跟.jsp

SpringBoot入门学习记录(一)

配置完前缀和后缀,在Controller里返回就不用带上目录和文件后追了,直接返回文件名字的字符串就可以,改成如下:

package com.hyblogs.controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller
public class TestController {
@RequestMapping("/testControl")
public String testControl(){
System.out.println("!!!!!");
return "MyJsp";
} }

运行:

SpringBoot入门学习记录(一)

总结几点:

  1、SpringBoot的目录按照MVC的思想进行分离,但需要注意Application.Java这个入口文件的位置。

  2、如果需要返回JSP页面,①配置文件后面不能有空格、tab等字符,②路径要对应,③pom.xml里不能同时存在jsp和Thymeleaf,默认会在templates中找模板文件;

   3、使用@Controller 注解,在对应的方法上,视图解析器可以解析return 的jsp,html页面,并且跳转到相应页面若返回json等内容到页面,则需要加@ResponseBody注解,而                @RestController相当于@Controller+@ResponseBody两个注解的结合,返回json数据不需要在方法前面加@ResponseBody注解了,但使用@RestController这个注解,就                不能返回jsp,html页面,视图解析器无法解析jsp,html页面。

   4、SpringBoot不推荐使用JSP,Thymeleaf模板确实是比JSP效率高,对前后端的分离做的更好,推荐使用。

Thymeleaf模板内容较多,且到下文分解---------------------------------------------------------------------------

上一篇:zz A list of open source C++ libraries


下一篇:DOS命令行中的双引号