高德JS API WEB认证方式通过代理服务器解决秘钥存储问题

摘要:
有关具体用法,请参阅以下JSAPI密钥和安全密钥设置和使用(此密钥升级添加了一个新的安全密钥)。使用密钥的方式可以被正式推荐为在代理服务器上使用JSAPI密钥并将安全密钥转发(安全)。这种方式主要是为了防止前端以明文形式存储密钥,key=您请求的密钥值“>server{listen80;server_name127.0.0.1可以根据实际端口进行修改;

高德JS API的标准使用流程分为5步,但是实际与认证相关的可以缩减为两步:

  1. key申请
  2. key使用
  • key申请

1 为应用添加 Key,「服务平台」一项请选择「 Web 端 ( JSAPI ) 」,设置域名白名单,可选(建议设置域名白名单)。
2 添加成功后,可获取到key值和安全密钥jscode(自2021年12月02日升级,升级之后所申请的 key 必须配备安全密钥 jscode 一起使用)

注意:此次升级不会影响之前已获得 key 的使用;升级之后的新增的key必须要配备安全密钥一起使用,具体用法请您参看下文《JSAPI key和安全密钥设置和使用》(本次key升级新增安全密钥,是为了提升广大用户的对自己的key安全有效管理,降低明文传输被窃取的风险 。)

  • key 使用

可以官方推荐采用JSAPI key搭配代理服务器并携带安全密钥转发(安全)的方式.这种方式主要是避免前端进行明文进行秘钥存储,通过代理服务器来存储秘钥,以避免秘钥泄漏

1 引入地图 JSAPI 脚本之前增加代理服务器设置脚本标签,设置代理服务器域名或地址,将下面示例代码中的「您的代理服务器域名或地址」替换为您的代理服务器域名或ip地址,其中_AMapService为代理请求固定前缀,不可省略或修改。(注意您这个设置必须是在 JSAPI 的脚本加载之前进行设置,否则设置无效。)

<script type="text/javascript">
        window._AMapSecurityConfig = {
            serviceHost:'您的代理服务器域名或地址/_AMapService',  
            // 例如 :serviceHost:'http://1.1.1.1:80/_AMapService',
        }
</script>
<script type="text/javascript" src="https://webapi.amap.com/maps?v=1.4.15&key=您申请的key值"></script> 

2 以 Nginx 反向代理为例,参考以下三个location配置,进行反向代理设置,分别对应自定义地图、海外地图、Web服务,其中自定义地图和海外地图如果没有使用到相关功能也可以不设置。需要将以下配置中的“您的安全密钥”六个字替换为您刚刚获取的jscode安全密钥。

server {
        listen       80;             #nginx端口设置,可按实际端口修改
        server_name  127.0.0.1;      #nginx server_name 对应进行配置,可按实际添加或修改
        
        # 自定义地图服务代理
        location /_AMapService/v4/map/styles {
            set $args "$args&jscode=您的安全密钥";
            proxy_pass https://webapi.amap.com/v4/map/styles;
        }
        # 海外地图服务代理
        location /_AMapService/v3/vectormap {
            set $args "$args&jscode=您的安全密钥";
            proxy_pass https://fmap01.amap.com/v3/vectormap;
        }
        # Web服务API 代理
        location /_AMapService/ {
            set $args "$args&jscode=您的安全密钥";
            proxy_pass https://restapi.amap.com/;
        }
}

保存相关配置之后需要通过命令nginx -s reload 命令重新加载 nginx 配置文件

  • 参考资料

高德地图 JS API web认证

免责声明:文章转载自《高德JS API WEB认证方式通过代理服务器解决秘钥存储问题》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇制作一个倒计时窗口oracle(cast , to_char , to_date )用法 羽毛下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

redis-删除所有key

删除所有Key,可以使用Redis的flushdb和flushall命令 //删除当前数据库中的所有Key flushdb //删除所有数据库中的key flushall 如果要访问 Redis 中特定的数据库,使用下面的命令 //下面的命令指定数据序号为0,即默认数据库 redis-cli -n 0 keys "*" | xargs redis-cli...

小程序安全性浅析

引言 近期微信小程序重磅发布,在互联网界掀起不小的波澜,已有许多公司发布了自己的小程序,涉及不同的行业领域。大家在体验小程序用完即走便利的同时,是否对小程序的安全性还存有疑虑。白泽日前对微信小程序进行初步的安全技术分析,在此整理出来抛砖引玉,如有描述不当的地方,欢迎纠正,轻拍。 本文中,大白将从小程序的框架、功能模块安全、账户使用安全方面进行剖析,希望能为...

全球最高价格成交的域名排名表

目前全球已公布的高价域名交易价格business 750万美元wine.com 330 万美元autos.com 220 万美元bingo.com 110 万美元efowers.com 100 万美元rock.com 100万美元ussexy.com 100 万美元websites.com 97万美元speaker.com 12 万美元drugs.com...

EwoMail 开源邮件服务器安装教程

安装环境 centos6/7系统,服务器需要干净环境,最好是全新安装的系统。 最低配置要求CPU:1核内存:1G硬盘:40G 检查swap 如果没启动swap,这会导致EwoMail的防病毒组件不能启动,所以在安装前先检查swap是否已经启动,如已启动可跳过该步骤。 查看swap [root@mail ~]# free -m 如果swap位置都显示是0,那...

VINS-Mono运行

修改 修改地图保存的路径因为我们现在跑的是euroc数据集,所以我们要修改的地方有两处。 euroc_config.yaml中的pose_graph_save_path项pose_graph_save_path: "/home/kk/自己的路径/" euroc_config.yaml中的output_path项output_path: "/home/kk/...

angular 路由传参的三种方式

1. 问号后面带的参数 url:http://localhost:4200/news?key=japan html 调用方法: <a[routerLink]="['/news']"[queryParams]="{key:'japan'}"> 跳转 </a> ts 调用方法: // 构造函数传入 privaterouter:Rou...