servlet+mysql实现简单报表显示

首先,有两个问题需要强调一下。一个是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>

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

你可能感兴趣的:(java,mysql,servlet)