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


    高德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认证

    喜欢关注一下,不喜欢点评一下
  • 相关阅读:
    分时区查询问题解决
    .htaccess伪静态实例分享
    net mvc 小目标
    PHP中钩子函数的实现与认识
    session
    修改net基本三层 动软生产
    格式化问题
    数据字典
    关联数据和formatter问题-easyui+微型持久化工具
    说说JSON和JSONP,也许你会豁然开朗
  • 原文地址:https://www.cnblogs.com/chengmuyu/p/15656571.html
Copyright © 2020-2023  润新知