首页 > 其他分享 >【Ajax技术】JQuery处理XML数据

【Ajax技术】JQuery处理XML数据

时间:2023-03-19 10:31:58浏览次数:44  
标签:JQuery XML name builder jquery Ajax var import append


我们将之前写的应用使用jquery返回xml数据
程序清单
服务端Servelt:AjaxXMLServer.java
静态页面:ajaxJqueryXml.html
javascript脚本文件:verifyjqueryxml.js

AjaxXMLServer.java:

import java.io.IOException;
import java.io.PrintWriter;
import java.net.URLDecoder;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

//这个servlet返回的是XML的数据
public class AjaxXMLServer extends HttpServlet {


protected void doPost(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse) throws ServletException, IOException {
doGet(httpServletRequest, httpServletResponse);
}


protected void doGet(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse) throws ServletException, IOException {
try{


//修改点1------相应的ContentType必须为text/xml
httpServletResponse.setContentType("text/xml;charset=utf-8");
PrintWriter out = httpServletResponse.getWriter();


//inte用来记录验证次数
Integer inte = (Integer) httpServletRequest.getSession().getAttribute("total");
int temp = 0;
if (inte == null) {
temp = 1;
} else {
temp = inte.intValue() + 1;
}
httpServletRequest.getSession().setAttribute("total",temp);


//1.取参数
String old = httpServletRequest.getParameter("name");
//String name = new String(old.getBytes("iso8859-1"),"UTF-8");
String name = URLDecoder.decode(old,"UTF-8");

//修改点2-----返回的数据需要拼装成xml格式
StringBuilder builder=new StringBuilder();
builder.append("<message>");

//2.检查参数是否有问题
if(old == null || old.length() == 0){
builder.append("用户名不能为空").append("</message>");
} else{

if(name.equals("hpu")){
//4。和传统应用不同之处。这一步需要将用户感兴趣的数据返回给页面段,而不是将一个新的页面发送给用户
//写法没有变化,本质发生了改变
builder.append("用户名[" + name + "]已经存在,请使用其他用户名, " + temp).append("</message>");
} else{
builder.append("用户名[" + name + "]尚未存在,可以使用该用户名注册, " + temp).append("</message>");
}
out.println(builder.toString());
System.out.println(builder.toString());
}
} catch(Exception e){
e.printStackTrace();
}
}
}


ajaxJqueryXml.html:


<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>用户校验ajax实例</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<script type="text/javascript" src="js/jquery-1.8.0.js"></script>
<script type="text/javascript" src="js/verifyjqueryxml.js"></script>
</head>

<body>
<h1> 用户校验ajax实例</h1><br>
请输入用户名:<br/>
<!-- ajax不需要使用表单进行数据提交,因此不用写表单标签 -->

<!-- ajax不需要name属性,只需要一个id的属性 -->
<input type="text" id="username"/>
<input type="button" value="校验" οnclick="verify()"/>
<!-- 这个div用于存放服务器返回的信息,开始为空 -->
<!-- id属性定义是为了利用dom的方式找到某一个节点,进行操作 -->
<div id="result">

</div>
<!-- div和span的值的差异,div的内容独占行,span的内容和其他内容相处良好 -->

</body>
</html>


verifyjqueryxml.js:


//定义用户名校验的方法
function verify(){
//1.获取文本框当中的内容
//document.getElementById("username"); dom的方式
//jquery的查找节点的方式,参数中#加上id属性值可以找到一个节点
//jquery的方法返回的都是jquery的对象,可以继续在上面执行其他的jquery方法
var jqueryObj=$("#username");
var userName=jqueryObj.val();
//alert("文本框的值是:"+userName);

//2.将文本中的数据发送给服务器的servlet
//javascript当中,一个简单的对象定义方法
//var obj={name:"123".age:20};

//使用JQuery的XMLHttpRequest对象请求的封装
$.ajax({
type:"POST",//Http请求方式
url:"AjaxXMLServer", //服务器端url地址
data:"name="+username, //发送给服务器端的数据
dataType:"xml",//告诉JQuery返回的数据方式
success:callback //定义交互完成,并且服务器正确返回数据时调用的回调函数
});


}


//回调函数
function callback(data){

//3.接受服务器端返回的数据
//需要将data这个dom对象中的数据解析出来
//首先需要将dom的对象转换成jquery的对象
var jqueryObj=$(data);
//获取message节点
var message=jqueryObj.children();
//获取节点中的内容
//如果节点中有多条信息,执行text方法会把所有信息拼接在一块
var text=message.text();
//4.将服务器返回的数据动态的显示在页面上
//找到保存信息的节点
var resultObj=$("#result");
//往这个节点填充服务器返回的值
//div节点中的内容就会被改变
resultObj.html(text);
}


测试:输入123点击校验,服务器端返回的信息在界面上显示,试验成功!


可以看到,使用jquery所封装的方法写的js文件,比传统的调用XMLHttpRequest对象去操作要


简洁了许多,这就是站在巨人肩膀上看得更远。

标签:JQuery,XML,name,builder,jquery,Ajax,var,import,append
From: https://blog.51cto.com/u_16012040/6130932

相关文章

  • 在IDEA中使用JRebel插件实现热部署(包括mybatis的xml文件)
    省流版下载插件JRebelandXRebel和JRebelmybatisPlusextension详细版首先,我的IDEA下载了官方中文插件(Chinese​(Simplified)​LanguagePack/中文语言包),所以在......
  • Vue3跨域问题Access to XMLHttpRequest at ‘http://127.0.0.1:8000/login‘ from ori
    这一个bug折磨了我一下午,终于解决了首先解决跨域问题需要修改vue.config.js文件在vue.config.js中添加devServer:{proxy:{'/api':{target:......
  • XML&XXE利用检测绕过
    概念:XML被设计为传输和存储数据,XML文档结构包括XML声明、DTD文档类型定义(可选)、文档元素,其焦点是数据的内容,其把数据从HTML分离,是独立于软件和硬件的信息传输工具。XXE漏......
  • 【 Python 】补全fibersim 导出的xml语法
    fibersim导出的xml文件中,node和mesh部分的标签会缺失。即<R></R>变成了<R/>.以下python脚本可以自动修正importref2=open('x13.xml','w')withopen('E:\\20230314......
  • Ajax提交后Moedl And View不进行页面跳转的解决方案
    场景前端使用ajax请求后台,返回ModelAndView后不进行页面跳转。用ajax提交是没有页面跳转的。实现如果只是简单的页面跳转和传递单个简单参数可以使用:window.location.hre......
  • xml中引入schema
      person.xml引入person.xsd示例:<?xmlversion="1.0"encoding="UTF-8"?><!--xmlns:xsl末尾的-instance表示是被别的文件约束的--><!--:xsl是为了区分本文件......
  • Dcat-Admin改写ajax实现请求过滤同名参数
    //方案一Admin::script( <<<JS(function($){//备份jquery的ajax方法var_ajax=$.ajax;//重写jquery的ajax方法......
  • DOM4J解析xml代码实现
    1、DOM4J是第三方提供的工具类,使用前需要导入DOM4J的jar包下载地址:https://dom4j.github.iopublicclassDom4jDemo{publicstaticvoidmain(String[]args)th......
  • ajax
    JSON1、初识JSONJSON是什么JSON是Ajax发送和接收数据的一种格式JSON全称是JavascriptObjectNotationJSON数据一般放在一个.json的文件中,这个文件数据格式要遵......
  • 【jQuery】实现菜单切换
    <!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"/><metahttp-equiv="X-UA-Compatible"content="IE=edge"/><metaname="viewport"co......