2017-11-01 12 views
0

이 질문에 대한 다른 답변을 보았지만 아무도 보편적으로 적용 할 수없는 것 같습니다. 다른 질문에는 답이 없습니다.START_OBJECT 토큰에서 String 인스턴스를 deserialize 할 수 없습니다.

당연히 "START_OBJECT 토큰에서 String 인스턴스를 deserialize 할 수 없습니다." 내 콘솔에. 내 websocketdata에서 문자열 화 (응답)하려고 할 때 발생한다고 생각합니다.

다음은 코드입니다.

<?php /** 
* The Header for our theme. 
* 
* Displays all of the <head> section and everything up till <div id="main"> 
* 
*/ ?> 
<!DOCTYPE html> 
<html <?php language_attributes(); ?>> 
    <!--<![endif]--> 
    <head> 
     <meta http-equiv="Content-Type" content="<?php bloginfo('html_type'); ?>; charset=<?php bloginfo('charset'); ?>" /> 
     <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0" /> 
     <script type="text/javascript" 
      src='http://martialparks.com/wp-content/themes/js/gamesparks-rt.js'></script> 
     <script type='text/javascript' src='http://martialparks.com/wp-content/themes/js/gamesparks.js'></script> 
     <script type='text/javascript' 
      src='http://martialparks.com/wp-content/themes/js/gamesparks-functions.js'></script> 
     <script type='text/javascript' src='http://martialparks.com/wp-content/themes/js/hmac-sha256.js'></script> 
     <link rel="profile" href="http://gmpg.org/xfn/11" /> 
     <link rel="pingback" href="<?php bloginfo('pingback_url'); ?>" /> 
     <?php 
     wp_head(); 
     ?> 
    </head> 

    <body <?php body_class() ?>> 
     <body onload="init()"> 
     <!--Start Header Wrapper--> 
     <div class="header_wrapper"> 
      <div class="header"> 
       <!--Start Container--> 
       <div class="container_24"> 
        <div class="grid_24"> 
         <div class="logo"> <a href="<?php echo esc_url(home_url()); ?>"><img src="<?php if (business_directory_get_option('business_directory_logo') != '') { ?><?php echo esc_url(business_directory_get_option('business_directory_logo')); ?><?php 
           } else { 
            echo esc_url(get_template_directory_uri() . '/images/logo.png'); 
           } 
           ?>" alt="<?php bloginfo('name'); ?>" /></a></div> 
        </div> 
        <div class="clear"></div> 
       </div> 
       <!--End Container--> 
       <div class="clear"></div> 
      </div> 
      <div class="clear"></div> 
      <!--Start Menu Wrapper--> 
      <div class="menu_wrapper"> 
       <div class="top_arc"></div> 
       <div class="menu-container"> 
        <div class="container_24"> 
         <div class="grid_24"> 
          <?php business_directory_nav(); ?> 
         </div> 
        </div> 
        <div class="clear"></div> 
       </div> 
       <div class="clear"></div> 
       <div class="bottom_arc"></div> 
      </div> 
      <!--End Container--> 
      <div class="clear"></div> 
     </div> 
     <!--End Header Wrapper--> 
     <div class="clear"></div> 
     <div class="wrapper"> 
      <!--Start Container--> 
      <div class="container_24"> 
       <div class="grid_24"> 
       <br/> 
       <br/> 
       <br/> 
        <input id="apiKey" type="hidden" value="A319082inSk2"/> 
        <input id="apiSecret" type="hidden" value="BNuYLYZAoDZDZyh1F7tbR8BMTiqeJbWt"/> 
        <label for="apiCredential">Api Credential</label><input id="apiCredential"/> 
        <label for="username">User Name</label><input id="username"/> 
        <label for="password">Password</label><input id="password"/> 
        <button onClick='gamesparks.registrationRequest("testuser", "testuser", "testuser", registerResponse)'>Register</button> 
        <button onClick='gamesparks.authenticationRequest(username, password, loginResponse)'>Login</button> 
        <button onClick='gamesparks.accountDetailsRequest(accountDetailsResponse)'>Account Details</button> 
        <button onClick='customEvent()'>Custom Event</button> 
        <button onClick='testRT()'>Test RT</button> 
        <i>Special thanks to the awesome team at GameSparks!</i> 
        <div id="messages"></div> 
        <br/> 
        <br/> 


User Name 
<div id="displayName" style="color: blue;"></div> 
Coins 
<div id="Coins" style="color: red;"></div> 
Exp 
<div id="Exp" style="color: green;"></div> 
Leader Points 
<div id="LeadP" style="color: darkgreen;"></div> 
Hero Points 
<div id="HeroP" style="color: purple;"></div> 

       <style> 
        #map { 
        height: 400px; 
        width: 100%; 
        } 
       </style> 

       <h3>Find a Park</h3> 
        <div id="map"></div> 
        <script> 
         function initMap() { 
         var Velocity = {lat: 38.308101, lng: -85.815464}; 
         var map = new google.maps.Map(document.getElementById('map'), { 
          zoom: 4, 
          center: Velocity 
         }); 
         var marker = new google.maps.Marker({ 
          position: Velocity, 
          map: map 
         }); 
         } 
        </script> 
        <script async defer 
        src="https://maps.googleapis.com/maps/api/js?key=AIzaSyDSHCinT3IVWFCLUudbsMZV6644GNrGiwc&callback=initMap"> 
        </script> 



