servlet+mysql实现简单报表显示

来源:互联网 发布:js里面的extend 编辑:程序博客网 时间:2024/05/21 18:49

首先,有两个问题需要强调一下。一个是sendRedirect()的路径问题,另一个是form表单中action的路径问题。
1. sendRedirect()的路径问题。
如果你jsp页面是在项目的page目录下建议如下写
response.sendRedirect(request.getContextPath() + “/page/index.jsp”);
其他类似。

你的页面是在根目录下面
response.sendRedirect(request.getContextPath() + /index.jsp”);

2.form表单中的action的路径问题
如果action的对象是jsp文件,那就不讨论了。如果是java文件,可能有几个小问题需要注意下。
(1)这里有一个说明,可以看一下,比较详细。http://blog.sina.com.cn/s/blog_44aed6930100qfjw.html
(2)另外:以”/”开头的表示绝对地址,即web根目录,比如你用tomcat服务器,那么就是指webapp目录了;不以”/”开头的表示的是相对地址,即相对于当前这个页面的地址。详细说明http://blog.sina.com.cn/s/blog_9f33f9170102v7h4.html
3.需要添加相应的数据库驱动包。笔者这里是mysql,所以添加的是mysql的驱动包。
4.如果servlet查找出现404,建议手动到web.xml中配置。
5.进入正文,操作环境为myeclipse 10。
工程结构截图
(1)首先,我们需要建立四个包,然后存放一些必要的java类文件。beans下放的是数据描述类。例如:resourceBeans.java这个是和数据库中的一个数据对象相对应的。

package beans;import java.util.Date;public class resourceBeans {    private int resID;    private String url;    private Date valid;    public int getResID() {        return resID;    }    public void setResID(int resID) {        this.resID = resID;    }    public String getUrl() {        return url;    }    public void setUrl(String url) {        this.url = url;    }    public Date getValid() {        return valid;    }    public void setValid(Date valid) {        this.valid = valid;    }}

这里体现了三个操作对象,其中有资源ID等。
(2)然后是jdbc文件下,存放的是数据库连接文件。

package jdbc;import java.sql.Connection;import java.sql.DriverManager;import java.sql.ResultSet;import java.sql.Statement;public class jdbcConn {    private static String url = "jdbc:mysql://localhost:3306/resource";    private static String user = "xxx";    //此处为数据库用户名    private static String pass = "xxx";     //数据库密码    public static Connection conn;    public static ResultSet rs;    public static Statement st;    public static Connection getConnection(){        try {            Class.forName("com.mysql.jdbc.Driver");            conn = DriverManager.getConnection(url, user, pass);        } catch (Exception e) {            // TODO Auto-generated catch block            e.printStackTrace();        }        return conn;    }}

(3)service中存放的是业务处理的过程。

package service;import java.sql.Connection;import java.sql.ResultSet;import java.sql.SQLException;import java.sql.Statement;import java.util.ArrayList;import java.util.List;import jdbc.jdbcConn;import beans.resourceBeans;public class Service {    private Connection dbconnection;    private Statement st;    private ResultSet rs;    private String sql;    private List list;    private resourceBeans mResources;    public List getList(){        list = new ArrayList();        dbconnection =  jdbcConn.getConnection();        try {            st = (Statement)dbconnection.createStatement();            sql="select * from resource";            rs = st.executeQuery(sql);            while(rs.next()){                mResources = new resourceBeans();                mResources.setResID(rs.getInt("resourceID"));                mResources.setUrl(rs.getString("url"));                mResources.setValid(rs.getDate("valid"));                list.add(mResources);            }        } catch (SQLException e) {            // TODO Auto-generated catch block            e.printStackTrace();        }        return list;    }}

(4)servlet中为搭建前台和后台交互,这里采用的是session存放后台返回的数据。现实操作中,可以采用ajax,接受后台返回的json数据。

package servlet;import java.io.IOException;import java.io.PrintWriter;import java.util.List;import javax.servlet.ServletException;import javax.servlet.http.HttpServlet;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;import service.Service;public class ServletInfor extends HttpServlet {    /**     * Constructor of the object.     */    public ServletInfor() {        super();    }    public void destroy() {        super.destroy();     }    public void doGet(HttpServletRequest request, HttpServletResponse response)            throws ServletException, IOException {        this.doGet(request, response);    }    public void doPost(HttpServletRequest request, HttpServletResponse response)            throws ServletException, IOException {        Service service = new Service();        List list = service.getList();        request.getSession().setAttribute("resource", list);        try {            response.sendRedirect(request.getContextPath()+"/index.jsp");        } catch (IOException e) {            // TODO Auto-generated catch block            e.printStackTrace();        }    }    public void init() throws ServletException {        // Put your code here    }}

(5)jsp页面

<%@ page language="java" import="java.util.*,beans.*" contentType="text/html;charset=utf-8"%><%String path = request.getContextPath();String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";%><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"><html>  <head>    <base href="<%=basePath%>">    <title>Resource Test Jsp</title>    <meta http-equiv="pragma" content="no-cache">    <meta http-equiv="cache-control" content="no-cache">    <meta http-equiv="expires" content="0">        <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">    <meta http-equiv="description" content="This is my page">    <!--    <link rel="stylesheet" type="text/css" href="styles.css">    -->  </head>  <scipt type="text/javascript" src="jquery-2.1.4.min.js"></scipt>    <body>    <form action="servlet/ServletInfor" method="post">        <input type="submit" value="product" >    </form>   <table border="1" id="ta">   <tr>   <th colspan="3">资源列表</th>   </tr>    <tr>        <th>ID</th>        <th>URL</th>        <th>VALID</th>    </tr>  <%    List list = null;    if(session.getAttribute("resource")!=null){        list = (List)session.getAttribute("resource");        if(list.size()>0){            for(int i=0;i<list.size();i++){                resourceBeans res = new resourceBeans();                res = (resourceBeans)list.get(i);                %>                <tr>                <td><%=res.getResID() %></td>                <td><%=res.getUrl()%></td>                <td><%=res.getValid() %></td>                </tr>                <%            }        }    }  %>   </table>  </body></html>

至此,这个小小的前后台交互的流程和功能就做好了。

0 0
原创粉丝点击