Cómo establecer atributos complejos en su bot Lex V2
Los atributos de sesión y solicitud son asignaciones de cadena a cadena de atributos y valores. En muchos casos, puede utilizar la asignación de cadenas para transferir valores de atributos entre la aplicación cliente y un bot. En algunos casos, sin embargo, es posible que necesite transferir datos binarios o una estructura compleja que no se puede convertir fácilmente a una asignación de cadenas. Por ejemplo, el siguiente objeto JSON representa una matriz de las tres ciudades más pobladas de los Estados Unidos:
{
"cities": [
{
"city": {
"name": "New York",
"state": "New York",
"pop": "8537673"
}
},
{
"city": {
"name": "Los Angeles",
"state": "California",
"pop": "3976322"
}
},
{
"city": {
"name": "Chicago",
"state": "Illinois",
"pop": "2704958"
}
}
]
}Esta matriz de datos no se convierte bien en una asignación de cadena a cadena. En este caso, puede transformar un objeto en una cadena sencilla para poder enviársela a su bot con las operaciones RecognizeText y RecognizeUtterance.
Por ejemplo, si utiliza JavaScript, puede utilizar la operación JSON.stringify para convertir un objeto a JSON y la operación JSON.parse para convertir un texto JSON a un objeto JavaScript:
// To convert an object to a string. var jsonString = JSON.stringify(object, null, 2); // To convert a string to an object. varobj= JSON.parse(JSON string);
Para enviar los atributos con la operación RecognizeUtterance, debe codificar en base64 los atributos antes de incluirlos en el encabezado de la solicitud, tal y como se muestra en el siguiente código JavaScript:
varencodedAttributes= new Buffer(attributeString).toString("base64");
Puede enviar datos binarios a las operaciones RecognizeText y RecognizeUtterance convirtiendo primero los datos a una cadena codificada en base64 y, a continuación, enviar la cadena como el valor en los atributos de sesión:
"sessionAttributes" : {
"binaryData": "base64 encoded data"
}