domain层:
package com.itheima.domain;
public class Word {
private int id;
private String word;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getWord() {
return word;
}
public void setWord(String word) {
this.word = word;
}
}
Dao层:
package com.itheima.dao;
import java.sql.SQLException;
import java.util.List;
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanListHandler;
import com.itheima.domain.Word;
import com.itheima.utils.JDBCUtils;
public class WordDao {
public List<Word> getWord(String word) throws SQLException {
QueryRunner queryRunner = new QueryRunner(JDBCUtils.getDataSource());
String sql = "select * from words where word like ? limit 5";
List<Word> list = queryRunner.query(sql, new BeanListHandler<Word>(Word.class), word+"%");
return list;
}
}
service业务层:
package com.itheima.service;
import java.sql.SQLException;
import java.util.List;
import com.itheima.dao.WordDao;
import com.itheima.domain.Word;
public class WordService {
public List<Word> getWord(String word) throws SQLException {
WordDao wordDao = new WordDao();
List<Word> list = wordDao.getWord(word);
return list;
}
}
Servlet层:
package com.itheima.servlet;
import java.io.IOException;
import java.util.List;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import com.itheima.domain.Word;
import com.itheima.service.WordService;
/**
* 仿百度页面的Servlet
*/
public class BaiduSearchServlet extends HttpServlet {
private static final long serialVersionUID = 1L;
protected void doGet(HttpServletRequest request,
HttpServletResponse response) throws ServletException, IOException {
try{
//中文处理
request.setCharacterEncoding("UTF-8");
//接受参数
String word = request.getParameter("word");
//调用业务层处理数据
WordService wordService = new WordService();
List<Word> list = wordService.getWord(word);
//将list存到request对象中
request.setAttribute("list", list);
//跳转页面
request.getRequestDispatcher("/search/info.jsp").forward(request, response);
}catch(Exception e){
e.printStackTrace();
throw new RuntimeException();
}
}
protected void doPost(HttpServletRequest request,
HttpServletResponse response) throws ServletException, IOException {
doGet(request, response);
}
}
Utils:
package com.itheima.utils;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import javax.sql.DataSource;
import com.mchange.v2.c3p0.ComboPooledDataSource;
/**
* JDBC的工具类
*
* @author jt
*
*/
public class JDBCUtils {
// 创建一个连接池:但是这个连接池只需要创建一次即可。
private static final ComboPooledDataSource dataSource = new ComboPooledDataSource();
/**
* 获得连接的方法
*
* @throws SQLException
*/
public static Connection getConnection() throws SQLException {
return dataSource.getConnection();
}
/**
* 获得连接池:
*/
public static DataSource getDataSource() {
return dataSource;
}
}
需要导入jquery-1.8.3.js文件;
jar包:
c3p0-0.9.1.2.jar
commons-dbutils-1.4.jar
fastjson-1.2.9.jar
jstl.jar
mysql-connector-java-5.0.8-bin.jar
standard.jar
xpp3_min-1.1.4c.jar
xstream-1.4.4.jar
还需要:search.js文件
前端页面;
info.jsp
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<html>
<head>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
</head>
<body>
<table border="1" style="width: 100%; margin-left: 380px">
<c:forEach var="w" items="${list}">
<tr>
<td>${w.word}</td>
</tr>
</c:forEach>
</table>
</body>
</html>
search.jsp页面:
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!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>Insert title here</title>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
<script type="text/javascript" src="${pageContext.request.contextPath}/js/jquery-1.8.3.js"></script>
<script type="text/javascript" src="${pageContext.request.contextPath}/search/search.js"></script>
</head>
<body>
<center>
<h1>百度一下</h1>
<input type="text" id="word" name="word"
style="width: 500px; height: 18px"> <input type="button"
value="百度一下"><br>
<div id="d1"
style="display: none; position: absolute; border: 1px solid grey; width: 500px; height: 20px">
</div>
</center>
</body>
</html>
简单的实现了一下仿百度搜索时的离焦事件,自己瞎捉摸的,有兴趣的可以看一下