使用XML传递数据

Servlet

package org.zln.ajax.servlet;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;

/**
 * Created by coolkid on 2015/6/7 0007.
 */
public class AjaxServer extends HttpServlet {
    @Override
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        doGet(request,response);
    }

    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        try{
            /*使用xml处理*/
            response.setContentType("text/xml;charset=UTF-8");
            request.setCharacterEncoding("UTF-8");
            PrintWriter out = response.getWriter();
            //取参数信息
            String name = request.getParameter("name");
            //输入校验
            StringBuilder stringBuilder = new StringBuilder();
            stringBuilder.append("<message>");
            if(name == null || name.length() == 0){
                stringBuilder.append("用户名不能为空").append("</message>");
            } else{
                //逻辑校验与业务处理
                if(name.equals("wangxingkui")){
                    stringBuilder.append("用户名[" + name + "]已经存在,请使用其他用户名").append("</message>");
                } else{
                    stringBuilder.append("用户名[" + name + "]尚未存在,可以使用该用户名注册").append("</message>");
                }
                out.println(stringBuilder.toString());
            }
            /*这些发往HTML的数据会被ajax的回调函数处理*/
            out.println("<br/><a href=\"ajax.html\">返回校验页面</a>");
        } catch(Exception e){
            e.printStackTrace();
        }
        //返回更新数据(而不是跳转到新的视图)
    }
}

js

/**
 * Created by coolkid on 2015/6/7 0007.
 */
var xmlHttp = null;

function verifyNew(id) {
    /*获取待打算数据*/
    var username = document.getElementById(id).value;
    /*创建XMLHttpRequest对象*/
    if (window.XMLHttpRequest) {
        /*针对FireFox Mozillar Opera Safair IE7+*/
        xmlHttp = new XMLHttpRequest();
        /*针对某些版本的Mozillar浏览器的bug修正*/
        if (xmlHttp.overrideMimeType) {
            xmlHttp.overrideMimeType(‘text/xml‘);
        }
    } else if (window.ActiveXObject) {
        /*针对IE6 IE5.5 IE5*/
        var activexName = [
            ‘MSXML2.XMLHTTP‘,
            ‘Microsoft.XMLHTTP‘
        ];
        for (var i = 0; i < activexName.length; i++) {
            try {
                /*取出一个空间名进行创建,如果创建成功,就终止循环*/
                xmlHttp = new ActiveXObject(activexName[i]);
                break;
            } catch (e) {
            }
        }
    }
    if (!xmlHttp) {
        alert(‘XMLHttpRequest对象创建失败‘);
    } else {
        /*注册回调函数*/
        xmlHttp.onreadystatechange = callback;
        /*设置连接 true表示异步交互 */
        xmlHttp.open(‘GET‘, ‘/Lesson5_AJAX_Demo1/AjaxServletDo.do?name=‘ + username, true);
        /*如果采用POST的方式,需要自己设置请求头*/
        /*
        xmlHttp.open("POST","/Lesson5_AJAX_Demo1/AjaxServletDo.do"+username,true);
        xmlHttp.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
        xmlHttp.send("name="+username);
        */
        /*发送数据*/
        xmlHttp.send(null); /*因为发送的数据已经在url中,所以这里的发送数据参数设置为null*/
    }
}
function callback() {
    if (xmlHttp.readyState == 4) { /*交互完成*/
        //判断http的交互是否成功
        if (xmlHttp.status == 200) {
            //使用responseXML的方式来接收XML数据对象的DOM对象
            var domObj = xmlHttp.responseXML;
            if (domObj) {
                //<message>123123123</message>
                //dom中利用getElementsByTagName可以根据标签名来获取元素节点,返回的是一个数组
                var messageNodes = domObj.getElementsByTagName(‘message‘);
                if (messageNodes.length > 0) {
                    //获取message节点中的文本内容
                    //message标签中的文本在dom中是message标签所对应的元素节点的字节点,firstChild可以获取到当前节点的第一个子节点
                    //通过以下方式就可以获取到文本内容所对应的节点
                    var textNode = messageNodes[0].firstChild;
                    //对于文本节点来说,可以通过nodeValue的方式返回文本节点的文本内容
                    var responseMessage = textNode.nodeValue;
                    //将数据显示在页面上
                    //通过dom的方式找到div标签所对应的元素节点
                    var divNode = document.getElementById(‘result‘);
                    //设置元素节点中的html内容
                    divNode.innerHTML = responseMessage;
                } else {
                    alert(‘XML数据格式错误,原始文本内容为:‘ + xmlHttp.responseText);
                }
            } else {
                alert(‘XML数据格式错误,原始文本内容为:‘ + xmlHttp.responseText);
            }
        } else {
            alert(‘出错了!!!‘);
        }
    }
}
时间: 2024-12-18 21:04:26