<script type="text/javascript"> 

    //Create a gamesparks object to be used 
    var gamesparks = new GameSparks(); 

    //Initialse the SDK 
    function init() { 
    gamesparks.initPreview({ 
     key: document.getElementById('apiKey').value, 
     secret: document.getElementById('apiSecret').value, 
     credential: document.getElementById('apiCredential').value, 
     onNonce: onNonce, 
     onInit: onInit, 
     onMessage: onMessage, 
     logger: console.log, 
    }); 
    } 

    function accountDetailsResponseCreator() { 
    var response = { 
     displayName: 'A User', 
     currencies: {Coins: 'A coin', Exp: 'A exp', LeadP: 'A lead p', HeroP: 'A hero p'} 
    } 
    accountDetailsResponse(response) 
    } 

    //Callback function to hmac sha256 a nonce with the secret. It's assumed you will have your own method of securing the secret; 
    function onNonce(nonce) { 
    return CryptoJS.enc.Base64.stringify(CryptoJS.HmacSHA256(nonce, document.getElementById('apiSecret').value)); 
    } 

    //Callback to handle when the SDK is initialised and ready to go 
    function onInit() { 
    console.log("Initialised"); 
    } 

    //Callback to handle async messages from the gamesparks platform 
    function onMessage(message) { 
    console.log("onMessage"); 
    } 

    //Response handler examples 
    function registerResponse(response) { 
    console.log(JSON.stringify(response)); 
    } 

    function loginResponse(response) { 
    console.log(JSON.stringify(response)); 
    } 

    function accountDetailsResponse(response) { 
    console.log (JSON.stringify(response));//logs the string to console 
    document.getElementById("displayName").innerHTML = (response.displayName); 
    document.getElementById("Coins").innerHTML = (response.currencies.Coins); 
    document.getElementById("Exp").innerHTML = (response.currencies.Exp); 
    document.getElementById("LeadP").innerHTML = (response.currencies.LeadP); 
    document.getElementById("HeroP").innerHTML = (response.currencies.HeroP); //returns value of name from string. I've tried doing each line with semicolons at the end, and all in a group with commas separating them. Both just give me the first variable and delete the rest. 
    } 

    function customEvent() { 
    gamesparks.sendWithData(
     "LogEventRequest", 
     { 
     eventKey: "FIRST_EVENT", 
     NUMBER_ATTR: 123, 
     STRING_ATTR: "this is a string", 
     JSON_ATTR: {key1: 12, key2: "abc"} 
     }, 
     function (response) { 
     console.log(JSON.stringify(response)); 
     } 
    ); 
    } 

    var apiKey = "2974660weiMa"; 
    var apiSecret = "p5pFVnohi5eWPYETb4aPgeMLtd95bjfJ"; 
    var myTimer = null; 
    var myRTSession = function() { 
    }; 
    var numCycles = 0; 

    myRTSession.started = false; 
    myRTSession.onPlayerConnectCB = null; 
    myRTSession.onPlayerDisconnectCB = null; 
    myRTSession.onReadyCB = null; 
    myRTSession.onPacketCB = null; 
    myRTSession.session = null; 

    myRTSession.start = function (connectToken, host, port) { 
    var index = host.indexOf(":"); 
    var theHost; 

    if (index > 0) { 
     theHost = host.slice(0, index); 
    } else { 
     theHost = host; 
    } 

    console.log(theHost + " : " + port); 

    myRTSession.session = GameSparksRT.getSession(connectToken, theHost, port, myRTSession); 
    if (myRTSession.session != null) { 
     myRTSession.started = true; 

     myRTSession.session.start(); 
    } else { 
     myRTSession.started = false; 
    } 
    }; 

    myRTSession.stop = function() { 
    myRTSession.started = false; 

    if (myRTSession.session != null) { 
     myRTSession.session.stop(); 
    } 
    }; 

    myRTSession.log = function (message) { 
    var peers = "|"; 

    for (var k in myRTSession.session.activePeers) { 
     peers = peers + myRTSession.session.activePeers[k] + "|"; 
    } 

    console.log(myRTSession.session.peerId + ": " + message + " peers:" + peers); 
    }; 

    myRTSession.onPlayerConnect = function (peerId) { 
    myRTSession.log(" OnPlayerConnect:" + peerId); 

    if (myRTSession.onPlayerConnectCB != null) { 
     myRTSession.onPlayerConnectCB(peerId); 
    } 
    }; 

    myRTSession.onPlayerDisconnect = function (peerId) { 
    myRTSession.log(" OnPlayerDisconnect:" + peerId); 

    if (myRTSession.onPlayerDisconnectCB != null) { 
     myRTSession.onPlayerDisconnectCB(peerId); 
    } 
    }; 

    myRTSession.onReady = function (ready) { 
    myRTSession.log(" OnReady:" + ready.toString()); 

    if (myRTSession.onReadyCB != null) { 
     myRTSession.onReadyCB(ready); 
    } 
    }; 

    myRTSession.onPacket = function (packet) { 
    myRTSession.log(" OnPacket:" + packet.toString()); 

    if (myRTSession.onPacketCB != null) { 
     myRTSession.onPacketCB(packet); 
    } 
    }; 

    function testRT() { 
    myRTSession.stop(); 

    gamesparks.initPreview({ 
     key: apiKey, 
     secret: apiSecret, 
     credential: "", 
     onNonce: onNonceRT, 
     onInit: onInitRT, 
     onMessage: onMessageRT, 
     logger: console.log, 
    }); 
    } 

    function onNonceRT(nonce) { 
    return CryptoJS.enc.Base64.stringify(CryptoJS.HmacSHA256(nonce, apiSecret)); 
    } 

    function onInitRT() { 
    console.log("Initialised"); 

    gamesparks.deviceAuthenticationRequest((Math.floor(Math.random() * (999 - 1)) + 1).toString(), null, null, "js", null, null, function (response) { 
     if (response.error) { 
     console.error(JSON.stringify(response.error)); 
     } else { 
     sendMatchmakingRequest(); 
     } 
    }); 
    } 

    //Callback to handle async messages from the gamesparks platform 
    function onMessageRT(message) { 
    //console.log("message " + JSON.stringify(message)); 
    if (message["@class"] === ".MatchFoundMessage") { 
     var accessToken = message["accessToken"]; 
     var host = message["host"]; 
     var port = message["port"]; 

     myRTSession.stop(); 

     if (myTimer) { 
     clearTimeout(myTimer); 
     } 

     myTimer = setInterval(mainRTLoop, 10); 

     myRTSession.start(accessToken, host, port); 
    } else if (message["@class"] === ".MatchNotFoundMessage") { 
     console.log("MATCH NOT FOUND"); 

     sendMatchmakingRequest(); 
    } 
    } 

    function sendMatchmakingRequest() { 
    gamesparks.sendWithData("MatchmakingRequest", 
     { 
     skill: 1, 
     matchShortCode: "Match_STD" 
     }, 
     function (response) { 
     if (response.error) { 
      console.error(JSON.stringify(response.error)); 
     } else { 
      console.log("Match OK..."); 
     } 
     } 
    ); 
    } 

    function mainRTLoop() { 
    if (myRTSession.started) { 
     myRTSession.session.update(); 

     var data = RTData.get(); 

     data.setLong(1, numCycles); 

     myRTSession.session.sendRTData(1, GameSparksRT.deliveryIntent.RELIABLE, data, []); 

     numCycles++; 
    } 
    } 
