首先,有两个问题需要强调一下。一个是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>
至此,这个小小的前后台交互的流程和功能就做好了。