【问题标题】:Nextjs API request only works locallyNextjs API 请求仅在本地有效
【发布时间】:2021-06-20 05:16:49
【问题描述】:

我正在尝试通过 Next.js API 路由使用“google-spreadsheet”写入谷歌表格。当我在本地测试时,它工作得很好。我可以在谷歌表中看到正在更新的数据。但是,当我将它部署到 Vercel 时,它不起作用。 Vercel 的“功能”日志显示以下错误消息。

错误认证 FetchError: 对https://www.googleapis.com/oauth2/v4/token 的请求失败,原因:客户端网络套接字在建立安全 TLS 连接之前断开 在客户端请求。 (/var/task/node_modules/node-fetch/lib/index.js:1461:11) 在 ClientRequest.emit (events.js:315:20) 在 TLSSocket.socketErrorListener (_http_client.js:469:9) 在 TLSSocket.emit (events.js:315:20) 在 emitErrorNT (internal/streams/destroy.js:106:8) 在 emitErrorCloseNT (internal/streams/destroy.js:74:3) 在 processTicksAndRejections (internal/process/task_queues.js:80:21) { 类型:'系统', 错误号:'ECONNRESET', 代码:'ECONNRESET', 配置:{ 方法:'POST', url: 'https://www.googleapis.com/oauth2/v4/token', 数据: { grant_type: 'urn:ietf:params:oauth:grant-type:jwt-bearer', 断言:....

如果有帮助,下面是我的代码。

export default async function addRowAPI(req, res) {
  if (req.method === 'POST') {
    try {
      let doc;
      try {
        doc = new GoogleSpreadsheet(process.env.SPREADSHEET_ID);
      } catch (error) {
        console.log('error at line 15:', error);
      }

      try {
        await doc.useServiceAccountAuth({
          client_email: process.env.GOOGLE_SHEETS_CLIENT_EMAIL,
          private_key: (process.env.GOOGLE_SHEETS_PRIVATE_KEY || '').replace(
            /\\n/g,
            '\n'
          ),
        });
      } catch (error) {
        console.log('error authentication', error);
      }

      await doc.loadInfo(); 
      console.log(doc.title);

      const sheet = doc.sheetsByTitle['Test_Sheet']; 
      console.log(sheet.title);
      console.log('addRow Doc:', doc);

      const newRow = await sheet.addRow(req.body);
      

      res.status(201).send();
    } catch (error) {
      res.status(500).json(error);
    }
  } else if (req.method === 'GET') {
    res.status(200).json({ ping: 'pong' });
  }
}

【问题讨论】:

  • 您是否在 Vercel 中正确设置了所有环境变量?它抱怨身份验证错误,这可能表明凭据错误/不存在。
  • @juliomalves 你是对的。我错过了设置环境变量之一。它现在正在工作。谢谢:)

标签: javascript reactjs next.js google-sheets-api vercel


【解决方案1】:

如 cmets 中所述,该错误抱怨身份验证问题,表明凭据错误/不存在。仔细检查您是否在 Vercel 中正确设置了所有环境变量。

【讨论】:

    猜你喜欢
    • 2021-04-23
    • 2022-01-17
    • 2022-07-24
    • 2016-12-10
    • 1970-01-01
    • 2016-06-01
    • 1970-01-01
    • 2021-02-09
    • 2023-02-24
    相关资源
    最近更新 更多