ajax与servlet--验证用户名是否存在

本文介绍了一个使用jQuery实现的用户名验证功能。通过AJAX与后端交互检查用户名是否已被注册,适用于用户登录或注册场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


            验证用户名是否存在--使用jQuery

一、数据库mysql

              数据库中已经存在用户名。


二、html页面     

<body>
    <h1>用户登录</h1>
    <hr>
    <form name="regForm" action="dologin.jsp" method="post">
        <table>
            <tr>
                <td>username</td>
                <td><input id="Name"  type="text" name="username"/><span id="msg">请输入昵称</span></td>
            </tr>
            <tr>
                <td>password</td>
                <td><input type="password" name="password"/></td>
            </tr>
            <tr>
                <td colspan="2"><input type="submit" value="submit"/></td>
            </tr>
        </table>
        <a href="/myblog/register.jsp">没有账号?立即注册。</a>  
    </form>
</body>


三、jQuery代码--ajax

当表单里的用户名失去焦点时,就会触发该ajax,与后端Ajax类交互。

  <script type="text/javascript" src="${path}js/jquery-3.1.1.js"></script>
  <script type="text/javascript"> 
  $(document).ready(function(){
	  
		 $("#Name").blur(function(){
			 var user = {username:$("#Name").val()};
			  $.ajax(
			   {url:"http://localhost:8080/myblog/ajax",
			   data:user,
			   async:true,
			   type:"POST",
			   dataType:"html",
			   success:function(result){
				  
			 $("#msg").html(result); }
				   
		        });  
              }); 
  })  
  </script>


四、后台类Ajax.java

该类中引用了DB类,方便创造数据库实例。该类与数据库交互,并返回数据到前端。

public class Ajax extends HttpServlet {

	@Override
	protected void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
	     
        response.setContentType("text/html");
        response.setCharacterEncoding("utf-8");
		
		String name = request.getParameter("username");
		
		//连接数据库
		
		try{	//创建数据库的连接
		Connection conn = DB.getConn();
		//sql语句
		String sql ="SELECT * FROM admin where username= ? ";
		PreparedStatement pstm = conn.prepareStatement(sql);
		pstm.setString(1, name);
		 ResultSet rs = pstm.executeQuery();
		 
			if(rs.next()){
				 response.getWriter().print("您的用户名已经注册");
			}
			else{
				response.getWriter().print("验证成功");
			}
	 
		 }catch(Exception e){
				e.printStackTrace();
		}	

	}
}

五、在Ajax.java中使用了DB类

创建数据库实例。


public class DB {
	
	private static Connection conn =null;

	private DB(){
		
	}
	
	public static Connection getConn(){
		if (conn != null) {
			return conn;
		}
		try{
			 Class.forName("com.mysql.jdbc.Driver");    
		String url = "jdbc:mysql://localhost/webuser?useUnicode=true&characterEncoding=utf-8&useSSL=false";

		conn= DriverManager.getConnection(url,"root", "17911");
		return conn;
		}catch(Exception e){
			e.printStackTrace();
			return null;
		}
		
	}
}


六、运行效果


未输入时:

jsh为已注册用户:


新用户:



七、展望

     
上面废话不多,直接写了html、js、servlet的代码,写javaweb学生信息管理系统应该会用到。

下次应该就是学生信息管理系统的源代码了。


评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值