SpringBoot2.0基础(一)


一、 Spring介绍

1.1  简单理解SpringBoot

SpringBoot是一个快速开发的框架,能够快速的整合第三方框架,简化XML配置,全部采用注解形式,内置http服务器(Jetty和Tomcat)最终使用Java应用程序进行执行。帮助开发者能够实现快速开发,SpringBoot的Web组件 默认集成的是SpringMVC框架。

SpringBoot的主要优点:

为所有Spring开发者更快的入门

开箱即用,提供各种默认配置来简化项目配置

内嵌式容器简化Web项目

没有冗余代码生成和XML配置的要求

1.2 系统要求:

Java1.8及以上

Spring Framework 4.1.5及以上

本文采用Java 1.8.0_73Spring Boot 2.0版本调试通过

1.3、SpringBoot和SpringMVC区别

SpringBoot是一个快速开发的框架,能够快速的整合第三方框架,简化XML配置,全部采用注解形式,内置Tomcat容器,帮助开发者能够实现快速开发,SpringBoot的Web组件 默认集成的是SpringMVC框架。

SpringMVC是控制层。

1.4、SpringBoot和SpringCloud区别

SpringBoot是一个快速开发的框架,能够快速的整合第三方框架,简化XML配置,全部采用注解形式,内置Tomcat容器,帮助开发者能够实现快速开发,SpringBoot的Web组件 默认集成的是SpringMVC框架。

SpringMVC是控制层。

SpringCloud依赖与SpringBoot组件,使用SpringMVC编写Http协议接口,同时SpringCloud是一套完整的微服务解决框架。

二、快速入门

拓展:查看spingboot最新版本——>百度maven——>搜索spring-boot-starter-parent就可以查看最新版本啦!

2.1、创建一个Maven工程

名为”springboot-helloworld” 类型为Jar工程项目

 

2.2、pom文件引入依赖

      <!-- 回顾 maven parent 目的:聚合工程 ,依赖关系 -->
      <!-- spring parent 目的:统一整合第三方框架依赖信息(springboot支持依赖 不需要写版本) -->

      <parent>

            <groupId>org.springframework.boot</groupId>

            <artifactId>spring-boot-starter-parent</artifactId>

            <version>2.0.0.RELEASE</version>

      </parent>

      <dependencies>

                <!-- springbooot 整合web组件 整合springmvc 将传统方式的springmvc依赖jar 全部下载下来 -->
                  <!-- 引入spring-boot-starter-web 帮我们整合好所有与spring相关的依赖jar包   -->
                  <!-- 原理:maven依赖传递 ,spring-boot-starter-parent中,已整合好相关jar依赖信息 -->

            <dependency>

                  <groupId>org.springframework.boot</groupId>

                  <artifactId>spring-boot-starter-web</artifactId>

            </dependency>

      </dependencies>


spring-boot-starter-parent
作用

在pom.xml中引入spring-boot-start-parent,spring官方的解释叫什么stater poms,它可以提供dependency management,也就是说依赖管理,引入以后在申明其它dependency的时候就不需要version了,后面可以看到。

spring-boot-starter-web作用

springweb核心组件

spring-boot-maven-plugin作用

 如果我们要直接Main启动spring,那么以下plugin必须要添加,否则是无法启动的。如果使用maven 的spring-boot:run的话是不需要此配置的。(我在测试的时候,如果不配置下面的plugin也是直接在Main中运行的。)

2.3、编写HelloWorld服务

创建package命名为com.yln.controller(根据实际情况修改)

创建HelloController类,内容如下

 

@RestController

@EnableAutoConfiguration

publicclass HelloController {

     @RequestMapping("/hello")

     public String index() {

          return"Hello World";

     }   

publicstaticvoid main(String[] args) {

          SpringApplication.run(HelloController.class, args);

     }

}

2.4、@RestController

在上加上RestController 表示修饰该Controller所有的方法返回JSON格式,直接可以编写

Restful接口

2.5、@EnableAutoConfiguration

注解:作用在于让 Spring Boot   根据应用所声明的依赖来对 Spring 框架进行自动配置
这个注解告诉Spring Boot根据添加的jar依赖猜测你想如何配置Spring。由于spring-boot-starter-web添加了Tomcat和Spring MVC,所以auto-configuration将假定你正在开发一个web应用并相应地对Spring进行设置。

2.6 SpringApplication.run(HelloController.class, args);

   标识为启动类

2.7、SpringBoot启动方式1

Springboot默认端口号为8080

 

@RestController

@EnableAutoConfiguration

publicclass HelloController {

     @RequestMapping("/hello")

     public String index() {

          return"Hello World";

     }   

publicstaticvoid main(String[] args) {

          SpringApplication.run(HelloController.class, args);

     }

}


 

启动主程序,打开浏览器访问http://localhost:8080/index,可以看到页面输出HelloWorld

2.8、SpringBoot启动方式2

@ComponentScan(basePackages = "com.yln.controller")---控制器扫包范围

@ComponentScan(basePackages = "com.yln.controller")

@EnableAutoConfiguration

publicclass App {

      publicstaticvoid main(String[] args) {

            SpringApplication.run(App.class, args);

      }

}

 

2.9、SpringBoot启动方式3

@SpringBootApplication

 

@SpringBootApplication被@Configuration、@EnableAutoConfiguration、@ComponentScan 注解所修饰,换言之 Springboot 提供了统一的注解来替代以上三个注解

扫包范围:在启动类上加上@SpringBootApplication注解,当前包下或者子包下所有的类都可以扫到。

三、 Web开发

3.1、静态资源访问

