我正在尝试从我的反应应用程序向我的服务器发送POST请求,但是我不断收到状态 400 Bad Request错误。例外是:
“org.springframework.http.converter.HttpMessageNotReadableException”。
错误信息是:
“JSON 解析错误:无法从 START_ARRAY 令牌中反序列化 java.util.LinkedHashMap 的实例;嵌套异常是 com.fasterxml.jackson.databind.JsonMappingException:无法从 START_ARRAY 令牌中反序列化 java.util.LinkedHashMap 的实例\n [来源:java.io.PushbackInputStream@6a188b06;行:1,列:1]"
我尝试使用POSTMAN测试 API,但仍然遇到同样的错误。
@PostMapping("/cart")
public Cart create(@RequestBody CartRequest cartRequest){
return cartRepository.save(new Cart(0,cartRequest.getProductname()));
}
我的模特课是
public class CartRequest {
String productname;
public CartRequest(int productid, String productname) {
this.productname = productname;
}
public String getProductname() {
return productname;
}
public void setProductname(String productname) {
this.productname = productname;
}
@Override
public String toString() {
return "CartRequest{" +
", productname='" + productname + '\'' +
'}';
}
}
存储库类如下
public interface CartRespository extends JpaRepository<Cart, Integer> {
}
请求代码如下
import React, { Component } from "react";
import axios from 'axios';
import NavBar from "./navbar";
export default class Products extends Component {
state = {
isLoading: true,
groups: [],
};
constructor(props){
super(props);
{
this.add = this.add.bind(this);
}
}
add(id, name) {
axios({
method: 'post',
url: '/api/cart',
body: {
productid: id,
productname: name
}
});
}
async componentDidMount() {
const response = await fetch('api/product');
const body = await response.json();
this.setState({ groups: body, isLoading: false });
}
发送请求的Button如下
{this.state.groups.map(group => <button key={group.id} onClick={() => this.add(group.productid, group.name)} className="flex-c-m size1 bg4 bo-rad-23 hov1 s-text1 trans-0-4">Add to Cart</button>)}
我正在尝试执行的是从产品中接收信息并将其添加到购物车中。
已使用GET请求接收到产品信息。
一只甜甜圈
相关分类