Как Watson помощник различает разных пользователей - PullRequest
0 голосов
/ 30 мая 2018

Я создал чат-бота с помощью Watson assistant.Я использую его через вызовы API.

Предположим, есть два разных человека, которые хотят использовать моего чат-бота одновременно.тогда что мне нужно сделать, чтобы Уотсон понял, что два разных человека отправляют запросы.

, если есть какие-либо дополнительные параметры, которые можно включить для решения этой проблемы?если да, пожалуйста, укажите.

//var objDiv = document.getElementById("chatbotid");
//objDiv.scrollTop = objDiv.scrollHeight;
document.querySelector("#input").addEventListener("keypress", function(e) {
  var key = e.which || e.keyCode;
  if (key === 13) { //Enter button
    var input = document.getElementById("input").value; //storing input value
    document.getElementById("input").value = "";
    TempChatInput = document.getElementById("chatbot");
    TempChatInput.innerHTML += "user: " + input + "<br/><br/>";
    //document.getElementById("user").innerHTML = input;
    output(input);
  }
});

function output(input) {
  //var xhr = new XMLHttpRequest();
  var newData = "{\"input\": {\"text\":" + "\"" + input + "\"" + "}}";
  //var input = $('input').val();
  var dataText;
  $.ajax({
    url: "https://gateway.watsonplatform.net/assistant/api/v1/workspaces/myWorkspaceID/message?version=2018-02-16",
    beforeSend: function(xhr) {
      //xhr.setRequestHeader("Authorization", "Basic" + btoa(username + ":" + password));
      xhr.setRequestHeader("Authorization", "Basic " + btoa("my username" + ":" + "my password"));
    },
    type: "POST",
    dataType: "json",
    contentType: "application/json",
    processData: false,
    //data: "{\"input\": {\"text\": \"location\"}}",
    data: newData,
    success: function(data) {
      dataText = data["output"]["text"];
      //console.log(dataText);
      TempChat = document.getElementById("chatbot");
      TempChat.innerHTML += "Chatbot: " + dataText + "<br/><br/>";
      //document.getElementById("chatbot").innerHTML = dataText;
      //alert(dataText);
      var objDiv = document.getElementById("chatbotid");
      objDiv.scrollTop = objDiv.scrollHeight;
    },
    error: function() {
      alert("Cannot get data");
    }
  });
  //document.getElementById("chatbot").innerHTML = dataText;
  }
body {
  color: #421;
  font-weight: bold;
  font-size: 18px;
  background: #069597;
  background-image: url("girl.png");
  background-repeat: repeat-y;
}

span {
  color: #104A70;
  padding: 1px;
}

::-webkit-input-placeholder {
  color: #104A70;
}

#main {
  position: fixed;
  top: 10%;
  right: 60px;
  width: 400px;
  border: 0px solid #421;
  padding: 40px;
}

#main div {
  margin: 10px;
}

#input {
  border: 0;
  background: rgb(255, 255, 255);
  padding: 5px;
  border: 1px solid #421;
  color: #104A70;
}

#line {
  text-align: center;
  background: #3BB2B4;
}

#chatbotid {
  overflow: scroll;
  width: 400px;
  height: 400px;
  background: rgb(230, 230, 225);
  padding: 5px;
  border: 2px solid #104A70;
}
<div id="line">
  <hr/>
  <h1 style="color:rgb(255,255,255);"> Vawsum Help Desk</h1>
  <hr/>
</div>
<div id="main">
  <!--	<div> <span id="user"></span></div>  -->
  <!--I have deleted user from this line -->
  <div id="chatbotid"> <span id="chatbot"></span></div>
  <!--I have deleted chatbot from this line -->
  <div><input id="input" type="text" placeholder="say something..." autocomplete="off" /></div>
</div>

1 Ответ

0 голосов
/ 30 мая 2018

Когда вы устанавливаете соединение с Watson Assistant, вы получаете идентификатор разговора, который возвращается вместе с ответом.

Вы можете использовать это, чтобы определить, разговаривают ли два разных пользователя одновременно.


Обновление на основе комментария:

Watson Assistant не имеет состояния.У него нет памяти о предыдущих вызовах.

Когда вы вернете полученный объект контекста, он продолжит работу с того места, где последний раз остановился.Если вы не предоставите идентификатор разговора или неверный идентификатор разговора, он сгенерирует новый.

...