此时的网络请求如下:
二、解决办法
经过对比本地开发测试的成功案例,和打包后的错误请求,再加上mapbox/mapbox-gl-geocoder源码(https://github.com/mapbox/mapbox-gl-geocoder)学习,解决办法如下:
图:正确的网络请求
图:错误的网络请求
解决思路:更改源码
原理:在网络请求前添加access_token请求参数,并且更改请求地址
// *\node_modules\@mapbox\mapbox-gl-geocoder\lib\index.js// _geocode函数内部const config = this._setupConfig(requestType, searchInput);// 此处添加config.access_token = this.options.accessToken; // 添加的tokenvar request;switch (requestType) { case GEOCODE_REQUEST_TYPE.LOCAL: request = Promise.resolve(); break; case GEOCODE_REQUEST_TYPE.FORWARD: request = this.geocoderService.forwardGeocode(config).send(); break; case GEOCODE_REQUEST_TYPE.REVERSE: request = this.geocoderService.reverseGeocode(config).send(); break;}
// node_modules\@mapbox\mapbox-sdk\services\geocoding.js// Geocoding.forwardGeocode函数v.assertShape({ query: v.required(v.string), mode: v.oneOf('mapbox.places', 'mapbox.places-permanent'), countries: v.arrayOf(v.string), proximity: v.oneOf(v.coordinates, 'ip'), types: v.arrayOf(v.oneOf(featureTypes)), autocomplete: v.boolean, bbox: v.arrayOf(v.number), limit: v.number, language: v.arrayOf(v.string), routing: v.boolean, fuzzyMatch: v.boolean, worldview: v.string, // 此处添加 access_token: v.string, // 添加access_token验证,如果不添加则传入参数会报错:验证失败})(config);
3. 修改请求参数
备注:可以把config.access_token固定,换成自己的mapbox token,这样步骤1和2就不需要更改(下文是根据前端传入的token动态进行变更)
// node_modules\@mapbox\mapbox-sdk\services\geocoding.js// Geocoding.forwardGeocode函数return this.client.createRequest({ method: 'GET', // 此处修改,添加https://api.mapbox.com前缀 和 "?access_token=" + config.access_token后缀 path: 'https://api.mapbox.com/geocoding/v5/:mode/:query.json' + "?access_token=" + config.access_token, params: pick(config, ['mode', 'query']), query: query });