我在loopback api应用程序中创建了一个之前的保存挂钩。我的位置模型有一个地址和一个latlng geopoint
"properties": {
"name": {
"type": "string"
},
"address": {
"type": "string"
},
"latlng": {
"type": "geopoint"
}
},
在我的common\models\location.js
中,我有以下代码:
var https = require('https');
var loopback = require('loopback');
module.exports = function(Location) {
Location.observe('before save', function(ctx, next) {
let path = `/maps/api/geocode/json?address=${ctx.instance['address']}&key=AIzaSyCWk3ePB8idTw74LyhR8tLSCmVgbZDKiIQ`
console.log(path);
https.get({
hostname: 'maps.googleapis.com',
path: encodeURI(path)
}, (res) => {
var body = [];
res.on('data', (d) => {
body.push(d)
})
res.on('end', () =>{
body = JSON.parse(Buffer.concat(body).toString());
let latlng = new loopback.GeoPoint({
lat: body['results'][0]['geometry']['location']['lat'],
lng: body['results'][0]['geometry']['location']['lng']
})
console.log(latlng)
if (ctx.instance) {
ctx.instance.latlng = latlng;
} else {
ctx.data.latlng = latlng;
}
})
})
next();
})
};
我期望此代码要做的是向谷歌地图发出http(s)请求,返回地址的纬度和经度,天真地预测第一个条目正确并将该数据保存到我的模型中属性。我目前正在向控制台输出预期的纬度和经度作为GeoPoint对象:
GeoPoint { lat: 42.3675294, lng: -71.18696609999999 }
如何使用此信息更新我的模型?我试图删除条件if (ctx.instance)
没有区别。我尝试使用不同的对象表示法:
ctx.instance['latlng']=latlng
未记录任何错误。我坚持使用MongoDB,但使用内存数据库的问题是一样的。附加代码位于Github.com/andygauge/api.socialconnect
答案 0 :(得分:1)
此处的问题是next()
的展示位置。由于nodejs的异步性质,在http请求完成和处理之前调用了next()
。在工作流程进行验证后,将对模型进行更改。
解决方案如下所示:
module.exports = function(Location) {
Location.observe('before save', function(ctx, next) {
let path = `/maps/api/geocode/json?address=${ctx.instance['address']}&key=AIzaSyCWk3ePB8idTw74LyhR8tLSCmVgbZDKiIQ`
console.log(path);
https.get({
hostname: 'maps.googleapis.com',
path: encodeURI(path)
}, (res) => {
var body = [];
res.on('data', (d) => {
body.push(d)
})
res.on('end', () =>{
body = JSON.parse(Buffer.concat(body).toString());
let latlng = new loopback.GeoPoint({
lat: body['results'][0]['geometry']['location']['lat'],
lng: body['results'][0]['geometry']['location']['lng']
})
console.log(latlng)
if (ctx.instance) {
ctx.instance.latlng = latlng;
} else {
ctx.data.latlng = latlng;
}
next();
})
})
})
};
感谢您的观点。