无法在 Google Action Webhook 中创建 XMLHttpRequest
Can't make a XMLHttpRequest inside a Google Action Webhook
我正在尝试自学 Google 行动,到目前为止一切顺利。我成功构建项目的最后一步是使用 Webhooks 从服务器检索数据。
为此,我使用 XMLHttpRequest
向我的服务器发送请求,检索 JSON 数据,解析它并让 Google 助手大声说出来。
代码如下:
const {conversation} = require('@assistant/conversation');
const functions = require('firebase-functions');
var XMLHttpRequest = require("xmlhttprequest").XMLHttpRequest;
const app = conversation({debug: true});
app.handle('start_scene_initial_prompt', (conv) => {
var json = {};
const xhr = new XMLHttpRequest();
const url = 'https://myserver.com/getInfo?token=myauthtoken&data=tempRDC';
xhr.open("GET", url, false);
try {
xhr.send();
if (xhr.status != 200) {
// we lost connection to mothership
conv.add('Erreur: '+ xhr.status);
} else {
json = JSON.parse(xhr.responseText);
conv.add('Temperature is ' + json[0].last + '°C');
}
} catch (error) {
conv.add('Unknown error');
}
});
exports.ActionsOnGoogleFulfillment = functions.https.onRequest(app);
代码编译和部署都很好,但无论我做什么,我总是以“未知错误”告终:
我也尝试了一个异步版本,结果是一样的:(
const {conversation} = require('@assistant/conversation');
const functions = require('firebase-functions');
var XMLHttpRequest = require("xmlhttprequest").XMLHttpRequest;
const app = conversation({debug: true});
app.handle('start_scene_initial_prompt', (conv) => {
var json = {};
const xhr = new XMLHttpRequest();
const url = 'https://nmyserver.com/getInfo?token=myauthtoken&data=tempRDC';
xhr.open("GET", url, false);
try {
xhr.send();
if (xhr.status != 200) {
// we lost connection to mothership
conv.add('Erreur: '+ xhr.status);
} else {
json = JSON.parse(xhr.responseText);
conv.add('temperature is ' + json[0].last + '°C');
}
} catch (error) {
conv.add('Unknown error');
}
});
exports.ActionsOnGoogleFulfillment = functions.https.onRequest(app);
当然,我测试了 HTTP 请求,它非常有效。我还修改了代码以创建类似的东西,但在本地,它也有效。
有人可以帮忙吗?
我没有足够的声誉来发表评论,所以我会把我的想法放在这里。首先,XMLHttpRequest 陈旧且过时。 fetch
API 更加可靠和容易。不管怎样,回到你的代码。我认为您的问题是您在响应准备好之前正在检查 xhr.status
。您还在定义回调之前发送请求。请尝试改用此代码:
var xhr = new XMLHttpRequest();
xhr.onreadystatechange = function() {
if (this.readyState == 4 && this.status == 200) {
// Do your logic
}
};
xhr.open("GET", url);
xhr.send(null);
我正在尝试自学 Google 行动,到目前为止一切顺利。我成功构建项目的最后一步是使用 Webhooks 从服务器检索数据。
为此,我使用 XMLHttpRequest
向我的服务器发送请求,检索 JSON 数据,解析它并让 Google 助手大声说出来。
代码如下:
const {conversation} = require('@assistant/conversation');
const functions = require('firebase-functions');
var XMLHttpRequest = require("xmlhttprequest").XMLHttpRequest;
const app = conversation({debug: true});
app.handle('start_scene_initial_prompt', (conv) => {
var json = {};
const xhr = new XMLHttpRequest();
const url = 'https://myserver.com/getInfo?token=myauthtoken&data=tempRDC';
xhr.open("GET", url, false);
try {
xhr.send();
if (xhr.status != 200) {
// we lost connection to mothership
conv.add('Erreur: '+ xhr.status);
} else {
json = JSON.parse(xhr.responseText);
conv.add('Temperature is ' + json[0].last + '°C');
}
} catch (error) {
conv.add('Unknown error');
}
});
exports.ActionsOnGoogleFulfillment = functions.https.onRequest(app);
代码编译和部署都很好,但无论我做什么,我总是以“未知错误”告终:
我也尝试了一个异步版本,结果是一样的:(
const {conversation} = require('@assistant/conversation');
const functions = require('firebase-functions');
var XMLHttpRequest = require("xmlhttprequest").XMLHttpRequest;
const app = conversation({debug: true});
app.handle('start_scene_initial_prompt', (conv) => {
var json = {};
const xhr = new XMLHttpRequest();
const url = 'https://nmyserver.com/getInfo?token=myauthtoken&data=tempRDC';
xhr.open("GET", url, false);
try {
xhr.send();
if (xhr.status != 200) {
// we lost connection to mothership
conv.add('Erreur: '+ xhr.status);
} else {
json = JSON.parse(xhr.responseText);
conv.add('temperature is ' + json[0].last + '°C');
}
} catch (error) {
conv.add('Unknown error');
}
});
exports.ActionsOnGoogleFulfillment = functions.https.onRequest(app);
当然,我测试了 HTTP 请求,它非常有效。我还修改了代码以创建类似的东西,但在本地,它也有效。
有人可以帮忙吗?
我没有足够的声誉来发表评论,所以我会把我的想法放在这里。首先,XMLHttpRequest 陈旧且过时。 fetch
API 更加可靠和容易。不管怎样,回到你的代码。我认为您的问题是您在响应准备好之前正在检查 xhr.status
。您还在定义回调之前发送请求。请尝试改用此代码:
var xhr = new XMLHttpRequest();
xhr.onreadystatechange = function() {
if (this.readyState == 4 && this.status == 200) {
// Do your logic
}
};
xhr.open("GET", url);
xhr.send(null);