寻找一种解决方案,在拥有多个子域的同时安全地使用 Here Maps javascript 地图应用程序密钥 ( https://developer.here.com/documentation/maps/3.1.20.0/api_reference/H.service.Platform.html )。
目前我们初始化地图如下:
this.platform = new H.service.Platform({
apikey: 'XXXX',
useCIT: true,
useHTTPS: true
});
Here maps Javascript 服务要求提供 api 密钥进行身份验证,并在 api 密钥正确时生成 GET。
他们的一种安全方法是列入白名单,但是我们允许我们的用户创建像 xxx.example.com 这样的子域,同时访问同一个 webapp。
HereMaps 安全选项之一如下:
- 使用选项为您的应用凭据创建受信任的域(插入没有协议的值)
此选项似乎不起作用,因为它不允许 * (*.example.com)。我禁用了这个选项以便能够使用这里的地图服务但是我宁愿增加一些安全性而不是直接暴露我们的 APP ID..
我找不到对此处地图 javascript 服务的 oauth2 支持的提及。所以我的问题:
- 这里的地图是否支持他们的 javascript 地图服务的 oauth2 身份验证?
- 除了使用 * 将子域列入白名单之外,还有其他选择吗?
- 有没有一种方法可以将我们的子域代理到我们的主域中。我想到了一个 iframe,但这似乎很麻烦,因为我们与地图交互?
- 也许是更好的方法?
提前致谢