</script> 
</body> 
</html> 

저의 삶에 대해 저는 무엇이 일어나고 있는지 또는 어떻게 고쳐야하는지 전혀 모릅니다. 173을 참조하는 버튼을 활성화 할 때 문제가 나타납니다.
function loginResponse(response) { console.log(JSON.stringify(response)); }

그러나 귀하의 공명 정서에 영향을 미치지 않도록하십시오. 필자는이 코드를 이전 버전의 코드와 비교하여 필자의 모든 기능에서 변경된 사항을 확인할 수 없었습니다.

답변

0

글쎄, 결론은 다음과 같습니다. 바보 인 사람은 stackoverflow에 질문을 게시하지 마십시오. 아무도 응답하지 않습니다. 그것들은 의미가 있기 때문에가 아니라, 기초를 배우는 것이 중요하기 때문입니다.

 <button onClick='gamesparks.authenticationRequest(username, password, loginResponse)'>Login</button> 

이상한, 오른쪽 :

그래서 문제는이 내 코드의 상단에 나를 위해 유래? 그렇지 않아. 무슨 일을했는지 ​​인증 요청에 대한 입력을 내 html 요소 입력과 일치하도록 변경하려고했습니다. (내 요소가 사용자 이름과 암호로 레이블 된 곳을 확인하십시오.) 작동하지 않았고, 분명히 그냥 숨기고 옮겼습니다. 잊어 버렸어. 내가 한 것은 "username"을 "testuser"로 바꾸는 것입니다. 이 값은 내가 인증하려고 시도했던 값과 일치합니다. 이제, 내 아기는 내 시험 대상자에게 값을 돌려주고 꿈처럼 달리고 있습니다.

거친 사랑에 감사드립니다, stackoverflow.