spring boot最新教程(一):入门程序Hello World的编写

前言        

随着各种开源的第三方的组件爆发式增长,java的开发显得越来越笨重:繁多的配置,低下的开发效率,复杂的部署流程以及第三方技术集成难度大。

在上述环境下,Spring Boot应运而生。它使用"习惯优于配置"(项目中存在大量的配置,此外还内置一个习惯性的配置,让你无需手动进行配置) 的理念让你的项目快速运行起来。使用Spring boot很容易创建一个独立运行(运行jar,内置servlet容器)、准生产级别的基于Spring框架的项目,使用spring boot你可以不用或者很少的spring配置。

spring boot的优缺点

优点:

1.  快速构建项目

2. 对主流开发框架的无配置集成

3. 项目可独立运行,无须依赖外部servlet容器

4. 提供运行时的应用监控

5. 极大的提高了开发部署效率

6. 与云计算的天然集成

缺点:

1. 书籍文档较少且不够深入

2. 由于大部分配置在类里面完成的,所以损失了一定的可维护的便利性

所以spring boot特别适合中小型项目。

 

Hello World程序开发

1.  设置spring boot的parent

<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>1.5.2.RELEASE</version>
</parent>

说明:Spring boot的项目必须要将parent设置为spring boot的parent,该parent包含了大量默认的配置,大大简化了我们的开发。
而且引入以后在申明其它dependency的时候就不需要version了,后面可以看到。

 

2.  导入spring boot的web支持

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
</dependency>

3.  添加spring boot的maven插件

<plugin>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-maven-plugin</artifactId>
</plugin>

当然,如果你不想用maven命令运行,也可以不用配置该插件

pom文件完整版

<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>
	<groupId>com.wx</groupId>
	<artifactId>springboot01</artifactId>
	<version>0.0.1-SNAPSHOT</version>

	<parent>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-starter-parent</artifactId>
		<version>1.5.2.RELEASE</version>
	</parent>
	
	<dependencies>
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-web</artifactId>
		</dependency>
		
	</dependencies>
	<build>
		<finalName>${project.artifactId}</finalName>
		<plugins>
			<!-- java编译插件 -->
			<plugin>
				<groupId>org.apache.maven.plugins</groupId>
				<artifactId>maven-compiler-plugin</artifactId>
				<configuration>
					<source>1.7</source>
					<target>1.7</target>
					<encoding>UTF-8</encoding>
				</configuration>
			</plugin>
			<!-- 如果你不想用maven命令运行spring boot可以不用作此配置 -->
			<plugin>
				<groupId>org.springframework.boot</groupId>
				<artifactId>spring-boot-maven-plugin</artifactId>
			</plugin>
		</plugins>
		
	</build>

</project>


4.  编写Hello World程序

package com.wx.controlers;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.Configuration;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;

@Controller
@SpringBootApplication
//@Configuration  //因为@SpringBootApplication包含了Configuration,所以这里可以省略
public class HelloApp {
    
    @RequestMapping("hello")
    @ResponseBody
    public String hello(){
        return "Hello";
    }
    
    public static void main(String[] args) {
        SpringApplication.run(HelloApp.class, args);
    }

}

代码说明:
(1)@SpringBootApplication:Spring Boot项目的核心注解,主要目的是开启自动配置。
(2)@Configuration:这是一个配置Spring的配置类。
(3)@Controller:标明这是一个SpringMVC的Controller控制器。

 

(4)@ResponseBody: 如果需要返回JSON,XML或自定义mediaType内容到页面,则需要在对应的方法上加上@ResponseBody注解
(5)main方法:在main方法中启动一个应用,即:这个应用的入口。
当然,我们也可以用restfull风格的注解(@restcontroller)来标注,如下代码:

package com.wx.controlers;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.Configuration;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;

@RestController
@SpringBootApplication
//@Configuration  //因为@SpringBootApplication包含了Configuration,所以这里可以省略
public class HelloApp {
    
    @RequestMapping("hello")
    //@ResponseBody
    public String hello(){
        return "Hello";
    }
    
    public static void main(String[] args) {
        SpringApplication.run(HelloApp.class, args);
    }

}

官方文档:
@RestController is a stereotype annotation that combines @ResponseBody and @Controller.
意思是:
@RestController注解相当于@ResponseBody + @Controller合在一起的作用。
如果只是使用@RestController注解Controller,则Controller中的方法无法返回jsp页面,配置的视图解析器InternalResourceViewResolver不起作用,返回的内容就是Return 里的内容。

 

5. 启动应用

在Spring Boot项目中,启动的方式有两种,一种是直接run Java Application另外一种是通过Spring Boot的Maven插件运行。

第一种:

 

第二种:

 

在项目上单击右键===》Run as===> Maven build...

看到如下信息,说明启动成功了

[   main] s.b.c.e.t.TomcatEmbeddedServletContainer : Tomcat started on port(s): 8080 (http)
[   main] com.wx.controlers.HelloApp               : Started HelloApp in 3.126 seconds (JVM running for 42.425)

启动浏览器运行

6  spring boot的核心

(1)  入口类和@SpringBootApplication

Spring Boot的项目一般都会有*Application的入口类,入口类中会有main方法,
这是一个标准的Java应用程序的入口方法。
@SpringBootApplication注解是Spring Boot的核心注解,它其实是一个组合注解:

该注解主要组合了以下注解:
1.@SpringBootConfiguration:这是Spring Boot项目的配置注解,这也是一个组合注解:

在Spring Boot项目中推荐使用@ SpringBootConfiguration替代@Configuration,所以HelloApp入口类上的Configuration注解可以注释掉

2.@EnableAutoConfiguration:启用自动配置,该注解会使Spring Boot根据项目中依赖的jar包自动配置项目的配置项:
a)如:我们添加了spring-boot-starter-web的依赖,项目中也就会引入SpringMVC的依赖,Spring Boot就会自动配置tomcat和SpringMVC

3.@ComponentScan:默认扫描@SpringBootApplication所在类的同级目录以及它的子目录。

   如果我们在启动类上又配置了@ComponentScan,  那么该默认的扫描失效,当前包也要重新纳入扫描!

(2)  关闭自动配置

通过上述,我们得知,Spring Boot会根据项目中的jar包依赖,自动做出配置,Spring Boot支持的自动配置如下(非常多):

如果我们不需要Spring Boot自动配置,想关闭某一项的自动配置,该如何设置呢?
比如:我们不想自动配置Redis,想手动配置。

当然了,其他的配置就类似了。

7  解决jsp页面的支持问题

由于Spring boot使用的内嵌的tomcat,而内嵌的tamcat是不支持jsp页面的,所有需要导入额外的包才能解决。

<dependency>
	<groupId>org.apache.tomcat.embed</groupId>
	<artifactId>tomcat-embed-jasper</artifactId>
	<scope>provided</scope>
</dependency>

修改启动类

package com.wx.controlers;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.Configuration;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;

@Controller
@SpringBootApplication
//@Configuration  //因为@SpringBootApplication包含了Configuration,所以这里可以省略
public class HelloApp {
    
    @RequestMapping("hello")
    //@ResponseBody
    public String hello(){
        return "Hello";
    }
    
    public static void main(String[] args) {
        SpringApplication.run(HelloApp.class, args);
    }

}

写一个Hello.jsp的页面放到webapp目录下:

编写全局配置文件application.properties,如图所示

关于全局配置文件,以后再讲解!

重新运行,结果如图

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

御前两把刀刀

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值