向MongoDB提交数据时获得500个错误和错误值

njthzxwz  于 2023-11-17  发布在  Go
关注(0)|答案(1)|浏览(146)

问题是,当我按下提交按钮时,它会将数据发送到MongoDB,但我也会收到一个500错误。另一个问题是,当我尝试输入用户数据(在html内部)时,它会发送null。有人能帮助我吗?
这是从.tsx

'use client'
import React, {ChangeEvent, FormEvent, useState} from "react";
import axios from 'axios';

const Form : React.FC = () => {
    const [rangeValue, setRangeValue] = React.useState<number | string>("50");
    const [name, setName] = useState('');
    const giveRangeValue = (event: React.ChangeEvent<HTMLInputElement>) => {
        const newRangeValue: string = event.target.value;
        setRangeValue(newRangeValue === "0" ? 0 : newRangeValue);
    }

    const handleSubmit = async (e: FormEvent<HTMLFormElement>)=> {
        e.preventDefault()
        console.log("Name:", name);
        console.log("Range Value:", rangeValue);

        const postData = {
            gebruikersNaam: name,
            risicoScore: rangeValue,
        };
        try {
            const response = await axios.post('/api/risk', postData);

            if (response.status === 200) {
                console.log(response.data);
            } else {
                console.error("Error:", response.data);
            }
        } catch (error){
            console.error(error)
        }
    }

    return (
        <main className={"flex flex-row"}>
            <form onSubmit={handleSubmit}>
                <div className={"form-div space-y-4"}>
                    <div className={"alert flex flex-col items-start"}>
                        <label>
                            Naam
                        </label>
                        <input
                            className={'input'}
                            id="email"
                            value={name}
                            type="text"
                            name="gebruikersNaam"
                            onChange={(e) =>
                                setName(e.target.value)}/>
                    </div>
                    <div className="alert flex flex-row">
                        <input
                            id="range"
                            type={"range"}
                            min={0} max={100}
                            value={rangeValue}
                            onChange={giveRangeValue}>
                        </input>
                        <span className={"value"}>{rangeValue}</span>
                    </div>
                    <div className={"form-btns"}>
                        <button className={"btn mr-5"} type={"submit"}>Maak melding</button>
                        <button className={"btn btn-form ml-10"} type={"button"}><a href={"../"}>Terug</a>
                        </button>
                    </div>
                </div>
            </form>
        </main>
    )
}

export default Form

字符串
这就是app/API/risk

import {getCollection} from "@util/mongodb";
import {Riskscore} from "@/types/db/Riskscore";
import {NextApiRequest, NextApiResponse} from "next";

export async function POST(req: NextApiRequest, res: NextApiResponse) {
    if (req.method === 'POST') {
        try {
            const {gebruikersNaam, risicoScore} = req.body;
            const collection = await getCollection<Riskscore>('netherlands', 'risicoscores');

            const result = await collection.insertOne({
                overlast: "E38",
                gebruikersNaam: "Jack",
                risicoScore: 4,
            });

            if (result.insertedId) {
                res.status(200).json({message: 'Name submitted to MongoDB'});
            } else {
                res.status(500).json({error: 'Error inserting data into MongoDB'});
            }
        } catch (error) {
            res.status(500).json({error: 'Error submitting name to MongoDB'});
        }
    } else {
        res.status(405).end();
    }
}


这是Riskscore.d.ts

import {Document} from "mongodb";

export interface Riskscore extends Document {
    overlast: string
    gebruikersNaam: string
    risicoScore: number
}

kx7yvsdv

kx7yvsdv1#

您的问题出在API响应中。
NextJS 13处理响应的方式与12不同,所以你需要调整你的代码。

import {getCollection} from "@util/mongodb";
import {Riskscore} from "@/types/db/Riskscore";
import {NextApiRequest, NextApiResponse} from "next";
import { NextResponse } from 'next/server'

export async function POST(req: NextApiRequest, res: NextApiResponse) {
  
        try {
            const body = await req.json(); //This is how you access the body in 13
            const {gebruikersNaam, risicoScore} = body;
            const collection = await getCollection<Riskscore>('netherlands', 'risicoscores');

            const result = await collection.insertOne({
                overlast: "E38",
                gebruikersNaam: "Jack",
                risicoScore: 4,
            });

            if (result.insertedId) {
                return NextResponse.json({message: 'Name submitted to MongoDB'}, {status: 200}); //You don't need to specify the status for this 
            } else {
                return NextResponse.json({error: 'Error inserting data into MongoDB'}, {status: 500});
            }
        } catch (error) {
            return NextResponse.json({error: 'Error submitting name to MongoDB'}, {status: 500});
        }
}

字符串

相关问题