Google Maps InvalidKeyMapError при создании сайта с помощью Gatsby и Netlify

Я создал сайт Gatsby, который использует компонент карт Google, который я взял из пакета npm «google-maps-react». Все отлично работает в моей локальной среде, но когда я развертываю Netlify, я получаю «Ошибка API JavaScript Карт Google: InvalidKeyMapError».

Я прошел все шаги, чтобы убедиться, что мой ключ API зарегистрирован и активирован правильно. Я позаботился о том, чтобы объявить ключ API как переменную среды в пользовательском интерфейсе Netlify, и я обращаюсь к нему в своем компоненте с помощью «process.env.GOOGLE_API_KEY».

import React from "react"
import { Map, InfoWindow, Marker, GoogleApiWrapper } from "google-maps-react"

export class MapContainer extends React.Component {


  render() {

    return (
      <Map google = {this.props.google} zoom = {14} initialCenter = {{lat:37.769461, lng:-122.251831}}>
        <Marker onClick = {this.onMarkerClick} name = {"Current location"} />
        <InfoWindow onClose = {this.onInfoWindowClose}>
          <div>
            ...some code
          </div>
        </InfoWindow>
      </Map>
    )
  }
}

export default GoogleApiWrapper({
    apiKey: (`${process.env.GOOGLE_API_KEY}`)
  })(MapContainer)

Из того, что я прочитал, объявление переменной среды GOOGLE_API_KEY в пользовательском интерфейсе Netlify было всем, что мне нужно было сделать, чтобы иметь к нему доступ, но я явно что-то упускаю. Любая помощь приветствуется, спасибо

Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
5
0
2 043
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Переменные среды должны начинаться с GATSBY_ в javascript на стороне клиента, как показано в файле документы.

Используйте GATSBY_GOOGLE_API_KEY и process.env.GATSBY_GOOGLE_API_KEY, чтобы получить к ним доступ во время сборки и включить их в код клиента Gatsby.

Я могу подтвердить. У меня тоже была такая же проблема, но этот пост решил мою проблему. Спасибо!

Student22 27.05.2020 05:48

Очень странно, но это решило ту же проблему в моем приложении Gatsby.

KeshavDulal 08.09.2020 03:29

Другие вопросы по теме