Я учусь создавать. NET Core web api, поэтому я решил попробовать простой POST-запрос к бэкэнду с помощью fetch () во внешнем интерфейсе.
Front-end
const Form = () => {
const submission = {
contactNumber: "123153214",
name: "JJ Lin",
group: 5,
tableId: 3,
isAccompanied: true,
};
const handleSubmit = async (event) => {
event.preventDefault();
fetch("https://localhost:5001/api/guest-submission", {
method: "POST",
mode: "no-cors",
headers: {
"Content-Type": "application/json",
},
body: JSON.stringify(submission),
})
.then((response) => {
if (response.status !== 200) {
console.log("not ok" + response.status);
}
})
.catch((err) => {
console.log(err);
});
};
return <button onClick={handleSubmit}>Click here to submit</button>;
};
На бэкэнде у меня есть класс гостя:
public class Guest
{
public string ContactNumber { get; set; }
public string Name { get; set; }
public Group Group { get; set; }
public int TableId { get; set; }
public bool IsAccompanied { get; set; }
}
С моим контроллером как таковым:
[HttpPost]
public ActionResult SubmitGuest([FromBody]Guest guestInput)
{
var guest = new Guest
{
ContactNumber = guestInput.ContactNumber,
Name = guestInput.Name,
Group = guestInput.Group,
TableId = guestInput.TableId,
IsAccompanied = guestInput.IsAccompanied
};
Console.WriteLine(guest.Name);
return Ok();
}
Использование Почтальона работало для меня. Но используя созданный мной интерфейс реакции, я продолжал получать ошибку 415.
Может кто-нибудь просветить меня, пожалуйста? Спасибо за вашу помощь !!!