|
<%@ page language="java" import="java.util.*" pageEncoding="gbk"%>
<HTML>
<head>
<title>使用Ajax实现自动提示功能</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">
-->
<style type="text/css">
body{font:11px arial;}
.suggest_link{
background-color:#FFFFFF;
padding:2px 6px 2px 6px;
}
.suggest_link_over{
background-color:#E8F2FE;
padding:2px 6px 2px 6px;
}
#suggest{
position:absolute;
background-color:#E82FE;
text-align:left;
border:1px solid #000000;
display:none;
}
</style>
<script type="text/javascript">
var xmlHttp;//声明浏览器初始化对象变量
function searchSuggest(){
try {
xmlHttp = new ActiveXObject("Msxml2.XMLHTTP");
} catch (e) {
try {
xmlHttp = new ActiveXObject("Microsoft.XMLHttp");
} catch (e) {
try {
xmlHttp = new XMLHttpRequest();
//针对某些特定版本的mozillar浏览器的BUG进行修正
if(xmlHttp.overrideMimeType){
//强制将MIME类型设置为text/xml
xmlHttp.overrideMimeType("text/xml");
}
} catch (e) {
// TODO: handle exception
}
}
}
//创建请求结果处理程序
xmlHttp.onreadystatechange = processRequest;
var str = document.getElementById("txtSearch").value;
if(xmlHttp!=null){
alert(str);
xmlHttp.open("GET","SearchSuggestServlet?seach="+str,true);
xmlHttp.send(null);
}else{
alert("不能创建XMLHttpRequest对象实例");
}
}
//给String对象添加去除左右空格方法
/*
String.prototype.trim = function(){
var m = this.match(/^\s*(\S+(\s+\S+)*)\s*$/);
return (m==null)? "":m[1];
}*/
//对返回数据进行处理
function processRequest(){
if(xmlHttp.readyState == 4){//请求响应完成
if(xmlHttp.status == 200){
//responseTest表示请求完成后,返回字符串信息
var sobj = document.getElementById("suggest");
sobj.innerHTML;
var str = xmlHttp.responseText.split("-");
var suggest = "";
if(str.length > 0 && str[0].length>0){
for(var i = 0;i<str.length;i++){
suggest += "<div onmouseover='javascript:suggestOver(this);'";
suggest += "onmouseover='javascript:suggestOver(this);'";
suggest += "onclick='javascript:setSearch(this.innerHTML);''";
suggest += "class='suggest_link'>"+str+"</div>";
}
sobj.innerHTML=suggest;
document.getElementById("suggest").style.display="block";
}else{
document.getElementById("suggest").style.display="none";
}
}else{
alert("请求处理返回的数据有错误...");
alert(xmlHttp.status);
}
}
}
function suggestOver(obj){
obj.className ="suggest_link_over";
}
function suggestOut(obj){
obj.className ="suggest_link";
}
</script>
</head>
<body>
<h3>Ajax实现搜索提示</h3>
<div style="width:500px;">
<form action="" id="formSearch">
<input type="text"" id="txtSearch" name="txtSearch" value="" onkeyup="searchSuggest()" autocomplete="off"/>
<input type="submit" id="cmdSearch" name="cmdSearch" value="搜索" /><br>
<div id="suggest" style="width:200px;"></div>
</form>
</div>
</body>
</html>
package Example_Ajax_P296;
import java.io.IOException;
import java.io.PrintWriter;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.ArrayList;
import java.util.List;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class SearchSuggestServlet extends HttpServlet {
/**
* Constructor of the object.
*/
public SearchSuggestServlet() {
super();
}
/**
* Destruction of the servlet. <br>
*/
public void destroy() {
super.destroy(); // Just puts "destroy" string in log
// Put your code here
}
/**
* The doGet method of the servlet. <br>
*
* This method is called when a form has its tag value method equals to get.
*
* @param request the request send by the client to the server
* @param response the response send by the server to the client
* @throws ServletException if an error occurred
* @throws IOException if an error occurred
*/
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
String str = new String(request.getParameter("seach").getBytes("ISO-8859-1"));
PrintWriter out = response.getWriter();
List strList = new ArrayList();
Connection conn = null;
PreparedStatement ps = null;
ResultSet rs = null;
String sql = "select distinct(title) from MESSAGE where title like '%" + str + "%' order by title";
try {
if(str!=null && str.length()>0){
Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
String url = "jdbc:sqlserver://localhost:1433;DataBaseName=company";
conn = DriverManager.getConnection(url, "sa", "89757");
ps = conn.prepareStatement(sql);
rs = ps.executeQuery();
while(rs.next()){
strList.add(rs.getString("title"));
}
}
StringBuffer sbu = new StringBuffer();
int size = strList.size();
for(int i=0;i<size;i++){
sbu.append((String)strList.get(i)+"-");
}
out.print(sbu.toString());
request.getSession().setAttribute("a", sbu.toString());
response.sendRedirect("MyJsp.jsp");
out.flush();
out.close();
} catch (Exception e) {
// TODO: handle exception
e.printStackTrace();
}
}
/**
* The doPost method of the servlet. <br>
*
* This method is called when a form has its tag value method equals to post.
*
* @param request the request send by the client to the server
* @param response the response send by the server to the client
* @throws ServletException if an error occurred
* @throws IOException if an error occurred
*/
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
this.doGet(request, response);
}
/**
* Initialization of the servlet. <br>
*
* @throws ServletException if an error occurs
*/
public void init() throws ServletException {
// Put your code here
}
} |
|