0

tilelive および mbtiles モジュールを使用して、ブラウザに .mbtiles ファイルをロードしようとしています。「lon.mbtiles」は、mapbox の Web サイトから直接ダウンロードされたサンプル都市 (ロンドン) であり、mapbox が最後にエラーを起こさない限り、ロード可能である必要があります。

ここに私のserver.jsがあります:

var express = require('express');
var http = require('http');
var app = express();
var tilelive = require('tilelive');
require('mbtiles').registerProtocols(tilelive);

tilelive.load('mbtiles://lon.mbtiles', function(err, source) {
    console.log("Server has connected");
if (err) {
    throw err;
    console.log("mbtiles file not found, please ensure the path is correct in server.js");
}

app.set('port', 7777);

// USED FOR CROSS-SERVER COMMS, NOT NECESSARY RIGHT NOW

// app.use(function(req, res, next) {
//     res.header("Access-Control-Allow-Origin", "*");
//     res.header("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept");
//     next();
// });


// ** Test function for localhost connection, works fine with port 7777 as is stands **

// app.get("/", function(req, res) {
//         res.send("test");
// });



app.get(/^\/v2\/tiles\/(\d+)\/(\d+)\/(\d+).pbf$/, function(req, res){

    var z = req.params[0];
    var x = req.params[1];
    var y = req.params[2];

    console.log('get tile %d, %d, %d', z, x, y);

    source.getTile(z, x, y, function(err, tile, headers) {
        if (err) {
            res.status(404)
            res.send(err.message);
            //console.log(err.message);
        } else {
          res.set(headers);
          res.send(tile);
        }
    });
});

http.createServer(app).listen(app.get('port'), function() {
    console.log('Express server listening on port ' + app.get('port'));
     });
});

スクリプトが実行され、ローカル ファイルから実行された場合はタイルが検出されますが、localhost を動作させることができません。ローカルホストをブロックするファイアウォールの問題が発生しているかどうかを確認するために (コードで) テストしましたが、問題なく動作しました。

app.getNodeJS に関する私の知識は、2 日間のビデオと記事を超えるものではありませんが、私の理解では、これは回線の問題です。

ローカルホストを実際に接続してエラーを返さないようにするにはどうすればよいですか?

前もって感謝します

4

1 に答える 1

0

.mbtile を読み込むには、3 つのスラッシュを使用する必要がありました'mbtiles:///lon.mbtiles'

sqliteもインストールする必要がありました require('sqlite3').verbose();

于 2016-11-13T20:57:04.363 に答える