程序员社区

springboot使用jsp完成数据的页面展示

上一篇文章介绍了使用JdbcTemplate完成对数据库的增删改查,使用了postman工具测试了功能是否实现,这一篇介绍如何调用springboot的后台接口,将数据真正展示出来。这里使用jsp进行页面展示,虽然springboot强烈不推荐使用jsp,而是推荐使用Themeleaf,但是很多人习惯使用jsp(包括我),这里先使用jsp做springboot的入门介绍,也可以更好的理解。


还是继续在第二篇的基础上做,代码稍加修改即可,添加几处依赖,如下:

<dependency>
        <groupId>org.apache.tomcat.embed</groupId>
        <artifactId>tomcat-embed-jasper</artifactId>
        <scope>provided</scope>
</dependency>
<dependency>
        <groupId>javax.servlet</groupId>
        <artifactId>jstl</artifactId>
        <scope>runtime</scope> 
</dependency>
<dependency>  
   	<groupId>javax.servlet</groupId>  
   	<artifactId>javax.servlet-api</artifactId>  
</dependency> 

全部查询及展示的接口

@RequestMapping("/list")
	public ModelAndView  itemsList() {
		String sql = "select * from items";
		List<Map<String, Object>> list = jdbcTemplate.queryForList(sql);
		ModelAndView mav = new ModelAndView("/WEB-INF/views/items.jsp");
		mav.addObject("list", list);
		return mav;
}

前台页面

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>  
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>springboot学习</title>
</head>
<body>
	<c:forEach items="${list}" var="item" varStatus="vs"> 
		<h1>这是标题:${item.title}</h1>
		<p>这是作者:${item.name}</p>
		<a>这是内容:${item.detail}</a>
	</c:forEach>
</body>
</html>

此时我们运行http://localhost:8080/items/list,可以看到如下页面,说明已经成功了(没有任何样式,这个不是介绍的重点)

springboot使用jsp完成数据的页面展示插图

接着,实现新增的功能,后台接口如下:

/**
	 * @return
	 * 跳转到新增接界面
	 */
	@RequestMapping("/toAdd")
	public ModelAndView  toAdd() {
		ModelAndView mav = new ModelAndView("/WEB-INF/views/add.jsp");
		return mav;
	}
	

	/**
	 * 新增数据
	 * @param items
	 * @return
	 */
	@RequestMapping("/add")
	public @ResponseBody boolean  addItems(Items items) {
		String sql = "insert into items (title,name,detail) value (?,?,?)";
		Object args[] = {items.getTitle(),items.getName(),items.getDetail()};  
		int temp = jdbcTemplate.update(sql, args); 
		if(temp > 0) {
			return true;
		}
		return false;
	}

前端代码,这里使用ajax进行前后台数据的交互,引入一个jquery包:

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>  
<%
String path = request.getContextPath();
%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>springboot学习</title>
<script type="text/javascript" src="<%=path%>/js/jquery-1.8.3.js"></script>
</head>
<body>
    <div>
    	<form name="addItems" >
  			<input type="text" name="title"><br>
  			<input type="text" name="name"><br>
  			<input type="text" name="detail"><br>
  			<input type="button" value="提交" οnclick="return add()"/>
  		</form>
    </div>
</body>
<script type="text/javascript">
		function add(){
			var title = addItems.title.value;
			var name = addItems.name.value;
			var detail = addItems.detail.value;
			 $(document).ready(function(){
				$.post("<%=path%>/items/add",
				{"title":title,"name":name,"detail":detail},
				function(data){
	 				if(data == true){
	 					alert("新建成功");
	 				}
	 				if(data == false){
	 					alert("新建失败");
	 				}
	 			});
			});
		}
	</script>
</html>

在前台输入标题,姓名及内容点击提交,会提示新建成功,数据成功被写入数据库,对于修改,删除基本和新增代码基本无差别,这里就不啰嗦了。


这里做一个解释:

在使用@RestController注解时,控制器类中的方法无法直接返回jsp页面,视图解析器InternalResourceViewResolver不起作用,返回的内容就是Return 里的内容。

比如:这里需要返回items.jsp页面,return "items.jsp"时他直接将items.jsp作为数据返回。

因为@RestController注解相当于@ResponseBody + @Controller合在一起的作用,所以如果需要返回到指定页面,则需要用 @Controller配合视图解析器InternalResourceViewResolver才行,可以利用ModelAndView返回jsp视图。


ModelAndView mav = new ModelAndView("/WEB-INF/views/items.jsp");

这样配置视图的路径可能有点麻烦,很多时候我们jsp都是放在某个文件夹下的,可以在application.properties中进行统一的配置,如下:

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


这样就可以使用ModelAndView mav = new ModelAndView("items");来代替上面的写法。

赞(0) 打赏
未经允许不得转载:IDEA激活码 » springboot使用jsp完成数据的页面展示

一个分享Java & Python知识的社区