您的位置:首页 > 编程语言 > Java开发

spring-boot 之 Hello World

2017-08-09 22:47 363 查看
第一步:
创建maven 工程
第二步:
配置pom依赖,参考官方例子:
http://projects.spring.io/spring-boot/
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.4.3.RELEASE</version>
</parent>

开始只需要引入这个一个依赖就可以了, 由于我们已经继承了 spring-boot-starter-parent ,而 spring-boot-starter-parent 又提供了 dependency-management ,所以我们可以忽略被选中依赖的版本。
        在添加依赖之前,我们先看一下现在已有什么:mvn dependency:tree。该命令会打印一个当前项目的依赖树。
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<java.version>1.8</java.version>
</properties>


设置编码格式和制定jdk版本
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>

通过打印依赖树,可以看出,spring-boot-starter-web  包含了很多内容,spring-webmvc、spring-web、jackson、validation、tomcat、starter。
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>

spring-boot 的打包插件,默认是打war包,打包可以使用 mvn pakage 命令 或者
mvn Dmaven.test.skip=true pakage (忽略测试过程),打包之后使用 java -jar 工程名启动

第三步: Hello world

package com.example;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.web.servlet.ServletComponentScan;
import org.springframework.boot.web.support.SpringBootServletInitializer;
@SpringBootApplication
public class SampleWebJspApplication extends SpringBootServletInitializer {

public static void main(String[] args) throws Exception {
SpringApplication.run(SampleWebJspApplication.class, args);
}
}


启动spring-boot 应用的main方法,@SpringBootApplication = (默认属性)@Configuration + @EnableAutoConfiguration + @ComponentScan。
1、@Configuration:提到@Configuration就要提到他的搭档@Bean。使用这两个注解就可以创建一个简单的spring配置类,可以用来替代相应的xml配置文件。@Configuration的注解类标识这个类可以使用Spring IoC容器作为bean定义的来源。@Bean注解告诉Spring,一个带有@Bean的注解方法将返回一个对象,该对象应该被注册为在Spring应用程序上下文中的bean。
2、@EnableAutoConfiguration:能够自动配置spring的上下文,试图猜测和配置你想要的bean类,通常会自动根据你的类路径和你的bean定义自动配置。
3、@ComponentScan:会自动扫描指定包下的全部标有@Component的类,并注册成bean,当然包括@Component下的子注解@Service,@Repository,@Controller。

Controller 视图

public class Linked {

// 存放元素
private Node first;

// 有一个值标识存储的大小
private int size;

// 有一个添加元素的方法
public void add(Object obj) {
Node node = new Node(obj);
/**
* 添加分两种情况:1.第一次 2.第n次
*/
if (first == null) {
first = node;
} else {
// 第n次添加,只能把元素挂在最后一个元素上面,循环找到最后一个
Node n = first;
while (n.next != null) {
n = n.next;
}
n.next = node;
}
size++;
}

// 有一个获得容器大小的方法
public int getSize() {
return this.size;
}

// 复写toString()方法,查看结果
@Override
public String toString() {
StringBuffer sb = new StringBuffer();
sb.append("[");
Node n = first;
if(n!=null){
sb.append(n.obj).append(",");
}
while (n.next != null) {
n = n.next;
if (n.next == null) {
sb.append(n.obj);
} else {
sb.append(n.obj).append(",");
}
}
sb.append("]");
return sb.toString();
}

// 有一个对象存储值和引用
private class Node {
// 值.任意类型
private Object obj;
// 引用
private Node next;

Node(Object obj) {
this.obj = obj;
}
}
}


四 spring -boot 应用的启动方式
① 通过IDE启动
② 启动jar包 ,java -jar 项目名
③使用maven 插件 mvn spring-boot:run

五 热部署
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<optional>true</optional>
</dependency>


只要修改了calss path 下的文件,项目会自动重启.

一些特定的资源改变时没有必要引起重启。有一些不会引起重启,但是会重加载。如果你想自定义的设置一下,可以使用 spring.devtools.restart.exclude 属性。如下:
spring.devtools.restart.exclude=static/**,public/**
如果想在默认的设置之外再添加新的排除选项,可以使用 spring.devtools.restart.additional-exclude 属性。
 
如果想在修改classpath之外的文件时也让应用重启,可以使用 spring.devtools.restart.additional-paths 属性。还可以配合上面提到的 spring.devtools.restart.exclude 属性,来控制是重启还是重加载。
 
如果不想使用自动重启功能,可以使用 spring.devtools.restart.enabled 属性。多数情况下,可以在 application.properties 中设置,这样仍然会创建一个restart类加载器,但不再监视改变。
如果想完全禁止自动重启,需要在调用 SpringApplication.run(..) 之前设置一个System属性。如下:
public static void main(String[] args) {

System.setProperty("spring.devtools.restart.enabled", "false");

SpringApplication.run(MyApp.class, args);
}
public static void main(String[] args) {
System.setProperty("spring.devtools.restart.enabled", "false");
SpringApplication.run(MyApp.class, args);
}


六 spring-boot 响应jsp
spring 官方不建议建议使用jsp ,使用jsp需要在main 下面创建webapp文件夹存放jsp页面

jsp页面内容:

要支持jsp相应还需要在 application.properties 做如下配置:
# 页面默认前缀目录
spring.mvc.view.prefix=/WEB-INF/jsp/
# 页面默认后缀目录
spring.mvc.view.suffix=.jsp
application.hello=hello jsp

在pom中添加依赖:
<dependency>
<dependency>
<groupId>org.apache.tomcat.embed</groupId>
<artifactId>tomcat-embed-jasper</artifactId>
<scope>provided</scope>
</dependency>

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


Controller 中方法:
package com.example;

import java.util.Map;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.servlet.ModelAndView;
@RestController
public class HelloController {

// 从 application.properties 中读取配置,如取不到默认值为Hello
@Value("${application.hello:Hello}")
private String hello;

@RequestMapping("/page1")
public ModelAndView page1(){
// 页面位置 /WEB-INF/jsp/helloJsp.jsp
ModelAndView mav = new ModelAndView("/helloJsp");
mav.addObject("hello", hello);
return mav;
}

@RequestMapping("/helloJsp")
public String helloJsp(Map<String, Object> map) {
map.put("hello", hello);
return "helloJsp";
}

}


注意:在使用 下面的方法返回jsp视图的时候,不能使用
@RestController 注解 要使用 @Controller 不然.就会返回字符串"hellojsp" 而不会返回页面内容:
@RestController=@Controller + @ResponseBody,@ResponseBody注解是返回json格式数据



解决办法是直接使用 @Controller 注解 在需要返回json格式数据的方法上面添加 @ResponseBody 就可以了
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息