本文通过两个实战实例详细讲述 JSP+jQuery 使用 Ajax 方式调用 JSON 的实现方法,从基础的参数传递与简单 JSON 返回,到基于实体类 + Servlet的复杂对象 / 集合 JSON 数据封装与页面渲染,覆盖前后端核心代码实现与关键配置,代码可直接复用,适合 Java Web 入门开发者参考,具体的实现步骤以及完整代码如下所示:
该实例实现前端通过 jQuery-Ajax 传递参数到 JSP 后端,后端处理后返回 JSON 格式的结果,前端解析 JSON 并做业务逻辑处理,是最基础的 JSP+Ajax+JSON 交互实现,适合简单的前后端参数传递场景。
需先引入 jQuery 核心库,通过点击事件触发 Ajax 请求,传递参数并接收后端返回的 JSON 数据:
<script type="text/javascript" src="jquery-1.5.1.min.js"></script>
<script type="text/javascript">
//test
function test(uid)
{
if(confirm("确定该用户操作"+uid+"吗?"))
{
var date = new Date();
var param = {uid:uid};
jQuery.get("test.jsp?para=" + date, param,
function(data){
if(data != null)
{
var result = data.result;
//alert("data==="+data);
if(result == 1)
{
alert("操作失败");
}
if(result == 0)
{
alert("操作失败。");
//document.location.href = document.location;
//window.location.reload();
}
}
});
}
}
</script>
<a href="javascript:void(0);" onclick="test(111111111111111111);">submit</a>
后端 test.jsp 接收前端传递的参数,处理后手动拼接 JSON 格式字符串返回,需重点设置响应头指定返回数据类型为 JSON,确保前端正确解析:
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%><%
response.setContentType("application/x-json;charset=UTF-8");
String uid=request.getParameter("uid");
int ret=0;
String result = "{\"result\":" + ret + "}";
out.print(result);
%>
该实例的核心是前后端数据格式的统一,前端传递键值对参数,后端手动拼接 JSON 字符串返回,重点掌握响应头设置和JSON 语法规范,是 JSP+Ajax+JSON 交互的基础,适合简单的业务状态返回(如操作成功 / 失败、数量统计等)。
实际开发中,业务数据往往包含复杂对象、对象集合、嵌套对象(如个人信息包含地址信息),仅手动拼接 JSON 字符串效率低且易出错,该实例通过Person、Address 实体类描述数据,在 Servlet 中借助json-lib 工具包将实体类 / 集合自动转换为 JSON 格式,前端通过 jQuery 解析复杂 JSON 数据并渲染到页面,是 Java Web 开发中最常用的 JSON 交互方式。
使用 json-lib 工具包实现 Java 对象与 JSON 的相互转换(序列化 / 反序列化),需引入以下 5 个依赖 jar 包,缺一不可,需将 jar 包放入项目
WEB-INF/lib目录下:
同时前端需引入两个核心 JS 文件:
创建两个序列化实体类,Person 包含基础属性和嵌套的 Address 对象,描述业务数据结构,实现java.io.Serializable接口保证对象可序列化,符合 Java Web 开发规范:
Address 类(地址实体,嵌套在 Person 中)
public class Address implements java.io.Serializable{
private String province;
private String city;
private String country;
public Address() {
}
public Address(String province, String city, String country){
this.province =province;
this.city = city;
this.country = country;
}
public String getProvince() {
return province;
}
public void setProvince(String province) {
this.province =province;
}
public String getCity() {
return city;
}
public void setCity(String city) {
this.city = city;
}
public String getCountry() {
return country;
}
public void setCountry(String country) {
this.country = country;
}
}
Person 类(人员实体,包含 Address 嵌套对象)
public class Person implements java.io.Serializable{
private String name;
private String sex;
private Integer age;
private Address address;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getSex() {
return sex;
}
public void setSex(String sex) {
this.sex = sex;
}
public Integer getAge() {
return age;
}
public void setAge(Integer age) {
this.age = age;
}
public Address getAddress() {
return address;
}
public void setAddress(Address address) {
this.address = address;
}
}
创建 DemoServlet 作为后端接口,处理前端 Ajax 请求,组装 Person 对象集合,通过 json-lib 将集合对象和嵌套对象自动转换为 JSON 格式并返回,替代手动拼接 JSON 字符串,提升开发效率和代码可维护性:
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import net.sf.json.JSONArray;
import net.sf.json.JSONObject;
import org.wncnke.json.pojo.Address;
import org.wncnke.json.pojo.Person;
public class DemoServlet extends HttpServlet{
@Override
protected void doGet(HttpServletRequest request,HttpServletResponse response)
throwsServletException, IOException {
doPost(request, response);
}
@Override
protected void doPost(HttpServletRequest request,HttpServletResponse response)
throwsServletException, IOException {
response.setContentType("text/xml;charset=utf-8");
response.setHeader("Cache-Control","no-cache");
try{
Personperson1 = new Person();
person1.setName("小王");
person1.setSex("女");
person1.setAge(23);
person1.setAddress(newAddress("辽宁省","大连市","高新园区"));
List<Person> list = new ArrayList<Person>();
list.add(person1);
try{
//取集合
JSONArray jsonArray = JSONArray.fromObject(list);
JSONObject jsonObject = new JSONObject();
jsonObject.put("person", jsonArray);
response.getWriter().write(jsonObject.toString());
} catch(IOException e) {
e.printStackTrace();
}
}catch(Exception e){
e.printStackTrace();
}
}
}
Servlet 需在 web.xml 中进行注册和 URL 映射,才能被前端访问,这是 Java Web 中 Servlet 的核心配置,指定 Servlet 的访问路径:
<?xml version="1.0"encoding="UTF-8"?>
<web-app xmlns="http://caucho.com/ns/resin" xmlns:resin="http://caucho.com/ns/resin/core">
<display-name>json</display-name>
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
<servlet>
<servlet-name>DemoServlet</servlet-name>
<servlet-class>org.wncnke.json.servlet.DemoServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>DemoServlet</servlet-name>
<url-pattern>/demoServlet</url-pattern>
</servlet-mapping>
</web-app>
前端通过 jQuery 的$.getJSON发起 Ajax 请求,接收 Servlet 返回的复杂 JSON 数据(包含集合和嵌套对象),解析后通过 jQuery 动态渲染到表格中,实现数据的页面展示:
view plaincopy to clipboardprint?
<%@ page language="java" 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%>">
<mce:script language="javascript" src="script/jquery.js"mce_src="script/jquery.js"></mce:script>
<mce:script language="javascript" src="script/json.js"mce_src="script/json.js"></mce:script>
<mce:script language="javascript"><!--
function addPerson(){
$.getJSON("demoServlet",null,function call(data){
var list = data.person;
$.each(list, function(i, p){
var row =$("#tr").clone();
row.find("#name").text(p.name);
row.find("#age").text(p.age);
row.find("#sex").text(p.sex);
row.find("#address").text(p.address.province + p.address.city +p.address.country);
row.appendTo("#tbody");
});
});
}
// --></mce:script>
</head>
<body>
<input type="button" value="JsonView"onClick="addPerson();">
<div id="dateMessage">
<table id="planTable"border="1">
<tr>
<td>Name</td>
<td>Sex</td>
<td>Age</td>
<td>Address</td>
</tr>
<tbody id="tbody">
<trid="tr">
<td id="name"></td>
<td id="sex"></td>
<td id="age"></td>
<td id="address"></td>
</tr>
</tbody>
</table>
</div>
</body>
</html>
正在加载... ...