在我们开发Web应用的时候,需要引用大量的js、css、图片等静态资源。

默认配置

SpringBoot默认提供静态资源目录位置需置于classpath下,目录名需符合如下规则:

/static

/public

/resources        

/META-INF/resources

举例:我们可以在src/main/resources/目录下创建static,在该位置放置一个图片文件。启动程序后,尝试访问http://localhost:8080/D.jpg。如能显示图片,配置成功。

3.2、渲染Web页面

渲染Web页面

在之前的示例中,我们都是通过@RestController来处理请求,所以返回的内容为json对象。那么如果需要渲染html页面的时候,要如何实现呢?

模板引擎

在动态HTML实现上Spring Boot依然可以完美胜任,并且提供了多种模板引擎的默认配置支持,所以在推荐的模板引擎下,我们可以很快的上手开发动态网站。

SpringBoot提供了默认配置的模板引擎主要有以下几种:

·       Thymeleaf

·       FreeMarker

·       Velocity

·       Groovy

·       Mustache

SpringBoot建议使用这些模板引擎,避免使用JSP,若一定要使用JSP将无法实现SpringBoot的多种特性,具体可见后文:支持JSP的配置

当你使用上述模板引擎中的任何一个,它们默认的模板配置路径为:src/main/resources/templates。当然也可以修改这个路径,具体如何修改,可在后续各模板引擎的配置属性中查询并修改。

3.3、使用Freemarker模板引擎渲染web视图

3.3.1、pom文件引入:

<!-- 引入freeMarker的依赖包. -->

<dependency>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-freemarker</artifactId>

</dependency>

3.3.2、后台代码

在src/main/resources/创建一个templates文件夹,后缀为*.ftl

     @RequestMapping("/index")

      public String index(Map<String, Object> map) {

          map.put("name","springboot");

            return"index";

      }


3.3.3、前台代码

<!DOCTYPE html>

<html>

<head lang="en">

<meta charset="UTF-8" />

<title></title>

</head>

<body>

        ${name}

</body>

</html>

3.3.4、Freemarker其他用法

@RequestMapping("/freemarkerIndex")

      public String index(Map<String, Object> result) {

            result.put("name", "rose");

            result.put("sex", "1");

            List<String> listResult = new ArrayList<String>();

            listResult.add("andy'");

            listResult.add("bob");

            listResult.add("anny");

            result.put("listResult", listResult);

            return"index";

      }

 

<!DOCTYPE html>

<html>

<head lang="en">

<meta charset="UTF-8" />

<title>首页</title>

</head>

<body>

       ${name}

<#if sex=="1">

            男

      <#elseif sex=="2">

            女

     <#else>

        其他     

       

        </#if>     

       <#list userlist as user>

         ${user}

       </#list>

</body>

</html>

 

3.3.4、Freemarker配置

新建application.properties文件

########################################################

###FREEMARKER (FreeMarkerAutoConfiguration)

########################################################

spring.freemarker.allow-request-override=false

spring.freemarker.cache=true

spring.freemarker.check-template-location=true

spring.freemarker.charset=UTF-8

spring.freemarker.content-type=text/html

spring.freemarker.expose-request-attributes=false

spring.freemarker.expose-session-attributes=false

spring.freemarker.expose-spring-macro-helpers=false

#spring.freemarker.prefix=

#spring.freemarker.request-context-attribute=

#spring.freemarker.settings.*=

spring.freemarker.suffix=.ftl

spring.freemarker.template-loader-path=classpath:/templates/

#comma-separated list

#spring.freemarker.view-names= # whitelist of view names that can be resolved

 

3.4、使用JSP渲染Web视图

3.4.1、pom文件引入以下依赖

      <parent>

            <groupId>org.springframework.boot</groupId>

            <artifactId>spring-boot-starter-parent</artifactId>

            <version>2.0.0.RELEASE</version>

      </parent>

      <dependencies>

            <!-- SpringBoot 核心组件 -->

            <dependency>

                  <groupId>org.springframework.boot</groupId>

                  <artifactId>spring-boot-starter-web</artifactId>

            </dependency>

            <dependency>

                  <groupId>org.springframework.boot</groupId>

                  <artifactId>spring-boot-starter-tomcat</artifactId>

            </dependency>

            <dependency>

                  <groupId>org.apache.tomcat.embed</groupId>

                  <artifactId>tomcat-embed-jasper</artifactId>

            </dependency>

      </dependencies>

 

3.4.2、在application.properties创建以下配置

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

spring.mvc.view.suffix=.jsp

 

3.4.3、后台代码

@Controller

publicclass IndexController {

      @RequestMapping("/index")

      public String index() {

            return"index";

      }

}


注意
:创建SpringBoot整合JSP,一定要为war类型,否则会找不到页面.

3.5、全局捕获异常

@ExceptionHandler表示拦截异常

·       @ControllerAdvice 是 controller 的一个辅助类,最常用的就是作为全局异常处理的切面类

·       @ControllerAdvice 可以指定扫描范围

·       @ControllerAdvice 约定了几种可行的返回值,如果是直接返回 model 类的话,需要使用 @ResponseBody 进行 json 转换

o   返回 String,表示跳到某个 view

o   返回 modelAndView

o   返回 model +@ResponseBody

 

@ControllerAdvice

publicclass GlobalExceptionHandler {

     @ExceptionHandler(RuntimeException.class)

     @ResponseBody

     public Map<String, Object> exceptionHandler() {

          Map<String, Object> map = new HashMap<String, Object>();

          map.put("errorCode", "101");

          map.put("errorMsg", "系統错误!");

          returnmap;

     }

}






  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值