一、实验简介

目的:检验输入登录名在数据库中是否存在,如果存在,当鼠标移出登录名框后,会提示用户名已存在,并且鼠标指针自动回到登录名框内。

操作步骤:

  1、获取登录名的值

  2、根据获取的登录名,组织查询条件,查询用户信息。

      *如果值存在,不能保存

      *如果值不存在,可以保存

二、实验操作

jsp部分:

<s:textfield name="logonName" id="logonName" size="20" maxlength="25" onblur="checkLogonName()" />

ajax部分:

 //创建Ajax引擎
function createXmlHttpRequest(){
var xmlHttp;
try{
//Firefox,Opera,safari
xmlHttp=new XMLHttpRequest();
}catch(e){
try{
//internet Explorer
xmlHttp=new ActiveXObject("Mxxml2.XMLHTTP");
}catch(e){
try{
xmlHttp=new ActiveXObject("Microsoft.XMLHTTP");
}catch(e){}
}
}
return xmlHttp;
}
 function checkLogonName(){
var logonName=document.getElementById("logonName").value;
//第一步:创建一个ajax引擎
xmlHttp=createXmlHttpRequest(); //第二步:事件处理函数,实质上相当于一个监听,监听服务器与客户端的连接状态
xmlHttp.onreadystatechange=function(){
//存储函数(或函数名),每当 readyState 属性改变时,就会调用该函数。
if(xmlHttp.readyState==4){
/**
readyState:存有 XMLHttpRequest 的状态。从0到4发生变化。
0: 请求未初始化
1: 服务器连接已建立
2: 请求已接收
3: 请求处理中
4: 请求已完成,且响应已就绪
**/
if(xmlHttp.status==200){
/**
status:
400: 未找到页面
200:"OK"
**/
var data=xmlHttp.responseText;
/**
responseText 获得字符串形式的响应数据。
responseXML 获得 XML 形式的响应数据。
**/
if(data==1){
//说明已经存在
alert("当前输入的登录名["+logonName+"]已经存在");
document.getElementById("logonName").value="";
document.getElementById("logonName").focus();
}
}
}
} //第三步:与后台服务器创建一个连接
xmlHttp.open("POST","../../CheckLogonName",true);
/**
open(method,url,async)
规定请求的类型、URL 以及是否异步处理请求。
method:请求的类型;GET 或 POST
url:文件在服务器上的位置
async:true(异步)或 false(同步)
**/
xmlHttp.setRequestHeader("Content-Type","application/x-www-form-urlencoded");//设置请求头
//第四步:发送请求的参数
xmlHttp.send("logonName="+logonName);
/**
send(string)
将请求发送到服务器。
string:仅用于 POST 请求
**/
/**
GET 还是 POST?
与 POST 相比,GET 更简单也更快,并且在大部分情况下都能用。
然而,在以下情况中,请使用 POST 请求:
1: 无法使用缓存文件(更新服务器上的文件或数据库)
2: 向服务器发送大量数据(POST 没有数据量限制)
3: 发送包含未知字符的用户输入时,POST 比 GET 更稳定也更可靠
**/
}

路径设置:
  在web.xml配置文件中,新建一个Servlet-mapping和Servlet

<servlet>
<servlet-name>CheckLogonName</servlet-name>
<servlet-class>cn.itcast.elec.servlet.CheckLogonName</servlet-class>
</servlet> <servlet-mapping>
<servlet-name>CheckLogonName</servlet-name>
<url-pattern>/checkLogonName</url-pattern>
</servlet-mapping>

新建一个Servlet文件

 IElecUserService elecUserService=(IElecUserService)ServiceProvider.getService(IElecUserService.SERVICE_NAME);
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException { response.setCharacterEncoding("UTF-8");
response.setContentType("text/html;charset=utf-8");
PrintWriter out = response.getWriter();
String logonName=request.getParameter("logonName");
/**
* checkflag:判断当前登录名是否在数据库中存在
* 如果查询结果有值,checkflag=1;则,数据库中有重复值
* checkflag=2,数据库中没有重复值
*/
String checkflag=elecUserService.checkLogonName(logonName);
out.print(checkflag);
out.flush();
out.close();
}
 public String checkLogonName(String logonName) {
// TODO Auto-generated method stub
String hqlWhere=" and o.logonName = ? ";
Object [] params={logonName};
List<ElecUser> list=elecUserDao.findCollectionByConditionNoPage(hqlWhere, params, null);
String checkflag="";
if(list!=null&&list.size()>0){
checkflag="1";
}else{
checkflag="2";
}
return checkflag;
}

