springboot学习(3)springboot使用jsp完成数据的页面展示

来源:互联网 发布:mac os 壁纸 编辑:程序博客网 时间:2024/05/16 13:53

上一篇文章介绍了使用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,可以看到如下页面,说明已经成功了(没有任何样式,这个不是介绍的重点)



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

/** * @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="提交" onclick="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");来代替上面的写法。

阅读全文
1 0