Ajax原生和Jquery例题

创建一个工程TestAJAX
(1)请写出一个原生ajax的示例,发送post请求,在后台输出接收到的请求参数,以key:value的格式输出
(2)将上述需求改为jquery ajax的形式发送
在这里插入图片描述

pom.xml

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  <modelVersion>4.0.0</modelVersion>
  <groupId>com.epoint</groupId>
  <artifactId>TestAJAX</artifactId>
  <version>0.0.1-SNAPSHOT</version>
  <packaging>war</packaging>
  
    <build>
	  	<plugins>
	  		<plugin>
				<groupId>org.apache.maven.plugins</groupId>
				<artifactId>maven-compiler-plugin</artifactId>
				<version>3.7.0</version>
				<configuration>
				<source>1.8</source>
				<target>1.8</target>
				</configuration>
			</plugin>	
	  	</plugins>
  </build>
</project>

ajaxTest.html

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Ajax测试</title>
<script src="js/jquery-3.4.1.min.js"></script>
</head>
<body>
	<button onClick="btnFun1()"> 原生AJAX发送请求</button>&nbsp;&nbsp;
	<span id="info1"></span>
	<br/>
	<br/>
	<button onClick="btnFun2()"> jQuery AJAX发送请求</button>&nbsp;&nbsp;
	<span id="info2"></span>
	
	<script type="text/javascript">
		
	//获取xhr对象
	function getXHR(){
		var xhr;
		
		if(window.XMLHttpRequest){
			//IE7+.Chrome,Firefox,Opera,Safari浏览器都支持xhr对象
			xhr = new XMLHttpRequest();
		}else{
			//IE5,IE6等比较旧的浏览器
			xhr = new ActiveXObject("Microsoft.XMLHTTP");
		}
		
		return xhr;
	}
	
	//原生Ajax
	function btnFun1(){
		// 1、我们首先要创建XMLHttpRequest
		var xhr = getXHR();
		
		// 2、调用open方法设置请求参数
		xhr.open("POST","/TestAJAX/AjaxServlet",true);
		
		 // 3、调用send方法发送请求
		xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
		xhr.send("username=zhangsan&passowrd=1111");
		
		// 4、接收到响应信息之后的信息
		//每当 readyState 改变时,就会触发 onreadystatechange 事件。
		xhr.onreadystatechange = function(){
			if(this.status == 200 && this.readyState == 4){
				document.getElementById("info1").innerHTML = this.responseText;
			}
		}
		
	}
	
	//jQuery AJAX
	function btnFun2(){
		
		var info = {"username":"lisi","password":"111"}
		$.ajax({
			type: "POST",
			url: "/TestAJAX/AjaxServlet",
			data: info,
			success: function (result) {
				document.getElementById("info2").innerHTML = result;
			},
			error: function (e) {//请求失败
				document.getElementById("info2").innerHTML = e.status;
			}
		});
		
	}
	</script>
</body>
</html>

AjaxServlet.java

package com.epoint.servlet;

import java.io.IOException;
import java.util.Enumeration;

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

/**
 * Servlet implementation class AjaxServlet
 */
@WebServlet("/AjaxServlet")
public class AjaxServlet extends HttpServlet {
	private static final long serialVersionUID = 1L;
       
    /**
     * @see HttpServlet#HttpServlet()
     */
    public AjaxServlet() {
        super();
    }

	/**
	 * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
	 */
	protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		
		request.setCharacterEncoding("UTF-8");
		
		//获取所有请求参数的名称和值
		Enumeration<String> parameterNames = request.getParameterNames();
		
		while (parameterNames.hasMoreElements()) {
			String parameterName = (String) parameterNames.nextElement();
			
			String[] parameterValues = request.getParameterValues(parameterName);
			
			for (String value : parameterValues) {
				System.out.println(parameterName + ":" + value);
				//返回响应
				response.getWriter().append(parameterName + ":" + value + "&nbsp;&nbsp;");
			}
			
		}
		
		
	}

	/**
	 * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
	 */
	protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		doGet(request, response);
	}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值