ajax总结及案例的更多相关文章

  1. AJAX应用小案例

    此案例在XAMPP本地服务器上运行,需要应用jquery3.1.1的版本,应用JSON传递数据 代码如下: html代码: <!DOCTYPE html><html lang=&qu ...

  2. ajax调用数据案例,二级联动

    题目:请针对移动端web浏览器制作一个结账数据信息展示页面 要求: 1. 页面样式除不使用表格呈现外,可自由选择其他呈现方式 2. 需符合移动端操作习惯 3. 可根据服务区.门店查询结账信息 4. 可 ...

  3. ajax基本原理与案例

    一.什么是Ajax AJAX即“Asynchronous Javascript And XML”( 异步 JavaScript和XML),AJAX不是一种新的编程语言,而是一种用于创建更好更快以及交互 ...

  4. jquery ajax/post 请求 案例

    @RequestMapping("/hello")    @ResponseBody    public Hello getJson(HttpServletRequest requ ...

  5. jSon和Ajax登录功能,ajax数据交互案例

    ajax实例,检测用户与注册 检测用户名是否被占用: 在用户填写完用户名之后,ajax会异步向服务器发送请求,判断用户名是否存在 首先写好静态页面: index.html <!DOCTYPE h ...

  6. ajax+php处理案例

    <div> <table> <tr> <th>状态</th> <th>信息</th> </tr> < ...

  7. 使用struts dojo ajax源码案例

    我这里使用的jar 包struts2-dojo-plugin-2.2.1.1.jar ===========jsp======================= <%@ taglib prefi ...

  8. 【前端学习笔记】2015-09-11~~~~ js中ajax请求返回案例

    <body><textarea id='a' rows=100 cols=300>result:</textarea>><script>var a ...

  9. 第六章 jQuery和ajax应用

    ajax是异步JavaScript和xml的简称. 一. ajax补白 优势 不足(不一定是不足) 不需要任何插件(但需要浏览器支持js) XMLHttpRequest对象在不同浏览器下有差异 优秀的 ...

随机推荐

  1. 自己挖的坑自己填--docker创建实例出现Waiting for SSH to be available…

    在之前使用Docker for Windows Installer.exe直接安装,通过docker-machine-driver-vmwareworkstation.exe实现docker和VM的共 ...

  2. Java枚举enum关键字

    枚举的理解 枚举其实就是一个类,枚举类的实例是一组限定的对象 传统的方式创建枚举 [了解] 对比:单例类 1.构造器私有化 2.本类内部创建对象 3.通过public static方法,对外暴露该对象 ...

  3. adb logcat查看手机端日志

    前言 做app测试,遇到异常情况,查看日志是必不可少的,日志如何输出到手机sdcard和电脑的目录呢?这就需要用logcat输出日志了以下操作是基于windows平台的操作:adb logcat | ...

  4. 【译】Redux 还是 Mobx,让我来解决你的困惑!

    原文地址:Redux or MobX: An attempt to dissolve the Confusion 原文作者:rwieruch 我在去年大量的使用了 Redux,但我最近都在使用 Mob ...

  5. Python的魔法方法??

    就是可以给你的类增加魔力的特殊方法,如果你的对象实现 (重载)了这些方法中的某一个,那么这个方法就会在特殊的情况下被 Python 所调用,你可以定义自己想要的行为,而这一切都是自动发生的. __in ...

  6. 使用Kafka的一些简单介绍: 1集群 2原理 3 术语

    目录 第一节 Kafka 集群 Kafka 集群搭建 Kafka 集群快速搭建 第二节 集群管理工具 集群管理工具 集群 Issues 第三节 使用命令操纵集群 第四节 Kafka 术语说明 第五节 ...

  7. 什么是dockerfile?

    什么是dockerfile? Dockerfile是一个包含用于组合映像的命令的文本文档.可以使用在命令行中调用任何命令. Docker通过读取Dockerfile中的指令自动生成映像. docker ...

  8. mongoDB学习笔记(2)

    一.删数据库 1.语法 MongoDB 删除数据库的语法格式如下: db.dropDatabase() 删除当前数据库,默认为 test,你可以使用 db 命令查看当前数据库名. 2.实例 以下实例我 ...

  9. vue.js(11)--案例--关键字搜索列表

    关键字搜索品牌案例 (1)页面布局 <div class="app"> <div class="panel panel-primary"> ...

  10. STS插件创建springboot项目,pom第一行报unkown错误

    Description    Resource    Path    Location    TypeUnknown    pom.xml    /amq-provider    line 1     ...