使用XML传递数据的相关文章

OpenCV和Matlab 通过XML传递数据

因为现在下到的数据集大部分都使用了Matlab的Calibration toolbox 进行标定,其结构大部分是.mat结构的,所以它和opencv中数据传递需要一个中间过程,网上也有直接调用matlab的dll的方法,但是中间件方法必然会受到版本限制,所以我最后还是选择了使用xml来作为中间文件传递数据. --------------1.calibration toolbox原始标定的.m数据--------------   http://ishare.iask.sina.com.cn/f/6

MyEclipse 2013 Web Service 实现以xml格式数据传递

提示:由于版本问题,使用MyEclipse 2013web Service的框架只有JAX-WS和JAX-RS,就没有XFire这个框架了....个人觉得XFire不怎么好用 一,新建一个服务器端的Web Service Project项目 2,我的xml数据是从数据库中来的,所有在生成xml之前,要连接数据库查询出来放在集合里...这些过程码农们自己写咯.... 这个是查询出,生成xml格式数据的.... 3,最重要的发布service 4,现在就把你的项目发布到tomcat中,不过咧...肯

使用全局变量在Activity之间传递数据

在Activity之间数据传递中还有一种比较实用的方式,就是全局对象,使用J2EE的读者来说都知道Java Web的四个作用域,这四个作用域从小到大分别是:Page.Request.Session和Application,其中Application域在应用程序的任何地方都可以使用和访问,除非是Web服务器停止,Android中的全局对象非常类似于Java Web中的Application域,除非是Android应用程序清除内存,否则全局对象将一直可以访问. 下面通过例子来分享一下它的实现: 建立

activity与fragment之间传递数据

总结:无论是activity给fragment传递数据,还是fragment给activity传递数据,都把activity和fragment都当做一个普通的对象,调用它的方法,传递参数. 1.Fragment中通过getActivity()然后进行强制转化,调用Activity中的公有方法 ((XXXXActivity)getActivity()).fun(); 2.Activity在切换Fragment的时候,通过setArguments向Fragment传递参数,Fragment通过get

MVC中前台如何向后台传递数据------$.get(),$post(),$ajax(),$.getJSON()总结

一.引言 MVC中view向controller传递数据的时候真心是一个挺让人头疼的一件事情.因为原理不是很懂只看一写Dome,按葫芦画瓢只能理解三分吧. 二.解读Jquery个Ajax函数 $.get(),$.post(),$.ajax(),$.getJSON() 1.$.get(url,[data],[callback]) 参数说明 url:请求地址,MVC中一般为:“/QueryScores/Search/” (/controller/action/) data:请求数据列表,MVC中ac

Android -- 启动Service并传递数据

本文主要记录Activity传递数据到Service. 1.效果图2.通过以上效果图,可以看出activity页面的数值改变,相应后台service输出的数值也跟着改变.3.核心代码如下,看代码中的38行,使用Intent作为载体,装载activity页面上的数据. ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41

struts2在action中获取request、session、application,并传递数据

如果只是通过request.session.application传递数据,则不需要获取相应的对象也可以传递数据,代码如下: ScopeAction.java: package com.itheima.action; import com.opensymphony.xwork2.ActionContext; public class ScopeAction { public String execute() { /* * 我们这里不通过字段(添加setXXX.getXXX方法)传递数据,我们想着

json如何传递数据配置方式

方案一: 不使用struts2的json, 1:导入json需要的jar包:(5个) 2:在Action中写: ServletActionContext.getRequest().setCharacterEncoding("UTF-8"); ServletActionContext.getResponse().setContentType("text/html;charset=utf-8"); //查询是否是通过简记码和仓库ID进行查询,获取的唯一货物 Goods

SpringMVC-前段后台传递数据

Controller.java代码: @Controller public class DataController { //一.接收和通过ModelMap传出参数,不需要视图解析器,测试时加了解析器,顾返回值不需后缀 //普通参数 @RequestMapping("/data1") public String data1(@RequestParam("uname")String name,ModelMap mm){ //接收数据 //1.页面提交的表单域名和参数名