提问者:小点点

即使启用了计费帐户,在使用google maps places api时,我仍然会得到“状态:超过查询限制”


已启用的帐单信息

我已经启用了计费功能,但在使用了很少的时间并提出了很少的请求后,我收到了:

您已超过此API的每日请求配额。如果您没有设置自定义每日请求配额,请验证您的项目有一个活动的计费帐户:http://g.co/dev/maps-no-account有关使用限制和谷歌地图JavaScript应用编程接口服务的更多信息,请参阅:https://developers.google.com/maps/documentation/javascript/usage”

从谷歌地图API获取数据时出错。
请在这里检查文档(https://developers.google.com/maps/documentation/javascript/places#place_details_responses)
状态:OVER_QUERY_LIMIT

有人能帮忙解决这个问题吗?

我正在公共/索引中使用React js和脚本代码。html是

<script src="https://maps.googleapis.com/maps/api/js?key=MY_KEY_HERE&libraries=places"></script>

实际上,在这里我用我生成的密钥代替了我的密钥,它工作了1小时,非常好,后来它显示了这个错误

我选择地点的代码是

import React, { Component } from 'react';
import Toper3 from './Toper3';
import { MDBContainer, MDBRow, MDBCol, MDBBtn, MDBInput,MDBCard, MDBCardBody } from 'mdbreact'; 
import { Fragment } from 'react';
import axios from 'axios';
import PlacesAutocomplete, { geocodeByAddress, geocodeByPlaceId, getLatLng } from 'react-places-autocomplete';
import TimeField from 'react-simple-timefield';

const isObject = val => {
    return typeof val === 'object' && val !== null;
  };

  const classnames = (...args) => {
    const classes = [];
    args.forEach(arg => {
      if (typeof arg === 'string') {
        classes.push(arg);
      } else if (isObject(arg)) {
        Object.keys(arg).forEach(key => {
          if (arg[key]) {
            classes.push(key);
          }
        });
      } else {
        throw new Error(
          '`classnames` only accepts string or object as arguments'
        );
      }
    });

    return classes.join(' ');
  };


class FindaRide extends Component {
    constructor(props) {
        super(props);

        this.state = {
            info : [],
            source: '',
            post_address_obj: {},
            errorMessage: '',
            latitude: null,
            longitude: null,
            isGeocoding: false,   
            d_post_address_obj: {},
            d_errorMessage: '',
            d_latitude: null,
            d_longitude: null,
            d_isGeocoding: false,                      
            destination : ''
        }
        }
        handleSourceAddressChange = address => {
            // console.log(address);
            this.setState({
              source: address,
              latitude: null,
              longitude: null,
              errorMessage: ""
            });
          };
          handleDestinationAddressChange = address => {
            // console.log(address);
            this.setState({
              destination: address,
              d_latitude: null,
              d_longitude: null,
              d_errorMessage: ""
            });
          }; 
          refine(){
              alert("refinement");
              const result = this.state.info.filter(word => word.source ==this.state.source&&word.destination==this.state.destination);
              console.log("filtered "+result.length);
              this.props.history.push({pathname : `findlist`, state : {details : this.props.location.state.details,info : this.state.info}}); 

          }
          handleSubmit = (event) => {
            event.preventDefault();
            axios.get('http://127.0.0.1:8000/api2/')
            .then(res=>{
                this.setState({
                    info : res.data
                });
                //console.log(res.data);
                this.refine();

            })                
        }            
    render() {
        return (
            <div>
                <Toper3 >{this.props.location.state.details.firstname} {this.props.location.state.details.lastname}</Toper3>
                <br/>              
                <MDBContainer>
                <MDBRow>

                <MDBCol md="6" className="mb-4"  > {/*style={{ maxWidth: "22rem" }}*/}
                <MDBCard color="indigo" text="white" className="text-center" align="center" style={{ maxWidth: "22rem" }}>
                    <MDBCardBody align = "center" >
                            FILL IN THE DETAILS TO FIND A RIDE
                    </MDBCardBody>
                </MDBCard> 
                </MDBCol>   
                </MDBRow> 
                <form onSubmit={this.handleSubmit}>
                <MDBRow>
                    <MDBCol md="6" className="mb-4">

                    <label> Source </label>

                    <PlacesAutocomplete
                    value={this.state.source}
                    onChange={this.handleSourceAddressChange}
                    >
                    {({ getInputProps, suggestions, getSuggestionItemProps }) => {
                    return (
                        <div className="Demo__search-bar-container">
                        <div className="Demo__search-input-container">
                            <input
                            {...getInputProps({
                                placeholder: "Tag the location",
                                className: "Demo__search-input"
                            })}
                            />
                            {this.state.source.length > 0 && (
                            <button
                                className="Demo__clear-button"
                                onClick={this.handleCloseClick}
                            >
                                x
                            </button>
                            )}
                        </div>
                        {suggestions.length > 0 && (
                            <div className="Demo__autocomplete-container">
                            {suggestions.map(suggestion => {
                                const className = classnames("Demo__suggestion-item", {
                                "Demo__suggestion-item--active": suggestion.active
                                });

                                return (
                                /* eslint-disable react/jsx-key */
                                <div
                                    {...getSuggestionItemProps(suggestion, {
                                    className
                                    })}
                                >
                                    <strong>
                                    {suggestion.formattedSuggestion.mainText}
                                    </strong>{" "}
                                    <small>
                                    {suggestion.formattedSuggestion.secondaryText}
                                    </small>
                                </div>
                                );
                                /* eslint-enable react/jsx-key */
                            })}
                            <div className="Demo__dropdown-footer">
                                <div>
                                <img
                                    src="http://files.hostgator.co.in/hostgator254362/image/powered-by-google.png"
                                    className="Demo__dropdown-footer-image"
                                />
                                </div>
                            </div>
                            </div>
                        )}
                        </div>
                    );
                    }}
                </PlacesAutocomplete>
                </MDBCol>
                </MDBRow>
                <MDBRow>
                <MDBCol md="6" className="mb-4">
                <MDBInput
                label="SOURCE"
                group
                type="text"
                validate
                error="wrong"
                success="right"
                value = {this.state.source}
                style={{ maxWidth: "18rem" }}
                //icon="envelope"
                required
                />      
                </MDBCol>
                </MDBRow>                  
                <MDBRow>
                    <MDBCol md="6" className="mb-4">

                    <label> Destination </label>

                    <PlacesAutocomplete
                    value={this.state.destination}
                    onChange={this.handleDestinationAddressChange}
                    >
                    {({ getInputProps, suggestions, getSuggestionItemProps }) => {
                    return (
                        <div className="Demo__search-bar-container">
                        <div className="Demo__search-input-container">
                            <input
                            {...getInputProps({
                                placeholder: "Tag the location",
                                className: "Demo__search-input"
                            })}
                            />
                            {this.state.destination.length > 0 && (
                            <button
                                className="Demo__clear-button"
                                onClick={this.handleCloseClick}
                            >
                                x
                            </button>
                            )}
                        </div>
                        {suggestions.length > 0 && (
                            <div className="Demo__autocomplete-container">
                            {suggestions.map(suggestion => {
                                const className = classnames("Demo__suggestion-item", {
                                "Demo__suggestion-item--active": suggestion.active
                                });

                                return (
                                /* eslint-disable react/jsx-key */
                                <div
                                    {...getSuggestionItemProps(suggestion, {
                                    className
                                    })}
                                >
                                    <strong>
                                    {suggestion.formattedSuggestion.mainText}
                                    </strong>{" "}
                                    <small>
                                    {suggestion.formattedSuggestion.secondaryText}
                                    </small>
                                </div>
                                );
                                /* eslint-enable react/jsx-key */
                            })}
                            <div className="Demo__dropdown-footer">
                                <div>
                                <img
                                    src="http://files.hostgator.co.in/hostgator254362/image/powered-by-google.png"
                                    className="Demo__dropdown-footer-image"
                                />
                                </div>
                            </div>
                            </div>
                        )}
                        </div>
                    );
                    }}
                </PlacesAutocomplete>
                </MDBCol>
                </MDBRow>

                 <MDBRow>
                <MDBCol md="6" className="mb-4">
                <MDBInput
                label="DESTINATION"
                group
                type="text"
                validate
                error="wrong"
                success="right"
                value = {this.state.destination}
                style={{ maxWidth: "18rem" }}
                //icon="envelope"
                required
                />      
                </MDBCol>
                </MDBRow>                          
                <br/>
                <br/>                                                         
                <MDBRow>  
                <MDBCol md="4" className="mb-4">                   

                <label> DateofJourney </label>    
                <input type = "date" value = {this.state.date} onChange={this.handledatechange} />  {/*(onChange = {event => this.setState({date:event.target.value})} required*/}
                </MDBCol>
                </MDBRow> 

                <MDBRow>
                <MDBCol md="6" className="mb-4">
                <MDBInput
                label="anything to say"
                group
                type="text"
                validate
                error="wrong"
                success="right"
                value = {this.state.ats} onChange={this.handleatschange}
                style={{ maxWidth: "18rem" }}
                icon="envelope"
                required
                />      
                </MDBCol>
                </MDBRow>                                                              
                    <MDBRow>  
                    <MDBCol md="6" className="mb-4">                   
                    <Fragment>

                    <MDBBtn gradient="blue" type="submit">Submit</MDBBtn>
                    </Fragment>  
                    </MDBCol>
                </MDBRow> 
                </form>
                </MDBContainer>                    
            </div>
        );
    }
}

export default FindaRide;

共2个答案

匿名用户

查看您提供的屏幕截图,您的账单账户似乎位于印度。

正如您可能知道的,谷歌地图平台现收现付定价已于2019年11月18日在印度推出。在此更改之前,您的项目受到一些自由限制,当超过这些限制时,可能会导致超查询限制错误。

要解决此问题,您将需要创建一个新的计费帐户,该帐户仅用于Maps API,并将您的Maps项目迁移到此新帐户。

这里有一个指南,你可以遵循它来学习如何为地图创建一个新的计费账户。请确保选择账单账户将支付的正确业务(在本例中为谷歌地图平台)。

下面是帮助您了解如何迁移项目的部分。

如果您在这个问题上仍然需要帮助,我建议您在GCP控制台上向我们提交一个支持案例,以打开一个个性化的沟通渠道,因为这个问题似乎与编程无关。

我希望这能有所帮助!

匿名用户

我一直等到下午1点30分(印度时间),配额刷新了。。现在它可以正常工作了。。因此,答案是等待到“太平洋午夜时间”,然后再次和平地开始工作(请注意,您的计费帐户应启用)