SpringBoot
案例一
1、导入依赖
</properties> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>1.4.1.RELEASE</version> </parent> <dependencies> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.11</version> <scope>test</scope> </dependency>
<dependency> <!-- spring-boot-starter-web是为我们提供了包括mvc,aop等需要的一些jar --> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> <!-- 因为我们已经配置了 parent 中的version 所以这里不需要指定version了 --> </dependency>
2、创建FirstController类
@RestController public class FirstController { @RequestMapping("/firstController") public String firstController(){ System.out.println("第一个请求"); return "Hello SpringBoot"; } }
3创建StartSpringBoot 测试类
@SpringBootApplication public class StartSpringBoot { public static void main(String[] args) { SpringApplication.run(StartSpringBoot.class,args); } }
控制台输出
. ____ _ __ _ _ /\\ / ___'_ __ _ _(_)_ __ __ _ \ \ \ \ ( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \ \\/ ___)| |_)| | | | | || (_| | ) ) ) ) ' |____| .__|_| |_|_| |_\__, | / / / / =========|_|==============|___/=/_/_/_/ :: Spring Boot :: (v1.4.1.RELEASE) 2019-12-10 16:19:28.638 INFO 12836 --- [ main] com.wdksft.StartSpringBoot : Starting StartSpringBoot on LAPTOP-98IAV276 with PID 12836 (E:\San\SpringBoot\springboot(1)\springboot\target\classes started by s in E:\San\SpringBoot\springboot(1)\springboot) 2019-12-10 16:19:28.647 INFO 12836 --- [ main] com.wdksft.StartSpringBoot : No active profile set, falling back to default profiles: default 2019-12-10 16:19:28.904 INFO 12836 --- [ main] ationConfigEmbeddedWebApplicationContext : Refreshing org.springframework.boot.context.embedded.AnnotationConfigEmbeddedWebApplicationContext@1c1bced: startup date [Tue Dec 10 16:19:28 CST 2019]; root of context hierarchy 2019-12-10 16:19:32.255 INFO 12836 --- [ main] s.b.c.e.t.TomcatEmbeddedServletContainer : Tomcat initialized with port(s): 8080 (http) 2019-12-10 16:19:32.278 INFO 12836 --- [ main] o.apache.catalina.core.StandardService : Starting service Tomcat 2019-12-10 16:19:32.280 INFO 12836 --- [ main] org.apache.catalina.core.StandardEngine : Starting Servlet Engine: Apache Tomcat/8.5.5 2019-12-10 16:19:32.574 INFO 12836 --- [ost-startStop-1] o.a.c.c.C.[Tomcat].[localhost].[/] : Initializing Spring embedded WebApplicationContext 2019-12-10 16:19:32.574 INFO 12836 --- [ost-startStop-1] o.s.web.context.ContextLoader : Root WebApplicationContext: initialization completed in 3683 ms 2019-12-10 16:19:33.083 INFO 12836 --- [ost-startStop-1] o.s.b.w.servlet.ServletRegistrationBean : Mapping servlet: 'dispatcherServlet' to [/] 2019-12-10 16:19:33.095 INFO 12836 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean : Mapping filter: 'characterEncodingFilter' to: [/*] 2019-12-10 16:19:33.096 INFO 12836 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean : Mapping filter: 'hiddenHttpMethodFilter' to: [/*] 2019-12-10 16:19:33.097 INFO 12836 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean : Mapping filter: 'httpPutFormContentFilter' to: [/*] 2019-12-10 16:19:33.098 INFO 12836 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean : Mapping filter: 'requestContextFilter' to: [/*] 2019-12-10 16:19:33.992 INFO 12836 --- [ main] s.w.s.m.m.a.RequestMappingHandlerAdapter : Looking for @ControllerAdvice: org.springframework.boot.context.embedded.AnnotationConfigEmbeddedWebApplicationContext@1c1bced: startup date [Tue Dec 10 16:19:28 CST 2019]; root of context hierarchy 2019-12-10 16:19:34.159 INFO 12836 --- [ main] s.w.s.m.m.a.RequestMappingHandlerMapping : Mapped "{[/firstController]}" onto public java.lang.String com.wdksft.cotroller.FirstController.firstController() 2019-12-10 16:19:34.171 INFO 12836 --- [ main] s.w.s.m.m.a.RequestMappingHandlerMapping : Mapped "{[/error]}" onto public org.springframework.http.ResponseEntity<java.util.Map<java.lang.String, java.lang.Object>> org.springframework.boot.autoconfigure.web.BasicErrorController.error(javax.servlet.http.HttpServletRequest) 2019-12-10 16:19:34.172 INFO 12836 --- [ main] s.w.s.m.m.a.RequestMappingHandlerMapping : Mapped "{[/error],produces=[text/html]}" onto public org.springframework.web.servlet.ModelAndView org.springframework.boot.autoconfigure.web.BasicErrorController.errorHtml(javax.servlet.http.HttpServletRequest,javax.servlet.http.HttpServletResponse) 2019-12-10 16:19:34.250 INFO 12836 --- [ main] o.s.w.s.handler.SimpleUrlHandlerMapping : Mapped URL path [/webjars/**] onto handler of type [class org.springframework.web.servlet.resource.ResourceHttpRequestHandler] 2019-12-10 16:19:34.250 INFO 12836 --- [ main] o.s.w.s.handler.SimpleUrlHandlerMapping : Mapped URL path [/**] onto handler of type [class org.springframework.web.servlet.resource.ResourceHttpRequestHandler] 2019-12-10 16:19:34.300 INFO 12836 --- [ main] .m.m.a.ExceptionHandlerExceptionResolver : Detected @ExceptionHandler methods in exceptionHan 2019-12-10 16:19:34.372 INFO 12836 --- [ main] o.s.w.s.handler.SimpleUrlHandlerMapping : Mapped URL path [/**/favicon.ico] onto handler of type [class org.springframework.web.servlet.resource.ResourceHttpRequestHandler] 2019-12-10 16:19:34.794 INFO 12836 --- [ main] o.s.j.e.a.AnnotationMBeanExporter : Registering beans for JMX exposure on startup 2019-12-10 16:19:34.990 INFO 12836 --- [ main] s.b.c.e.t.TomcatEmbeddedServletContainer : Tomcat started on port(s): 8080 (http) 2019-12-10 16:19:35.002 INFO 12836 --- [ main] com.wdksft.StartSpringBoot : Started StartSpringBoot in 7.743 seconds (JVM running for 11.854)
网页访问
二、SpringBoot静态资源访问
1、在resources文件下创建static包,再static下创建img包
三、SpringBoot解决异常问题
1、在Controller类中定义一个异常
@RestController public class FirstController { @RequestMapping("/firstController") public String firstController(){ int result=5/0; System.out.println("第一个请求"); return "Hello SpringBoot"; } }
2. 定义异常类
@ControllerAdvice public class ExceptionHan { @org.springframework.web.bind.annotation.ExceptionHandler(RuntimeException.class) @ResponseBody public Map<String,Object> exceHandler(){ Map<String,Object> map=new HashMap<>(); map.put("error","500"); map.put("msg","异常"); return map; }
3、结果如下
四、SpringBoot使用freemarker
1、导入依赖freemarker
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-freemarker</artifactId> </dependency>
2、配置application.propertiesleuk文件
## Freemarker 配置 spring.freemarker.template-loader-path=classpath:/templates/ spring.freemarker.cache=false spring.freemarker.charset=UTF-8 spring.freemarker.check-template-location=true spring.freemarker.content-type=text/html spring.freemarker.expose-request-attributes=false spring.freemarker.expose-session-attributes=false spring.freemarker.request-context-attribute=request spring.freemarker.prefix=/ spring.freemarker.suffix=.ftl
3、在resources包下创建templates包并创建holle.ftl模板
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>SpringBoot整合FreeMarker</title> </head> <body> 欢迎: ` ${name} <#list stulist as stu> ${stu.stu_name} </#list> <#if 1==1> 等等等等!!! </#if> <#list userList as user> ${user} </#list> </body> </html>
4、创建StartSpringBoot启动类
package com.freemarker; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; @SpringBootApplication public class StartSpringBoot { public static void main(String[] args){ SpringApplication.run(StartSpringBoot.class,args); } }
5、创建Controller类freemarkerController类
package com.freemarker.Controller; import com.freemarker.entity.student; import org.springframework.stereotype.Controller; import org.springframework.ui.ModelMap; import org.springframework.web.bind.annotation.RequestMapping; import java.util.ArrayList; import java.util.List; @Controller @RequestMapping("/free") public class freemarkerController { @RequestMapping("/freeFirst") public String freeFirst(ModelMap map){ map.put("name","张三"); return "hello"; //找templates/name.ftl } @RequestMapping("/freeSecond") public String freeSecond(ModelMap map){ List<String> list=new ArrayList<>(); list.add("张三"); list.add("李四"); list.add("王五"); map.put("userList",list); return "hello"; } @RequestMapping("/freeThread") public String freeThread(ModelMap map){ List<student> list=new ArrayList<>(); student stu=new student(); stu.setStu_id(1); stu.setStu_name("小王"); list.add(stu); map.put("stulist",list); return "hello"; } }
6、页面访问实现效果如下