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>
至此,这个小小的前后台交互的流程和功能就做好了。
- servlet+mysql实现简单报表显示
- 报表 ireport 基于Servlet实现
- rdlc 报表实现百分比显示
- Servlet的简单实现
- 简单的servlet实现
- 简单的Servlet实现
- C#一个简单报表实现
- Mysql+servlet实现分页
- oracle分页显示的servlet例子——相比mysql简单多了,哈哈!
- 搭建简单的servlet&MySQL
- JasperReport + Servlet Web应用之:HTML显示报表内容
- Servlet+AJAX实现数据处理显示
- ajax+servlet+css实现简单的页面刷新和显示控制
- 用jsp+Servlet实现简单的提交表单并显示的注册
- devexpress 水晶报表控件 实现递归显示
- [水晶报表]实现RDLC 网格显示
- 快逸V5实现报表按比例显示
- [javaEE]JSP+Servlet+Mysql实现图片上传和分页显示(后续还会更新功能)
- 关于equals()的使用
- 论写代码注释的重要性
- Java Web项目启动加载顺序
- 2015年ACM北京网络赛 B题 (模拟+枚举题意请原谅我英语不好。。。)
- java学习之IO字节流
- servlet+mysql实现简单报表显示
- 《机器学习实战》学习笔记:Logistic回归&预测疝气病证的死亡率
- 对JSONObject中的数据进行排序
- bat 初试
- Mysql 零散知识点
- SQL语句
- 【IOS 开发学习总结-OC-9】★ objective-c面向对象之——方法
- Java的虚拟机存储 堆栈与GC概要
- Linux中的孤儿进程