五 Spring Boot web开发

目录

五 Spring Boot web开发

5.1静态资源的访问

5.2 自动返回json格式数据

5.3 全局捕获异常

5.4 渲染Web页面

5.5 Freemarker的使用

第一步:

第二步:

第三步:创建.ftl模板文件

5.6 SpringBoot 使用jsp


五 web开发

5.1静态资源的访问

在我们开发Web应用的时候,需要引用大量的js、css、图片等静态资源。

Spring Boot默认提供静态资源目录位置需置于classpath下,目录名需符合如下规则:

/static

/public

/resources

/META-INF/resources

举例:我们可以在src/main/resources/目录下创建static,在该位置放置一个图片文件。启动程序后,尝试访问http://localhost:8080/imgs/d.jpg。如能显示图片,配置成功。

5.2 自动返回json格式数据

@RestController//相当于声明Controller,提供restful风格
public class UserController{
    @RequestMapping("/login")//映射路径
    @ResponseBody//响应体-自动返回json格式字符串
    public Map<String,Object> login(String username,String password){
        Map<String,Object> map = new HashMap<String,Object>();
            if("gyf".equals(username) && "123".equals(passwprd)){
                map.put("success",1);
                map.put("errMsg","")
            }else{
                map.put("success",0);
                map.put("errMsg","用户名或密码不正确");
        }
            //返回map
            return map;

    }
}

5.3 全局捕获异常

@ExceptionHandler 表示拦截异常

@ControllerAdvice

controller的一个辅助类,最常用的就是作为全局异常处理的切面类

可以指定扫描范围

约定了几个返回值,如果是直接返回model类的话,需要使用

@ResponseBody进行json格式转换

案例:在com.gyf.web.exception包中定义一个全局异常类

@ControllerAdvice//切面
public class GlobalExceptionHandler {

	@ExceptionHandler(RuntimeException.class)//捕获运行时异常
	@ResponseBody
	public Map<String,Object> exceptionHander(){
		Map<String, Object> map = new HashMap<String, Object>();
		map.put("errorCode", "101");
		map.put("errorMsg", "系統错误!");
		return map;
	}
}

在启动spring中,配置扫描包为com.gyf.web

@ComponentScanner(basePackages="com.gyf.web")
@EnableAutoConfigration
public class APP{
     public static void mian(String [] args){
        SpringAppliaction.run(APP.class,args);
    }
}

在某个映射的方法中添加个int i = 10/0的算术异常

@RestController//相当于声明一个Controller,提供restful风格
public class UserController{
    @RequestMapping("/login")//映射路径
    @ResponseBody//响应体-自动返回json格式的字符串
    public Map<String,Object> login(String username,String password){
        int i =10/0;
        Map<String,Object> map = new HashMap<String,Object>();
        if("gyf".equals(username) && "123".equals(password)){
            map.put("success",1);
            map.put("errMsg","");
        }else{
            map.put("success",0);
            map.put("errMsg","系统错误")

        }
        return map;
    }
}

访问上的个路径结果为

5.4 渲染Web页面

模板引擎

在动态HTML实现上Spring Boot依然可以完美胜任,并且提供了多种模板引擎的默认配置支持,所以在推荐的模板引擎下,我们可以很快的上手开发动态网站。

Spring Boot提供了默认配置的模板引擎主要有以下几种:

  • Thymeleaf
  • FreeMarker
  • Velocity
  • Groovy
  • Mustache

Springboot+freemarker

SpringBoot建议使用这些模版引擎,避免使用JSP,若一定要使用JSP将无法使用Spring Boot的多种特性,具体可见后文:

支持JSP的配置

当你使用上述模版中的任何一个,它们默认的模版配置路径为:src/main/resources/templates。当然也可以修改这个路径,具体如何修改,可在后续各模版引擎的配置属性汇中查询并修改

5.5 Freemarker的使用

第一步:

<!--引用freemarker的依赖包->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactld>spring-boot-starter-freemarker</artifactld>
</dependency>

第二步:

写个控制器,并返回数据

@Controller//如果要访问freemarker模版,就不要用RestController
@RequestMapping("/stu")
public class StudentController{
    @RequestMapping("/list")
    public String list(Map<String,Object>,data){
        //添加数据
        date.put("loginname","gyf");
        date.put("age",32);
        list<Student> list = new ArrayList<Student>();
        list.add(new Student(1001,"张三","男"));
        list.add(new Student(1001,"李四","男"));
        list.add(new Student(1001,"小丽","女"));
        data.put("stuList",list);
        return "stu/list";
    }
}

第三步:创建.ftl模板文件

  • 在src/main/resources/创建一个templates文件夹,后缀为*.ftl
  • 掌握如何取值和判断
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8" />
<title></title>
</head>
<body>
	  欢迎${loginname}
	  <#if age <= 17>小哥
	  <#elseif age <= 30>先生
	  <#else>大叔
	  </#if>登录
	  <table border="1">
	  	<tr>
	  		<td>ID</td>
	  		<td>名字</td>
	  		<td>性别</td>
	  	</tr>
	  	<#list stuList?sort_by("id")?reverse as stu>
		 	<tr>
		  		<td> ${stu.id}</td>
		  		<td> ${stu.name}</td>
		  		<td> ${stu.gender}</td>
	  	    </tr>
		</#list>
	  </table>
</body> 
</html>

5.6 SpringBoot 使用jsp

Step1:创建war maven工程

Step2:pom文件引入以下依赖

<parent>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-starter-parent</artifactId>
		<version>1.3.3.RELEASE</version>
	</parent>
	<dependencies>
		<!-- SpringBoot 核心组件 -->
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-web</artifactId>
		</dependency>
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-tomcat</artifactId>
		</dependency>
		<dependency>
			<groupId>org.apache.tomcat.embed</groupId>
			<artifactId>tomcat-embed-jasper</artifactId>
		</dependency>
	</dependencies>

Step3:application.properties创建以下配置

spring.mvc.view.prefix=/WEB-INF/view/
spring.mvc.view.suffix=.jsp

Step4:控制器代码

@Controller
@EnableAutoConfigration
@RequestMapping("/teacher")
public class TeacherController{
    public String list(){
        return "list";
    }
    public static void main(String [] args){
        SpringApplication.run(TeacherController.class,args);

    }
}

Step5:jsp

猜你喜欢

转载自blog.csdn.net/qq_43674132/article/details/92803290