Невозможно отобразить плитку GeoJSON с Polymaps из-за CORS
Я пытаюсь визуализировать простую карту с помощью Polymaps, но проблема CORS становится посередине:
Сторона сервера
Для сервера я использую TileStache со следующим файлом конфигурации:
{
"cache":
{ "name": "Test", "path": "/home/jose/data/maps", "umask": "0000" },
"layers":
{ "local": {
"provider": {"name": "mbtiles", "tileset": "mundo.mbtiles" }
},
"arpt": {
"allowed origin": "*",
"provider": { "name": "vector", "driver": "GeoJSON",
"parameters": {"file": "/home/user/data/data.geojson"},
"properties": ["ICAO"] }
}
}
}
Я выполняю такой сервер с помощью:
$ tilestache-server.py -c config.cfg -i localhost -p 8080
Этот сервер, кажется, работает должным образом, учитывая, что я на самом деле могу видеть плитки карты и могу получать плитки геоджона.
Сторона клиента
Вот где у меня проблема. Firefox жалуется на:
Cross-Origin Request Blocked: The Same Origin Policy disallows reading the remote resource at http://127.0.0.1:8080/arpt/5/15/12.geojson. This can be fixed by moving the resource to the same domain or enabling CORS.
(повторяется для каждой запрошенной плитки GeoJSON)
Код JavaScript, который я запускаю:
<!DOCTYPE html>
<head>
<title></title>
<script type="text/javascript" src="polymaps.min.js"></script>
<link rel="points" type="application/json" href="http://localhost:8080/arpt">
<style type="text/css">
@import url("example.css");
#map {
background: #E6E6E6;
}
.layer use {
stroke: #ccc;
stroke-opacity: .5;
}
#copy {
color: #000;
opacity: .5;
}
#copy a {
color: #000;
}
</style>
</head>
<body>
<h1>Comienzo</h1>
<p>Fin</p>
<!--Polymaps Build-->
<!--div id="map"></div -->
<script>
//curl -H "Origin: http://example.com" -H "Access-Control-Request-Methos: POST" -H "Access-Control-Request-Headers: X-Requested-With" -X OPTIONS --head --verbose http://localhost:8080/arpt/3/2/0.geojson
//window.document.domain = 'http://localhost';
var po = org.polymaps;
//Add Image tiles as base
var map = po.map()
//.container( document.getElementById("map").appendChild(po.svg("svg")) )
.container( document.body.appendChild(po.svg("svg")) )
.zoom(5)
.zoomRange([1,5])
.center({lat: 37.76, lon: 0 })
.add( po.interact() );
// Control de zoom sin control de dirección
map.add( po.compass().pan("none") );
// Tile que vienen de mbtiles.
map.add( po.image().url( "http://127.0.0.1:8080/local/{Z}/{X}/{Y}.png") );
// Tile GeoJSON
map.add( po.geoJson()
.url("http://127.0.0.1:8080/arpt/{Z}/{X}/{Y}.geojson")
.tile(true)
//.zoomRange([3,5])
.on("load", load) );
function load (e) {
for (var i=0;i<e.featureslength;i++) {
console.log(e.properties.ICAO,e.features[i].geometry.coordinates);
}
/* po.stylist()
//.attr("stroke", function(d) { return "blue"; })
.title(e.properties.ICAO; });*/
}
</script>
<!-- script type="text/javascript" src="ex01.js">
</script -->
</body>
</html>
Я просто новичок, изучающий JavaScript и играющий с этими технологиями. Я не совсем понимаю проблему CORS, учитывая, что я использую все локальные хосты на виртуальной машине.
Любая подсказка о том, что я сделал неправильно, будет оценена.
С уважением,
Хосе М.