发展史html
从Spring3.x开始提供了Java配置方式,使用Java配置方式能够更好的理解你配置的Bean,如今咱们就处于这个时代,而且Spring4.x和Spring boot都推荐使用java配置的方式。能够彻底替代xml配置。java
Springboot介绍mysql
它是全新的框架,主要就是为了简化spring的搭建及应用程序的开发的。web
springboot特性:spring
springboot-HelloWorld实现sql
建立Maven项目(打包方式是war),项目结构:apache
pom.xml中的依赖:json
<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.test</groupId>
<artifactId>springbootTest</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>war</packaging>
<build/>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.5.6.RELEASE</version>
</parent>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-resources-plugin</artifactId>
<version>2.4.3</version>
</dependency>
</dependencies>
</project>tomcat
使用的JDK是JDK7。使用的是springboot内置的tomcatspringboot
Controller类:
package test1;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
@Controller
public class Controller1 {
@RequestMapping(value="/hello")
@ResponseBody
public String hello(){
return "hello world!";
}
}
主类:
package test1;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
public class HelloApplication {
public static void main(String[] args) {
SpringApplication.run(HelloApplication.class, args);
}
}
注意:主类默认会扫描同包下或者子包下的类,因此创建的类放置的位置要注意。
解释用到的注解:
(1)Controller中使用的注解比较熟悉
(2)主类中使用的注解:@SpringBootApplication 能够启动一个类
访问url:http://localhost:8080/hello
注意:
springboot有本身使用的tomcat,端口是8080
springboot访问Controller添加后缀
前面测试的例子中Controller中没有添加后缀,访问URL也没有添加后缀。
如今添加访问URL的后缀,作法:
(1)在src/main/java中添加application.properties文件,在文件中添加:
server.servlet-path=*.html
(2)Controller不变
@RequestMapping(value="/hello")
@ResponseBody
public String hello(){
return "a";
}
(3)访问的URL:http://localhost:8080/hello.html中添加访问的后缀
springboot添加拦截器
建立一个拦截器类,注意仍是以前说的,springboot默认扫描的是与主类同包下的类或者子包下的类,因此这个拦截器类要放在与主类同包下:
package test1;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter;
@Configuration //申明这是一个配置
public class MySrpingMVCConfig extends WebMvcConfigurerAdapter{
// 自定义拦截器
@Override
public void addInterceptors(InterceptorRegistry registry) {
HandlerInterceptor handlerInterceptor = new HandlerInterceptor() {
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
throws Exception {
System.out.println("自定义拦截器............");
return true;
}
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler,
ModelAndView modelAndView) throws Exception {
}
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler,
Exception ex) throws Exception {
}
};
registry.addInterceptor(handlerInterceptor).addPathPatterns("/**");
}
}
springboot返回Json格式数据
返回json格式的数据有两种方式:
(1)传统springmvc的作法
package test1;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
@Controller
public class Controller1 {
@RequestMapping(value="/hello")
@ResponseBody
public String hello(){
return "a";
}
}
(2)springboot提供的返回Json格式的@RestController注解
package test1;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class Controller1 {
@RequestMapping(value="/hello")
public String hello(){
return "a";
}
}
使用这个注解,这个Controller中的全部方法返回的都是json格式的数据。
springBoot项目属性配置
springboot使用的配置文件是application.properties中的,这个文件放在src/main/resources下。他就是至关于咱们的web项目的web.xml文件,可是这里的是更增强大的。
1.application.properties默认配置
访问的是8080端口,路径是/,没有后缀
2.配置application.properties
(1)修改URL访问的端口:添加server.port=8888
访问的URL:http://localhost:8888/hello
(2)修改URL访问的后缀:添加server.servlet-path=*.html
Controller中的@RequestMapping(value="/hello")不变,访问的URL:localhost:8888/hello.html
(3)添加访问Controller的路径:
第一种方式:直接在Controller中添加:@RequestMapping(value="/context/hello")
第二种方式:在application.properties中添加server.context-path=/context,Controller中仍是原来的@RequestMapping(value="/hello")
springboot自定义属性
先看一下pom.xml中使用的springboot版本:
<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.test</groupId>
<artifactId>springbootTest</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>war</packaging>
<build/>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.5.6.RELEASE</version>
</parent>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-resources-plugin</artifactId>
<version>2.4.3</version>
</dependency>
</dependencies>
</project>
我使用的是JDK7,使用JDK8会报错。
当咱们想要使用key-value的时候,有两种方式:
(1)能够把属性放在application.properties中
普通key-value的使用:
好比在application.properties中添加一个key-value:test=spring boot \u4F60\u5927\u7237(自动编码的)(spring boot 你大爷)。注意这个文件application.properties的编码不是utf-8,不要改变这个。
在Controller中的使用:
package test1;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class Controller1 {
@Value("${test}")
private String test;
@RequestMapping(value="/hello")
public String hello(){
return "a:"+test;
}
}
带有前缀的key-value的使用:
好比在application.properties中添加一个key-value:mysql.name=hello。
在Controller中的使用:
package test1;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class Controller1 {
@Value("${mysql.name}")
private String test;
@RequestMapping(value="/hello")
public String hello(){
return "a:"+test;
}
}
(2)也能够放在一个配置类(ConfigrationProperties属性)中,实际上这个类被扫描以后,里面的key-value仍是被放在application.properties中的
建立配置类(注意放在src/main/java下,由于springboot默认扫描的是与主类同包或子包下):
package test1;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component;
@Component
@ConfigurationProperties(prefix="mysql")//属性前缀
public class MysqlProperties {
private String name="myname";
private String age="myage";
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getAge() {
return age;
}
public void setAge(String age) {
this.age = age;
}
}
Controller使用:
package test1;
import javax.annotation.Resource;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class Controller1 {
@Resource
private MysqlProperties test;
@RequestMapping(value="/hello")
public String hello(){
return "name:"+test.getName()+"</br>"+"age:"+test.getAge();
}
}
application.properties配置文件中不用作什么配置。
springboot的freemark支持(模板)
(1)pom.xml中添加freemarker支持
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-freemarker</artifactId>
</dependency>
(2)Controller使用
package test1;
import javax.annotation.Resource;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.servlet.ModelAndView;
@RestController
public class Controller1 {
@RequestMapping(value="/hello")
public ModelAndView hello(){
ModelAndView mode = new ModelAndView();
mode.addObject("message","spring boot 你大爷");
mode.setViewName("a");//页面的名字
return mode;
}
}
(3)application.properties文件
server.context-path=/context(不变,这里是URL访问Controller的路径的配置,与freemarker无关)
(4)页面
在src/main/resources下建立templates文件夹(springboot能够识别这个名字的文件夹)
首先建立一个a.html,里面添加的内容是:
而后将a.html文件更名为a.ftl。
(5)访问的URL:http://localhost:8080/context/hello