日期:2014-05-16  浏览次数:20330 次

Jquery+ajax+json+servlet原理和Demo
Jquery+ajax+json+servlet原理和Demo

大致过程:
用户时间点击,触发js,设置$.ajax,开始请求。服务器响应,获取ajax传递的值,然后处理。以JSON格式返回给ajax。ajax在sucess对应的函数中将返回的json数据进行解析,然后输出到jsp页面。


1.前台index.jsp

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%
	String path = request.getContextPath();
	String basePath = request.getScheme() + "://"
			+ request.getServerName() + ":" + request.getServerPort()
			+ path + "/";
%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
	<head>
		<base href="<%=basePath%>">

		<title>Jquery Ajax Json Servlet Demo</title>
		<meta http-equiv="pragma" content="no-cache">
		<meta http-equiv="cache-control" content="no-cache">
		<meta http-equiv="expires" content="0">
		<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
		<meta http-equiv="description" content="This is my page">
		<!--
	<link rel="stylesheet" type="text/css" href="styles.css">
	-->
		<script type="text/javascript" src="js/jquery.min.js"></script>
		<script type="text/javascript">
	       function jsonAjaxPost(){
	         var userNameObj=$("#username").val();
	         var contentObj=$("#content").val();
             $.ajax({
               type:"post",//请求方式
               url:"jsonAjaxAction?userName="+encodeURI(encodeURI(userNameObj))
                   +"&content="+encodeURI(encodeURI(contentObj)),//发送请求地址
               timeout:30000,//超时时间:30秒
               dataType:"json",//设置返回数据的格式
               //请求成功后的回调函数 data为json格式
               success:function(data){
                  $("#resultJsonText").text("你的名字:"+data.yourName+"  你输入的内容:"+data.yourContent);
              },
              //请求出错的处理
              error:function(){
                        alert("请求出错");
              }
           });
          }
	</script>
	</head>
	<body>
	<form id="form1" method="post">
		<p>
			评论:
		</p>
		<p>
			姓名:
			<input type="text" name="username" id="username" />
		</p>
		<p>
			内容:
			<textarea name="content" id="content" rows="2" cols="20"></textarea>
		</p>
		<p>
			<input type="button" id="send" value="提交" onclick="jsonAjaxPost()" />
		</p>
	</form>
	<div class="comment">
		返回数据:
		<p id="resultJsonText"></p>
	</div>
	<div id="resText">
	</div>
	</body>
</html>


2.后台Servlet

/*
 * $filename: JsonAjaxServlet.java,v $
 * $Date: Sep 1, 2013  $
 * Copyright (C) ZhengHaibo, Inc. Al