0

0

利用ajax进行异步请求验证

巴扎黑

巴扎黑

发布时间:2017-07-03 10:34:27

|

1607人浏览过

|

来源于php中文网

原创

 场景描述:

登录程序大家都不陌生,但如果要注册,则必须保证用户的ID不能重复,这种检测用户ID的操作可以通过Ajax完成。

 

表结构:

 



异步验证


	
用户ID:
姓 名:
密 码:

servlet.java(当然  也可以配置成action,这个需要自己配置,不一定是要servlet的)


package zz.ajax;
import java.io.*;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.PreparedStatement;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class CheckServlet extends HttpServlet{
	public static final String DBDRIVER = "org.gjt.mm.mysql.Driver";
	public static final String DBURL = "jdbc:mysql://localhost:3306/zz";
	public static final String DBUSER = "root";
	public static final String DBPASSWORD = "mysql";

	public void doGet(HttpServletRequest request, HttpServletResponse response)
               throws ServletException,java.io.IOException{
		this.doPost(request, response);
	}

	public void doPost(HttpServletRequest request, HttpServletResponse response)
               throws ServletException,java.io.IOException{
		request.setCharacterEncoding("GBK");
		response.setContentType("text/html");		// 设置回应的MIME
		Connection conn = null;
		PreparedStatement pstmt = null;
		ResultSet rs = null;
		PrintWriter out = response.getWriter();		// 接收验证的userid
		String userid = request.getParameter("userid");
		try{
			Class.forName(DBDRIVER);	// 加载驱动
			conn = DriverManager.
				getConnection(DBURL, DBUSER, DBPASSWORD);	// 连接数据库

			String sql = "SELECT COUNT(userid) FROM user WHERE userid=?";
			pstmt = conn.prepareStatement(sql);
			pstmt.setString(1, userid);
			rs = pstmt.executeQuery();
			System.out.printf("*********");
			if (rs.next()){
				if (rs.getInt(1) > 0){		// 判断ID是否已存在
					out.print("true");		// 已存在
				}else {
					out.print("false");
				}
			}
			out.close();
			
		}catch (Exception e){
			e.printStackTrace();
		}finally {
			try{
				conn.close();
			}catch (Exception e){
				e.printStackTrace();
			}
		}
	}

}



 



[html] view plaincopy


  1. 网页错误详细信息  

    AI智研社
    AI智研社

    AI智研社是一个专注于人工智能领域的综合性平台

    下载
  2.   

  3. 消息: 'userid' 未定义  

  4. 行: 18  

  5. 字符: 3  

  6. 代码: 0  

  7. URI: http://localhost/demo/14_Ajax/regist.htm  

  8.   

  9.   

  10. function checkUserid(userid){      // 显示信息  

  11. 没有声明参数  


不能进入

if (xmlHttp.status == 200){                 // HTTP操作正常

alert("*****3");

说明HTTP操作不正常,那怎么返回HTTP状态码

调试过程:



[html] view plaincopy


  1. if (xmlHttp.readyState == 4){           // 数据返回完毕  

  2.             //alert("*****2");  

  3.             alert(xmlHttp);  

  4.             alert(xmlHttp.readyState);  

  5.             alert(xmlHttp.status);  

  6.             if (xmlHttp.status == 200){         // HTTP操作正常  

  7.                 alert("*****3");  


xmlHttp.readyState == 4           说明数据返回完毕

 

数据返回完毕,但服务器找不到指定的资源(),文档不存在!而且Servlet调试根本未进入,这是为什么???


MLDN论坛李祺老师解答:

说明你的AJAX提交路径对应的资源不存在。
你的Servlet必须将编译后的class文件放到项目的WEB-INF/classes目录下,并放到对应的包中,如果没有加入,则会找不到资源

我又出这样的问题:

Servlet.java文件不必放在WEB-INF/classes文件夹下

!!!!!!!但你的

                    zz.ajax.CheckServlet

             是放哪?

 

其它编译错误:

java.lang.ClassNotFoundException: DBDRIVER

Class.forName("DBDRIVER");   // 加载驱动 不要“”

显示效果:

 


/*  转载自http://blog.csdn.net/zhangze2/article/details/7959493  */


 



[html] view plaincopy


  1. 网页错误详细信息  

  2.   

  3. 消息: 'userid' 未定义  

  4. 行: 18  

  5. 字符: 3  

  6. 代码: 0  

  7. URI: http://localhost/demo/14_Ajax/regist.htm  

  8.   

  9.   

  10. function checkUserid(userid){      // 显示信息  

  11. 没有声明参数  


不能进入

if (xmlHttp.status == 200){                 // HTTP操作正常

alert("*****3");

说明HTTP操作不正常,那怎么返回HTTP状态码?

调试过程:



[html] view plaincopy


  1. if (xmlHttp.readyState == 4){           // 数据返回完毕  

  2.             //alert("*****2");  

  3.             alert(xmlHttp);  

  4.             alert(xmlHttp.readyState);  

  5.             alert(xmlHttp.status);  

  6.             if (xmlHttp.status == 200){         // HTTP操作正常  

  7.                 alert("*****3");  


xmlHttp.readyState == 4           说明数据返回完毕

 

数据返回完毕,但服务器找不到指定的资源(),文档不存在!而且Servlet调试根本未进入,这是为什么???


MLDN论坛李祺老师解答:

说明你的AJAX提交路径对应的资源不存在。
你的Servlet必须将编译后的class文件放到项目的WEB-INF/classes目录下,并放到对应的包中,如果没有加入,则会找不到资源

我又出这样的问题:

Servlet.java文件不必放在WEB-INF/classes文件夹下

!!!!!!!但你的

                    zz.ajax.CheckServlet

             是放哪?

 

其它编译错误:

java.lang.ClassNotFoundException: DBDRIVER

Class.forName("DBDRIVER");   // 加载驱动 不要“”

显示效果:

 

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

14

2026.01.30

c++ 字符串格式化
c++ 字符串格式化

本专题整合了c++字符串格式化用法、输出技巧、实践等等内容,阅读专题下面的文章了解更多详细内容。

9

2026.01.30

java 字符串格式化
java 字符串格式化

本专题整合了java如何进行字符串格式化相关教程、使用解析、方法详解等等内容。阅读专题下面的文章了解更多详细教程。

12

2026.01.30

python 字符串格式化
python 字符串格式化

本专题整合了python字符串格式化教程、实践、方法、进阶等等相关内容,阅读专题下面的文章了解更多详细操作。

4

2026.01.30

java入门学习合集
java入门学习合集

本专题整合了java入门学习指南、初学者项目实战、入门到精通等等内容,阅读专题下面的文章了解更多详细学习方法。

20

2026.01.29

java配置环境变量教程合集
java配置环境变量教程合集

本专题整合了java配置环境变量设置、步骤、安装jdk、避免冲突等等相关内容,阅读专题下面的文章了解更多详细操作。

18

2026.01.29

java成品学习网站推荐大全
java成品学习网站推荐大全

本专题整合了java成品网站、在线成品网站源码、源码入口等等相关内容,阅读专题下面的文章了解更多详细推荐内容。

19

2026.01.29

Java字符串处理使用教程合集
Java字符串处理使用教程合集

本专题整合了Java字符串截取、处理、使用、实战等等教程内容,阅读专题下面的文章了解详细操作教程。

3

2026.01.29

Java空对象相关教程合集
Java空对象相关教程合集

本专题整合了Java空对象相关教程,阅读专题下面的文章了解更多详细内容。

6

2026.01.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号