5

私はjavascriptにかなり慣れていないので、ほぼ一日中スクリプトを調べて、デバッグと調査のためにwebsocketトラフィックを盗聴する方法があるかどうか、またはwebsocketを自分のものに単純に置き換える方法があるかどうかを確認しています。

私はChromeでフィルタリングを試み、フィドラーを使用しましたが、何らかの形でトラフィックが隠されています。Wireshark は、どちらも見つけることができないものをつかむようですが、少なくとも hex に慣れていない私にとっては、ぎくしゃくしています。

ただし、Websocket のようなものを javascript で拡張できるので、Greasemonkey のようなものを使用して作成されたときに「拡張」して、想定どおりのことを実行し続けるだけでなく、追加の作業も行うことができることを本当に知りたいです。

たとえば、Greasemonkey などで次の websocket を拡張して、onMessage(evt) が引き続き画面に書き込みを行うようにすることはできますが、アラート (メッセージ);?? を追加することはできますか? これは、トラフィックを監視していると言うよりも望ましいでしょう。ソースファイルを変更できないことに注意してください。

Google Chrome は、ドラゴン オブ アトランティスのようなゲームの Websocket サイトを識別していません。アクションは ajax 投稿ですが、チャットは、フラッシュ パラメータにある Websocket です。

<!DOCTYPE html>

 <meta charset="utf-8" />

<title>WebSocket Test</title>

<script language="javascript" type="text/javascript">

  var wsUri = "ws://echo.websocket.org/";
  var output;

  function init()
  {
    output = document.getElementById("output");
    testWebSocket();
  }

  function testWebSocket()
  {
    websocket = new WebSocket(wsUri);
    websocket.onopen = function(evt) { onOpen(evt) };
    websocket.onclose = function(evt) { onClose(evt) };
    websocket.onmessage = function(evt) { onMessage(evt) };
    websocket.onerror = function(evt) { onError(evt) };
  }

  function onOpen(evt)
  {
    writeToScreen("CONNECTED");
    doSend("WebSocket rocks");
  }

  function onClose(evt)
  {
    writeToScreen("DISCONNECTED");

  }


  function onMessage(evt)

  {

    writeToScreen('<span style="color: blue;">RESPONSE: ' + evt.data+'</span>');

    websocket.close();

  }



  function onError(evt)

  {

    writeToScreen('<span style="color: red;">ERROR:</span> ' + evt.data);

  }



  function doSend(message)

  {

    writeToScreen("SENT: " + message); 

    websocket.send(message);

  }


  function writeToScreen(message)

  {

    var pre = document.createElement("p");

    pre.style.wordWrap = "break-word";

    pre.innerHTML = message;

    output.appendChild(pre);

  }


  window.addEventListener("load", init, false);


</script>


<h2>WebSocket Test</h2>


<div id="output"></div>


</html>

私はこれをstackoverflowで見つけました。日付をwebsocketに置き換えるだけですか??

Date = function (Date) { return function () { var date = clockwork.instantiate(Date, arguments); var args = arguments.length; var arg = arguments[0]; if ((args === 3 || args == 6) && arg < 100 && arg >= 0) date.setFullYear(arg); return date; } }(Date);
4

0 に答える 0