文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

向 Spring 端点发送 POST,给出状态 400

2024-02-13 17:19

关注

问题内容

在 React 应用程序中,将 playerId 参数从前端传递到后端似乎存在问题。 Spring控制器中的createGame函数设置为接收playerId参数,但该值未使用Axios从前端正确传递。已尝试使用长整型和字符串作为playerId,但问题仍然存在。 仍然获得状态 400!

春天

反应

  1. 将其存储为字符串参数。
  2. 我使用了@PathVariable。
  3. 我尝试直接在Postman中写入参数。
  4. 我尝试更改端点。
  5. 我没有展示的另一个端点(/login)运行良好,因此代理没有问题。

解决方法

在共享的 react 屏幕截图中 - 看起来您发送了一个 json 正文。

但是,在 spring controller 中 - 使用@requestparam。

看起来您要么需要更改react部分来调用像'/api/games/{playerid}'这样的url(这样playerid将作为url的一部分传递),要么更新spring控制器以接受@requestbody(并创建一个带有字段“playerid”的类) - 因此整个对象可以作为请求主体传递。

目前 react 发送了一个正文 - 但 spring 正在寻找 url 查询参数。两个部分都需要做同样的事情 - 无论它是什么。

spring 的变化如下所示:

public ResponseEntity createGame(@RequestBody PlayerRequest playerRequest) {
    Long playerId = playerRequest.getPlayerId();
    // other code goes here
}

public class PlayerRequest {
    private Long playerId;

    public Long getPlayerId() {
        return playerId;
    }

    public void setPlayerId(Long playerId) {
        this.playerId = playerId;
    }
}

以上就是向 Spring 端点发送 POST,给出状态 400的详细内容,更多请关注编程网其它相关文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