Ошибка на стороне клиента при использовании токена анализатора тона iBM Bluemix на стороне сервера

Я уже получил токен на стороне сервера и сохранил его в файле cookie, но не могу понять, почему я получаю сообщение об ошибке при запросе API с этим токеном.

Вот запрос jQuery ajax, который я отправляю:

$.ajax({
     url:'https://gateway.watsonplatform.net/tone-analyzer/api/v3/tone',
         data:{
            'X-Watson-Authorization-Token':readCookie('token'),
            'text':input,
            'version':'v3',
            'version_date':'2016-05-19'
        },
        dataType:'jsonp',
        contentType:'application/json',
        method:'GET',
        success:function(tone){
            console.log(tone);
        }
    });

Если я не использую dataType:jsonp, Я получаю ошибку источника контроля доступа. Когда я не пользуюсь contentType:application/json или использовать contentType:application/javascript, Я получаю диалог входа в систему, когда запрашивается API, запрашивая имя пользователя и пароль. Но мне не нужно было передавать имя пользователя и пароль теперь, когда у меня есть токен. И когда я запускаю его таким образом, с dataType и contentType, я получаю неверный запрос на 400 ошибок.

Кто-нибудь знает, что я делаю не так? В документации сказано, что я могу использовать токен на стороне клиента. Но мне нужно получить его на стороне сервера.

ОБНОВИТЬ:

Согласно совету, я не обращаюсь к коду на стороне сервера через jjery ajax-вызов отдельного php-файла. Я могу получить токен, но когда я передаю его вызову API в тональный анализатор, я получаю ошибку 400. Независимо от того, расшифровываю ли я токен или нет.

Вот мой JQuery:

$.when($.ajax({
    url:'watsonToken.php',
    type:'GET',
})).done(function(token){
    console.log('watsonToken, lasts 1 hour: ', decodeURI(token));
    $.ajax({
        url:'https://gateway.watsonplatform.net/tone-analyzer/api/v3/tone',
        type:'POST',
        data:JSON.stringify({
            'body':input,
            'version':'2016-05-19'
        }),
        contentType:'application/json',
        headers:{
            'X-Watson-Authorization-Token':decodeURI(token)
        },
        success:function(tone){
            console.log(tone);
        },
        error: function(error){
            console.error('Error: Couldn\'t use token: ', error);
        }
    });
}).fail(function(){
    console.error('Error: Couldn\'t fetch watson token');
});

И файл watsonToken.php, который получает токен:

<?php
$accessWatsonToken = curl_init();
$params=http_build_query(array('url' =>     'https://gateway.watsonplatform.net/tone-analyzer/api/v3/tone'));
curl_setopt($accessWatsonToken, CURLOPT_URL, "https://gateway.watsonplatform.net/authorization/api/v1/token?$params");
curl_setopt($accessWatsonToken, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($accessWatsonToken, CURLOPT_USERPWD, 'username':password');
print curl_exec($accessWatsonToken);
curl_close($accessWatsonToken);
?>

1 ответ

Я думаю, что вы пытаетесь поставить X-Watson-Authorization-Token в качестве параметра тела, когда он должен быть заголовком и version должен быть параметром запроса. Кроме того, в поле данных для вашего вызова rest JQuery вы странизируете объект, который уже является строкой, и в заголовках вы декодируете ответ токена, который не нужно декодировать.

Более подробную информацию о том, как создавать звонки в службу тонального анализатора Watson, вы можете найти здесь.

РЕДАКТИРОВАТЬ: Вот полный пример использования PHP.

index.php

<!doctype html>
<html lang="en">
<head>
    <title>Watson Tone Analyzer Example</title>
    <meta charset="utf-8"/>
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.3/jquery.min.js"></script>
</head>

<body>
    <h2>This is an example of client side call to Watson Tone analyzer service using an authorization token.</h2>
    <div id="myoutput"></div>
</body>
</html>

<script>
analyze();

function analyze(){
  $.ajax({
       url:'/get-token.php',
          type:'GET',
          success:function(token){
              callToneAnalyzer(token);
          },
          error: function(err) {
              console.error(err);
          }
      });
}

function callToneAnalyzer(token) {
  $.ajax({
       url:'https://gateway.watsonplatform.net/tone-analyzer/api/v3/tone?version=2016-05-19',
          type:'POST',
          data: JSON.stringify({text: "this is my sample text"}),
          contentType: 'application/json',
          headers: {
            'X-Watson-Authorization-Token': token
          },
          success:function(tone){
              $("#myoutput").text(JSON.stringify(tone));
          },
          error: function(err) {
              $("#myoutput").text(JSON.stringify(err));
          }
      });
}
</script>

получить-token.php

<?php
// Send a http request using curl
function getToken(){
     $username='YOUR-TONE-ANALYZER-USERNAME';
     $password='YOUR-TONE-ANALYZER-PASSWORD';
     $URL='https://gateway.watsonplatform.net/authorization/api/v1/token?url=https://gateway.watsonplatform.net/tone-analyzer/api';

     $ch = curl_init();
     curl_setopt($ch, CURLOPT_URL, $URL);
     curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
     curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "GET");
     curl_setopt($ch, CURLOPT_TIMEOUT, 30); //timeout after 30 seconds
     curl_setopt($ch, CURLOPT_HTTPAUTH, CURLAUTH_BASIC);
     curl_setopt($ch, CURLOPT_USERPWD, "$username:$password");

     $result=curl_exec ($ch);
     curl_close ($ch);
     return $result;
}
echo getToken();
?>
Другие вопросы по тегам