在NextJS 13.4 API中执行PUT的正确方法是什么?(响应,NextAPI响应,NextResponse)使用新的应用程序路由器

cgfeq70w  于 2023-11-18  发布在  其他
关注(0)|答案(1)|浏览(141)

在新的App Router中,在NextJS 13.4中执行简单的PUT的正确方法是什么?
以前使用NextAPIRequest、NextAPIResponse、使用if(req.method = 'PUT')、通过const { id } = request.query;从URL中提取参数以及使用NextAPIResponse抛出错误消息来执行删除的方法似乎已经过时了。

zsohkypk

zsohkypk1#

这里是NextJS 13.4中更新的PUT API,使用了新的app routing,包含了错误消息。
为了使示例更加清晰,我将包含一个对supabase client的调用;您调用的API可以不同,但您可以看到错误消息等。

// FILE NAME /app/api/tacos/route.js
import { NextResponse } from 'next/server';
import supabase from '../../supabase/client';

export async function PUT(request) {
    try {
       // ! OLD WAY
       // const { id, newData } = req.body; // ! OLD WAY
       // const dataOldWay = JSON.parse(request.body); // ! OLD WAY
       const { id, newData } = await request.json();

       const { data: insertedData, error } = await supabase.from("my_table").update(newData).eq("id", id).select();

       if (error) {
          console.log("error catch");
          
          return NextResponse.json({ error: "Internal Server Error" }, { status: 500 });
          // ! THE FOLLOWING DOES NOT WORK - will assume and return a status 200 response
          // return NextResponse.json({ error: 'Internal Server Error', status: 500 });
       }

       return NextResponse.json({ insertedData });
    } catch {
        return NextResponse.json({ error: 'Catch Error - Internal Server Error' }, { status: 500 });
    }
}

字符串
为清楚起见,在Typescript中,此函数签名将为export async function PUT(request: NextRequest) {
阅读更多关于路由处理程序here的信息。
为了完整起见,这里有一个非常简单的函数,我在客户端应用程序中使用它来调用这个API。

// This is being called from a Page in your React app
// 'use client';
// import React from 'react`;
// ... define your other import statements here

const putData = async () => {
   const id = "23423dfe-2343-2323223-232323-232323223";
   const data = { key1: "value1", key2: 22222222 };

   try {
      const response = await fetch("/api/saveCalculation", {
         method: "PUT",
         body: JSON.stringify({id, data}),
         headers: {
            "Content-Type": "application/json",
         },
      });

      if (response.ok) {
          console.log("OKAY");
          const data = await response.json();
          console.log("putData - data updated", responseData);
      } else {
         // Handle the error
         console.log("NOT OKAY");
         const data = await response.json();
         console.log("putData - data NOT updated", responseData);
      }
   } catch (error) {
      console.error("Error", error);
      const data = await response.json();
      console.log("putData - try/catch - error", responseData);
   }
};


注意:你当然可以在代码中更高的位置合并responseData声明,但我保持了它的简单性,为了可读性,使用了更小的范围。

相关问题