首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SailsJS geoNear问题

SailsJS geoNear问题
EN

Stack Overflow用户
提问于 2015-03-04 09:19:04
回答 2查看 1K关注 0票数 1

我在让geoNear在SailsJS中工作时遇到了很多麻烦。

在我的UserController.js中,我试图对用户模型中的location字段进行geoNear查询。它被定义为具有2D索引的JSON。以下是该字段数据的示例:

"location" : { "type" : "Point" , "coordinates" : [ 42.8003 , -73.8808 ]}

在我的UserController中,我的geoSearch方法如下所示:

代码语言:javascript
复制
 geoSearch: function(req, res) {
    //sails.log.verbose(req);
    var lat = req.param('lat');
    var lng = req.param('long');
    var limit = req.param('limit') || 50;
    var maxDistance = req.param('radius') || 5000; //meters
    sails.log.verbose('lat : ' + lat);
    sails.log.verbose('lng : ' + lng);
    sails.log.verbose('limit : ' + limit);
    sails.log.verbose('maxDistance : ' + maxDistance);
    if (!(lat && lng)) {
        //bad stuff
        res.badRequest('Missing lat or long!');
    } else {
        User.native(function(err, collection) {
          collection.geoNear(lng, lat, {
                    limit: limit,
                    maxDistance: maxDistance, // in meters
                    query: {}, // allows filtering
                    distanceMultiplier: 3959, // converts radians to miles (use 6371 for km)
                    spherical : true
          }, function(mongoErr, users) {
                  if (mongoErr) {
                      console.error(mongoErr);
                      res.send('_geoSearch failed with error='+mongoErr);
                  } else {
                      console.log('users=',users);
                      res.json(users.results);
                    }
             });
        });
    }
}

但是,当我发出如下请求时:

http://localhost:1337/api/user/location/?lat=42.8003&long=-73.8808

我得到了输出:

代码语言:javascript
复制
verbose: lat : 42.8003
verbose: lng : -73.8808
verbose: limit : 50    
verbose: maxDistance : 5000
{ [MongoError: exception: 'near' field must be point]
  name: 'MongoError',
  errmsg: 'exception: \'near\' field must be point',
  code: 17304,
  ok: 0 }

我已经在这方面挣扎了很长一段时间,任何帮助或指导都将不胜感激。

其他信息:

MongoDB ~3.0 SailsJS ~0.10

https://github.com/mongodb/node-mongodb-native/blob/dd7bb687749ffab6ec4c4a6b052ef2cdffc0d780/lib/mongodb/collection.js#L1446

http://docs.mongodb.org/manual/reference/command/geoNear/

EN

回答 2

Stack Overflow用户

发布于 2015-04-08 21:31:07

我也有同样的问题,它是由以下原因引起的:

但是,当我发出如下请求时:

http://localhost:1337/api/user/location/?lat=42.8003&long=-73.8808

因此,当在服务器端接收到数据时,会将其转换为“字符串”。试着这样解决它:

代码语言:javascript
复制
    var latitude = parseFloat(req.param('lat'));
    var longitude = parseFloat(req.param('long'));

希望这能对你有所帮助。

票数 2
EN

Stack Overflow用户

发布于 2015-03-31 03:34:32

在我将以下代码添加到bootstrap.js文件之前,我也遇到过类似的问题

代码语言:javascript
复制
module.exports.bootstrap = function(cb) {
  // Ensure we have 2dsphere index on Property so GeoSpatial queries can work!
  sails.models.stores.native(function (err, collection) {
    collection.ensureIndex({ loc: '2dsphere' }, function () {

      // It's very important to trigger this callack method when you are finished
      // with the bootstrap!  (otherwise your server will never lift, since it's waiting on the bootstrap)
      cb();

    });
  });

};

基本上,你是在确保你的集合有一个与之相关联的2d球体关键字。最后,在您的模型文件中,不要忘记将包含地理坐标的键的类型定义为json,如下所示:

代码语言:javascript
复制
module.exports = {

  attributes: {

    loc: {
      type: 'json'
    }

  }
};

希望这能有所帮助。保重。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28845089

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档