A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

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

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

  • [AppleScript] 纯文本查看 复制代码
    [html] view plain copy
    <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>  




全部查询及展示的接口

  • [AppleScript] 纯文本查看 复制代码
    [java] view plain copy
    @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;  
    } 



前台页面

  • [AppleScript] 纯文本查看 复制代码
    [html] view plain copy
    <%@ 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> 



此时我们就可以运行了。

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

[AppleScript] 纯文本查看 复制代码
[java] view plain copy
/** 
     * @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包:

  • [AppleScript] 纯文本查看 复制代码
    [html] view plain copy
    <%@ 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="提交"/>  
            </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中进行统一的配置,如下:

[AppleScript] 纯文本查看 复制代码
[plain] view plain copy
spring.mvc.view.prefix=/WEB-INF/views/  
spring.mvc.view.suffix=.jsp  




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

4 个回复

倒序浏览
回复 使用道具 举报
来看看了,谢谢分享
回复 使用道具 举报
来看看了,谢谢分享
回复 使用道具 举报
来看看了,谢谢分享
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马