千家信息网

如何使用nginx代理天地图做缓存解决跨域问题

发表于:2024-11-20 作者:千家信息网编辑
千家信息网最后更新 2024年11月20日,这篇文章主要介绍了如何使用nginx代理天地图做缓存解决跨域问题,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。作为一个GISer开发者
千家信息网最后更新 2024年11月20日如何使用nginx代理天地图做缓存解决跨域问题

这篇文章主要介绍了如何使用nginx代理天地图做缓存解决跨域问题,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

作为一个GISer开发者,天地图是经常在项目中以底图的形式出现,其加载地址如:

1.天地图矢量:http://t{0-6}.tianditu.com/DataServer?T=vec_w&x={x}&y={y}&l={z}
2.天地图影像:http://t{0-6}.tianditu.com/DataServer?T=img_w&x={x}&y={y}&l={z}
3.天地图地形:http://t{0-6}.tianditu.com/DataServer?T=ter_w&x={x}&y={y}&l={z}

其中t{0-6}是天地图提供的7个服务器名称t0,t1,t2....

下面是我以openlayers加载天地图过程中遇到跨域问题

1、错误的产生条件

// 采用openlayers加载天地图var layer = new ol.layer.Tile({  source: new ol.source.XYZ({    // crossOrigin: 'Anonymous', // 是否请求跨域操作    url: url // 天地图地址  })});

如果没有用到crossOrigin属性就不会产生跨域问题,一般这个参数也不会设置。

这个参数使用场景如下官网所述:

The crossOrigin attribute for loaded images. Note that you must provide a crossOrigin value if you are using the WebGL renderer or if you want to access pixel data with the Canvas renderer. See https://developer.mozilla.org/en-US/docs/Web/HTML/CORS_enabled_image for more detail.

查阅MDN文档(https://developer.mozilla.org/zh-CN/docs/Web/HTML/CORS_settings_attributes),可以发现crossOrigin有两个取值

在开发过程中,往往需要本地运行开发版,服务器运行生产版。当两个版本在同一个浏览器中访问时,设置了crossOrigin就会出现跨域问题,如下图所示的错误,

has been blocked by CORS policy: No 'Access-Control-Allow-Origin'header is present on the requested resource.

注:只有天地图设置了crossOrigin之后会出现这个问题,谷歌底图是不会出现的,原因是:

天地图在返回的request header的Origin属性设置成当前访问的IP,而google底图Origin属性设置的是*,意味着不同IP的系统在浏览器缓存了google瓦片之后依然能访问google底图。

2、错误解决的方法

2.1 简单暴力的方法

简单暴力的解决方法就是清除浏览器的缓存图片,在同一时刻,只查看一个其中的一个系统,如果要查看另一个系统,必须事先清除浏览器图片缓存

2.2 删除CrossOrigin属性

重新审视一遍地图需求,判断是否真的需要crossOrigin属性,如果不需要,就根本不会出现这个问题

2.3 nginx代理解决

如果前面的方法都感觉不合适,那就用nginx来代理解决吧,它可以解决跨域问题,也可以将瓦片缓存至本地,加快访问速度。

直接上配置文件哈。

#user nobody;worker_processes 4;#error_log logs/error.log;#error_log logs/error.log notice;#error_log logs/error.log info;#pid    logs/nginx.pid;events {  worker_connections 1024;}http {  include    mime.types;  default_type application/octet-stream;  #log_format main '$remote_addr - $remote_user [$time_local] "$request" '  #         '$status $body_bytes_sent "$http_referer" '  #         '"$http_user_agent" "$http_x_forwarded_for"';  #access_log logs/access.log main;  sendfile    on;  #tcp_nopush   on;  #keepalive_timeout 0;  keepalive_timeout 65;  #gzip on;    client_max_body_size 20M;     # 关键代码块1  proxy_temp_path ../proxy_cache/tianditu_temp;  proxy_cache_path ../proxy_cache/tianditu levels=1:2 keys_zone=cache_one:200m inactive=1d max_size=30g;  upstream tianditu_server {    server t0.tianditu.com weight=1 max_fails=2 fail_timeout=30s;    server t1.tianditu.com weight=1 max_fails=2 fail_timeout=30s;    server t2.tianditu.com weight=1 max_fails=2 fail_timeout=30s;    server t3.tianditu.com weight=1 max_fails=2 fail_timeout=30s;    server t4.tianditu.com weight=1 max_fails=2 fail_timeout=30s;    server t5.tianditu.com weight=1 max_fails=2 fail_timeout=30s;    server t6.tianditu.com weight=1 max_fails=2 fail_timeout=30s;  }    server {    listen    8088;    server_name localhost;    #charset koi8-r;    #access_log logs/host.access.log main;     # 关键代码块2    location /DataServer {      more_set_headers 'Access-Control-Allow-Origin: *';      add_header Access-Control-Allow-Headers X-Requested-With;      add_header Access-Control-Allow-Methods GET,POST,OPTIONS;            proxy_cache cache_one;      proxy_cache_key $uri$is_args$args;      proxy_pass http://tianditu_server/DataServer;    }  }}

下面解释一下配置文件:

关键代码块1:

1、采用nginx upstream配置一组服务地址,做负载均衡用,其效果优于openlayers顺序遍历t0至t6

2、设置了代理缓存临时地址和缓存地址,这里可以采用相对路径

关键代码块2

匹配到DataServer之后,需要

1、设置跨域header,这里用了一个新的nginx模块--headers-more,需要在编译nginx时加入,如果是windows下用nginx,可以用这个网站的安装包:https://openresty.org,它预编译了很多nginx实用模块

2、用proxy_pass将地址代理到 http://tianditu_server/DataServer地址上,其中tianditu_server就是上面配置负载均衡的服务组名称。

感谢你能够认真阅读完这篇文章,希望小编分享的"如何使用nginx代理天地图做缓存解决跨域问题"这篇文章对大家有帮助,同时也希望大家多多支持,关注行业资讯频道,更多相关知识等着你来学习!

天地 缓存 问题 地址 代理 属性 代码 关键 方法 浏览器 篇文章 服务 浏览 配置 系统 错误 开发 均衡 两个 参数 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 数据库修改数据语句的关键字是 北邮光网络技术期末考试 数据库中的外键约束的作用 app 软件开发的含义 网络安全发展规划与实践 怎么查梦幻西游服务器在哪个区 收到网络安全周短信 数据库的字段名是什么意思 网络技术对应哪些专业 网络安全审查办法自什么时间起 2021网络安全周内容 唐山千寻网络技术有限公司 网络安全竞赛证书制作不出来 新疆银行软件开发岗笔试题 网络技术基础复习题 研发 网络技术需求 网络安全和信息化审计报告 网络安全宣传小学生手抄报 辩论网络安全重在什么 服务器生存第1关怎么过 软件开发最好的大学是哪所 毕业论文及数据库吗 全栈网络安全工程师价格 怎么看服务器在不在服务 桓台化工管理软件开发 北京正规网络技术服务资费 风暴奇侠无法连接服务器 潍坊直播软件开发企业 软件开发 工作岗位 万方数据库如何查引用
0