首页 > web前端 > js教程 > 正文

JS如何与SpringRESTfulAPI通信_JS与SpringRESTfulAPI通信的实现教程

爱谁谁
发布: 2025-11-17 22:23:02
原创
679人浏览过
JavaScript 与 Spring RESTful API 通信需通过 fetch 发送 HTTP 请求,Spring 使用 @RestController 提供接口并配置 @CrossOrigin 解决跨域;前端用 GET 获取数据、POST 提交 JSON 数据需设置请求头 Content-Type 并序列化,PUT 更新、DELETE 删除资源,确保请求方法、数据格式正确即可实现完整交互。

js如何与springrestfulapi通信_js与springrestfulapi通信的实现教程

JavaScript 与 Spring RESTful API 通信,主要是通过浏览器fetch APIAJAX 请求后端暴露的 REST 接口发送 HTTP 请求(如 GET、POST、PUT、DELETE 等),Spring Boot 后端接收请求并返回 JSON 数据。下面一步步说明如何实现前后端通信。

1. 确保 Spring 提供 RESTful 接口

在 Spring Boot 中,使用 @RestController 注解创建一个控制器,对外提供 JSON 格式的接口。

@RestController
@CrossOrigin(origins = "http://localhost:3000") // 允许前端域名访问(解决跨域)
public class UserController {

    @GetMapping("/api/users")
    public List<User> getUsers() {
        return Arrays.asList(
            new User(1, "Alice"),
            new User(2, "Bob")
        );
    }

    @PostMapping("/api/users")
    public User createUser(@RequestBody User user) {
        user.setId(99); // 模拟保存
        return user;
    }
}
登录后复制

注意: 必须添加 @CrossOrigin 或配置全局 CORS,否则浏览器会因同源策略拒绝请求。

2. 前端 JS 发送请求获取数据(GET)

使用 fetch() 从 Spring 接口获取用户列表:

fetch('http://localhost:8080/api/users')
  .then(response => response.json())
  .then(data => {
    console.log('用户列表:', data);
    // 可在此渲染到页面
  })
  .catch(error => console.error('请求失败:', error));
登录后复制

3. 前端提交数据到 Spring(POST)

向后端提交新用户数据:

微信 WeLM
微信 WeLM

WeLM不是一个直接的对话机器人,而是一个补全用户输入信息的生成模型。

微信 WeLM 33
查看详情 微信 WeLM
const userData = { name: "Charlie" };

fetch('http://localhost:8080/api/users', {
  method: 'POST',
  headers: {
    'Content-Type': 'application/json',
  },
  body: JSON.stringify(userData)
})
.then(response => response.json())
.then(result => {
  console.log('创建成功:', result);
})
.catch(error => console.error('提交失败:', error));
登录后复制

关键点: 设置 Content-Type: application/json,并用 JSON.stringify 序列化数据。

4. 处理 PUT 和 DELETE 请求

修改用户信息(PUT):

fetch('http://localhost:8080/api/users/1', {
  method: 'PUT',
  headers: { 'Content-Type': 'application/json' },
  body: JSON.stringify({ name: "Alice Smith" })
})
.then(res => res.json())
.then(data => console.log('更新成功:', data));
登录后复制

删除用户(DELETE):

fetch('http://localhost:8080/api/users/1', {
  method: 'DELETE'
})
.then(() => console.log('用户已删除'));
登录后复制

基本上就这些。只要 Spring 正确暴露 REST 接口,JS 使用 fetch 发送标准 HTTP 请求,就能实现完整通信。关键是处理好跨域、数据格式和请求方法。不复杂但容易忽略细节。

以上就是JS如何与SpringRESTfulAPI通信_JS与SpringRESTfulAPI通信的实现教程的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号