search

Home  >  Q&A  >  body text

There are no HTTP methods exported in "...". Export named exports for each HTTP method

I'm working on a React.js/Next.js project using Google reCAPTCHA. My frontend seems to be working (I know that because I've set up the print statements), but the backend gives me this error in my local terminal:

Error - No HTTP method exported in 'srcappapirecaptcharoute.ts'. Export named exports for each HTTP method.

An error also occurred in my development tools:

'POST http://localhost:3000/api/recaptcha 405 (Method not allowed)'

I think this is related to other errors.

This is the code:

import { NextApiRequest, NextApiResponse } from 'next';
import express from 'express';
import cors from 'cors';
import bodyParser from 'body-parser';
import axios from 'axios';

const app = express();
app.use(cors());
app.use(bodyParser.json());

console.log('hi');

export async function postHandler(req: NextApiRequest, res: NextApiResponse){

  if (req.method === 'POST') {
    const { token } = req.body;
    try {
      const response = await axios.post(
      `https://www.goog le.com/recaptcha/api/siteverifysecret=${process.env.NEXT_PUBLIC_RECAPTCHA_SECRET_KEY}&response=${token}`
      );

      console.log('you made it here');

      if (response.data.success) {
        res.status(200).json({ message: 'reCAPTCHA verification successful' });
      } else {
        res.status(400).json({ message: 'reCAPTCHA verification failed' });
      }
    } catch (err) {
      console.log(err);
      res.status(500).json({ message: 'Internal server error' });
    }
  };
}

I tried renaming the function, exporting it as const, and exporting it at the end of the file rather than at naming time.

P粉310931198P粉310931198343 days ago435

reply all(1)I'll reply

  • P粉505917590

    P粉5059175902024-01-29 09:27:52

    If you are using NextJS 13 App Router, please use the following code:
    File: ./app/api/recaptcha/route.ts

    import { NextResponse } from 'next/server';
    import axios from 'axios';
    
    export async function POST(req: Request){
      const { token } = req.body;
      try {
        const response = await axios.post(`https://www.google.com/recaptcha/api/siteverify?secret=${process.env.NEXT_PUBLIC_RECAPTCHA_SECRET_KEY}&response=${token}`,{},{headers: { "Content-Type": "application/x-www-form-urlencoded; charset=utf-8" }});
        if (response.data.success) {
          return NextResponse.json({ message: 'reCAPTCHA verification successful' })
        } else {
          return NextResponse.json({ message: 'reCAPTCHA verification failed' })
        }
      } catch (err) {
        return NextResponse.json({ message: 'Internal server error' })
      }
    }
    

    If you are using NextJs 13 Page Router, then use:
    File: ./pages/api/recaptcha.ts

    import { NextApiRequest, NextApiResponse } from 'next';
     
    const handler = async (req: NextApiRequest, res: NextApiResponse) => {
      if (req.method === 'POST') {
        const { token } = req.body;
        try {
          const response = await axios.post(`https://www.google.com/recaptcha/api/siteverify?secret=${process.env.NEXT_PUBLIC_RECAPTCHA_SECRET_KEY}&response=${token}`,{},{headers: { "Content-Type": "application/x-www-form-urlencoded; charset=utf-8" }});
          if (response.data.success) {
            return res.status(200).json({ message: 'reCAPTCHA verification successful' })
          } else {
            return res.status(400).json({ message: 'reCAPTCHA verification failed' })
          }
        } catch (err) {
          return res.status(500).json({ message: 'Internal server error' })
        }
      }
      else{
        res.status(405).json({message: "Method Not Allowed"})
      }
    };
     
    export default handler;
    

    Hope this solves your problem :)

    reply
    0
  • Cancelreply