上一篇
使用JavaScript的XMLHttpRequest对象或jQuery的$.ajax()方法发起异步请求,Java后端通过Servlet或Spring MVC控制器接收请求,处理数据后返回JSON/XML响应,前端通过回调函数动态更新页面内容。
在Java Web开发中,Ajax(Asynchronous JavaScript and XML)技术通过异步通信实现页面局部刷新,提升用户体验,以下是详细实现步骤和最佳实践:
核心实现原理
- 前端:JavaScript发起XMLHttpRequest或Fetch API请求
- 后端:Java Servlet接收请求并返回JSON/XML数据
- 数据处理:前端解析响应数据并更新DOM
完整代码示例
前端页面 (index.jsp)
<!DOCTYPE html>
<html>
<head>Ajax示例</title>
<script>
function getUserData() {
const userId = document.getElementById("userId").value;
// 创建XMLHttpRequest对象
const xhr = new XMLHttpRequest();
xhr.open("GET", "UserServlet?userId=" + userId, true);
xhr.onreadystatechange = function() {
if (xhr.readyState === 4 && xhr.status === 200) {
const user = JSON.parse(xhr.responseText);
document.getElementById("result").innerHTML =
`姓名: ${user.name}<br>邮箱: ${user.email}`;
}
};
xhr.send();
}
</script>
</head>
<body>
<input type="text" id="userId" placeholder="输入用户ID">
<button onclick="getUserData()">获取用户</button>
<div id="result"></div>
</body>
</html>
后端Servlet (UserServlet.java)
@WebServlet("/UserServlet")
public class UserServlet extends HttpServlet {
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws IOException {
String userId = request.getParameter("userId");
// 模拟数据库查询
User user = UserService.getUserById(userId); // 自定义业务逻辑
response.setContentType("application/json");
response.setCharacterEncoding("UTF-8");
response.getWriter().write(new Gson().toJson(user)); // 使用Gson库转换JSON
}
}
// 用户实体类
class User {
String name;
String email;
// 构造方法和getter/setter省略
}
依赖配置 (pom.xml – Maven)
<dependency>
<groupId>com.google.code.gson</groupId>
<artifactId>gson</artifactId>
<version>2.8.9</version>
</dependency>
关键注意事项
-
跨域问题 (CORS)
后端需添加响应头:response.setHeader("Access-Control-Allow-Origin", "*"); -
POST请求处理

- 前端:使用
xhr.open("POST", url)并设置Content-Type - 后端:实现
doPost()方法,通过request.getReader()获取JSON数据
- 前端:使用
-
安全防护
- 验证请求参数(防止SQL注入)
- 添加CSRF令牌(如Spring Security的
_csrf)
-
性能优化

- 使用
@WebServlet注解替代web.xml配置 - 响应数据压缩:
response.setHeader("Content-Encoding", "gzip")
- 使用
现代替代方案
-
Fetch API 示例
fetch("UserServlet?userId=123") .then(response => response.json()) .then(data => console.log(data)); -
框架推荐

- 前端:Axios(自动转换JSON)
- 后端:Spring Boot
@RestController@GetMapping("/user") public User getUser(@RequestParam String userId) { return userService.findUser(userId); }
常见问题解决
- 乱码问题:确保前后端统一使用UTF-8编码
- 404错误:检查Servlet路径映射(
@WebServlet或web.xml) - 500错误:查看Tomcat日志,检查JSON转换异常
- 跨域错误:配置CORS过滤器或使用Nginx反向代理
最佳实践
- 始终设置
response.setContentType("application/json") - 使用try-catch处理后端异常,返回错误码:
response.setStatus(HttpServletResponse.SC_BAD_REQUEST); response.getWriter().write("{"error":"无效参数"}"); - 前端添加加载状态提示和超时处理
- 敏感数据使用HTTPS传输
引用说明:本文代码遵循Java Servlet 4.0规范,参考Oracle官方文档[1],JSON处理使用Google Gson库[2],安全实践依据OWASP Web安全标准[3]。
[1] Oracle Java EE 教程
[2] Gson GitHub
[3] OWASP API Security
