• Spring Boot入门


    1.Spring Boot入门

    1.1什么是Spring Boot

    Spring 诞生时是 Java 企业版(Java Enterprise EditionJEE,也称 J2EE)的轻量级代替品。无需开发重量级的 Enterprise JavaBeanEJB),Spring 为企业级Java 开发提供了一种相对简单的方法,通过依赖注入和面向切面编程,用简单的Java 对象(Plain Old Java ObjectPOJO)实现了 EJB 的功能。

    虽然 Spring 的组件代码是轻量级的,但它的配置却是重量级的。一开始,Spring XML 配置,而且是很多 XML 配置。Spring 2.5 引入了基于注解的组件扫描,这消除了大量针对应用程序自身组件的显式 XML 配置。Spring 3.0 引入了基于 Java 的配置,这是一种类型安全的可重构配置方式,可以代替 XML。所有这些配置都代表了开发时的损耗。因为在思考 Spring 特性配置和解决业务问题之间需要进行思维切换,所以写配置挤占了写应用程序逻辑的时间。和所有框架一样,Spring 实用,但与此同时它要求的回报也不少。

    除此之外,项目的依赖管理也是件吃力不讨好的事情。决定项目里要用哪些库就已经够让人头痛的了,你还要知道这些库的哪个版本和其他库不会有冲突,这难题实在太棘手。并且,依赖管理也是一种损耗,添加依赖不是写应用程序代码。一旦选错了依赖的版本,随之而来的不兼容问题毫无疑问会是生产力杀手。

    Spring Boot 让这一切成为了过去。

        Spring Boot Spring 社区较新的一个项目。该项目的目的是帮助开发者更容易的创建基于 Spring 的应用程序和服务,让更多人的人更快的对 Spring 进行入门体验,为 Spring 生态系统提供了一种固定的、约定优于配置风格的框架。

    Spring Boot 具有如下特性:

    1)为基于 Spring 的开发提供更快的入门体验

    2)开箱即用,没有代码生成,也无需 XML 配置。同时也可以修改默认值来满足特定的需求。

    3)提供了一些大型项目中常见的非功能性特性,如嵌入式服务器、安全、指标,健康检测、外部配置等。

    4Spring Boot 并不是不对 Spring 功能上的增强,而是提供了一种快速使用 Spring 的方式。

    1.2 Spring Boot入门小Demo

    1.2.1起步依赖

    创建Maven工程 springboot_demo(打包方式jar)  

    pom.xml中添加如下依赖

      <parent>

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

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

    <version>1.4.0.RELEASE</version>

      </parent>  

      <dependencies>

        <dependency>

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

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

        </dependency>

      </dependencies>

    我们会惊奇地发现,我们的工程自动添加了好多好多jar

     

         ........

    而这些jar包正式我们做开发时需要导入的jar包。因为这些jar包被我们刚才引入的spring-boot-starter-web所引用了,所以我们引用spring-boot-starter-web后会自动把依赖传递过来。

    1.2.2变更JDK版本

    我们发现默认情况下工程的JDK版本是1.6 ,而我们通常用使用1.7的版本,所以我们需要在pom.xml中添加以下配置

      <properties>   

        <java.version>1.7</java.version>

      </properties>

    添加后更新工程,会发现版本已经变更为1.7

    1.2.3引导类

    只需要创建一个引导类 .

    package cn.itcast.demo;

    import org.springframework.boot.SpringApplication;

    import org.springframework.boot.autoconfigure.SpringBootApplication;

    @SpringBootApplication

    public class Application {

    public static void main(String[] args) {

    SpringApplication.run(Application.class, args);

    }

    }

    简单解释一下,@SpringBootApplication其实就是以下三个注解的总和

    @Configuration 用于定义一个配置类

    @EnableAutoConfiguration :Spring Boot会自动根据你jar包的依赖来自动配置项目。

    @ComponentScan: 告诉Spring 哪个packages 的用注解标识的类 会被spring自动扫描并且装入bean容器

    我们直接执行这个引导类,会发现控制台出现的这个标识

     

    你能不能看出来上边这个图是什么东西?

    1.2.4 Spring MVC实现Hello World输出

    我们现在开始使用spring MVC框架,实现json数据的输出。如果按照我们原来的做法,需要在web.xml中添加一个DispatcherServlet的配置,再添加一个spring的配置文件,配置文件中需要添加如下配置

        <!-- 使用组件扫描,不用将controllerspring中配置 -->

    <context:component-scan base-package="cn.itcast.demo.controller" />

        <!-- 使用注解驱动不用在下边定义映射器和适配置器 -->

       <mvc:annotation-driven>

      <mvc:message-converters register-defaults="true">

        <bean class="com.alibaba.fastjson.support.spring.FastJsonHttpMessageConverter">  

          <property name="supportedMediaTypes" value="application/json"/>

          <property name="features">

            <array>

              <value>WriteMapNullValue</value>

              <value>WriteDateUseDateFormat</value>

            </array>

          </property>

        </bean>

      </mvc:message-converters>  

    </mvc:annotation-driven>

    但是我们用SpringBoot,这一切都省了。我们直接写Controller

    package cn.itcast.demo.controller;

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

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

    @RestController

    public class HelloWorldController {

    @RequestMapping("/info")

    public String info(){

    return "HelloWorld";

    }

    }

    我们运行启动类来运行程序

    在浏览器地址栏输入 http://localhost:8080/info 即可看到运行结果

    1.2.5修改tomcat启动端口

    src/main/resources下创建application.properties

    server.port=8088

    重新运行引导类。地址栏输入

    http://localhost:8088/info

    1.2.6读取配置文件信息

    src/main/resources下的application.properties 增加配置

    url=http://www.itcast.cn

    我要在类中读取这个配置信息,修改HelloWorldController  

    @Autowired

    private Environment env;

    @RequestMapping("/info")

    public String info(){

    return "HelloWorld~~"+env.getProperty("url");

    }

    1.2.7热部署

    我们在开发中反复修改类、页面等资源,每次修改后都是需要重新启动才生效,这样每次启动都很麻烦,浪费了大量的时间,能不能在我修改代码后不重启就能生效呢?可以,在pom.xml中添加如下配置就可以实现这样的功能,我们称之为热部署。

    <dependency>  

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

        <artifactId>spring-boot-devtools</artifactId>  

    </dependency>  

    赶快试试看吧,是不是很爽。

  • 相关阅读:
    安装adobe,路径My Pictures或卷无效。请重新输入。
    PrintDocument打印、预览、打印机设置和打印属性的方法(较完整) .
    C# 生成CODE128条码
    SQL2005 安装时 “性能监视器计数器要求(错误)” 解决方案
    Siebel escript学习笔记
    siebel 界面搭建
    Siebel Tools 开发笔记
    Siebel Tools配置
    Oracle:environment variable "PATH" does not exceed the recommended length
    IOS开发入门实例
  • 原文地址:https://www.cnblogs.com/hxun/p/11422803.html
Copyright © 2020-2023  润新知