ajax 调用onblur检查用户名是否存在时提示404 NOT FOUND错误

lymne 2013-05-28 09:28:19
index.jsp// 首页,在这里输入用户名查询

<!doctype html>
<html lang="en">
<head>
<meta charset="gbk">
<title>Document</title>
</head>
<body>
<script>
window.onload = initPage;
function initPage() {
document.getElementById("userid").onblur = checkUserid;//引用函数方法
}
function createRequest() {
try {
request = new XMLHttpRequest();
} catch (tryMS) {
try {
request = new ActiveXObject("Msxml2.XMLHTTP");
} catch (otherMS) {
try {
request = new ActiveXObject("Microsoft.XMLHTTP");
} catch (failed) {
request = null;
}
}
}
return request;
}
function checkUserid(){
request=createRequest();
var theName = document.getElementById("userid").value;
request.open("GET","CheckServlet?userid="+theName,true);
request.onreadystatechange=checkUseridCallback;
request.send(null);
document.getElementById("msg").innerHTML="正在验证...";

}

function checkUseridCallback(){
if(request.readyState==4){
if(request.status==200){
if( text=="true"){
flag=false;
document.getElementById("msg").innerHTML="用户ID重复";
}else{
flag=true;
document.getElementById("msg").innerHTML="此用户ID可以注册";
}
}
}
}
</script>
<form action="index.jsp" method="GET" ">
用户ID: <input type="text" id="userid" name="userid">
<span id="msg"></span>
<br>
姓名 <input type="text" name="name" >
</form>
</body>
</html>



package org.lxh.ajaxdemo;
import java.io.*;
import java.sql.*;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.*;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpServlet;
public class CheckServlet extends HttpServlet{
public static final String DBDRIVER="com.mysql.jdbc.Driver";
public static final String DBURL="jdbc:mysql://localhost:8889/username?characterEncoding=gbk";
public static final String DBUSER="root";
public static final String DBPASS="root";
public void doGet(HttpServletRequest request,HttpServletResponse response)
throws ServletException,IOException{
this.doPost(request, response);
}
public void doPost(HttpServletRequest request,HttpServletResponse response)
throws ServletException,IOException{
request.setCharacterEncoding("gbk");
response.setContentType("text/html");
Connection conn=null;
PreparedStatement pstmt=null;
ResultSet rs=null;
PrintWriter out=response.getWriter();
String userid=request.getParameter("userid");
try{
Class.forName(DBDRIVER);
conn=DriverManager.getConnection(DBURL,DBUSER,DBPASS);
String sql=" select * from name where username=?";
pstmt=conn.prepareStatement(sql);
pstmt.setString(1,userid);
rs=pstmt.executeQuery();
if(rs.next()){
if(rs.getInt(1)>0){
out.println("true");

}else{
out.println("false");
}
}
out.close();

}catch(Exception e){
e.printStackTrace();
}finally{
try{
conn.close();
}catch(SQLException e){
e.printStackTrace();
}
}
}
}


...全文
138 10 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
lymne 2013-05-29
  • 打赏
  • 举报
回复
引用 9 楼 zhongxianyao 的回复:
改为rs.getString("password") == password
password也要传进来


我这里没有弄密码验证。只单纯验证用户名是否存在。
数据库只有一个表,name
里面有三个人名如下图


当我输入jack的时候,它仍旧是判定为false的,所以还是可以注册。
我改成这样
if(rs.next()){
if(rs.getString("username")==userid){
out.println("true");

}else{
out.println("false");
}
还是不行啊
编程点滴 2013-05-28
  • 打赏
  • 举报
回复
改为rs.getString("password") == password password也要传进来
lymne 2013-05-28
  • 打赏
  • 举报
回复
引用 7 楼 zhongxianyao 的回复:
哦,那估计是数据库那边的连接出错了,因为数据库那边我没有运行
问题大概解决了,的确是数据库链接的问题,谢谢你的回答好人一生平安。 不过还有一个剩余的问题就是 String sql=" select * from name where username=?"; pstmt=conn.prepareStatement(sql); pstmt.setString(1,userid); rs=pstmt.executeQuery(); if(rs.next()){ if(rs.getInt(1)>0){ //这里验证方法应该是错的,怎么改呢? out.println("true");//如果有该用户名则返回true信息 }else{ out.println("false"); } 这里永远都是out.println("false"),不管用户名存不存在。为什么呢?导致 if(request.readyState==4){ if(request.status==200){ if( request.responseText=="true"){ document.getElementById("msg").innerHTML="用户ID重复"; //这段话永远执行不到 }else{ document.getElementById("msg").innerHTML="此用户ID可以注册"; } } }
编程点滴 2013-05-28
  • 打赏
  • 举报
回复
哦,那估计是数据库那边的连接出错了,因为数据库那边我没有运行
lymne 2013-05-28
  • 打赏
  • 举报
回复
引用 5 楼 zhongxianyao 的回复:
试一下吧,我运行了一下是这样的,不知你那边的情况怎么样
改了还是不行啊,泪奔~~应该不是数据库链接那边的错误吧?
编程点滴 2013-05-28
  • 打赏
  • 举报
回复
试一下吧,我运行了一下是这样的,不知你那边的情况怎么样
编程点滴 2013-05-28
  • 打赏
  • 举报
回复
你的<url-pattern>配置错了,去掉/ajaxdemo 改为如下:

<servlet>
    <description></description>
    <display-name>CheckServlet</display-name>
    <servlet-name>CheckServlet</servlet-name>
    <servlet-class>org.lxh.ajaxdemo.CheckServlet</servlet-class>
  </servlet>
  <servlet-mapping>
    <servlet-name>CheckServlet</servlet-name>
    <url-pattern>/CheckServlet</url-pattern>
  </servlet-mapping>
lymne 2013-05-28
  • 打赏
  • 举报
回复
引用 1 楼 zhongxianyao 的回复:
你看一下你的web.xml有没有对servlet进行配置先,再在servlet中输出一句话,看是否有进入该方法
配置在楼下。
lymne 2013-05-28
  • 打赏
  • 举报
回复
编程点滴 2013-05-28
  • 打赏
  • 举报
回复
你看一下你的web.xml有没有对servlet进行配置先,再在servlet中输出一句话,看是否有进入该方法

81,122

社区成员

发帖
与我相关
我的任务
社区描述
Java Web 开发
社区管理员
  • Web 开发社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