Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

Fiddler에서 WebSocket 통신을 모니터링하는 방법

아래의 사이트에서 웹 소켓 통신을 해볼까요?

WebSocket.org - Echo Test
; http://www.websocket.org/echo.html

"Connect" 버튼을 누르고 "Send" 버튼을 누르면 웹 소켓 통신이 이뤄지는 것을 볼 수 있습니다.

그럼, 이것을 Fiddler에서 캡쳐할 수 있을까요? 일단 기본적으로는 캡쳐되지 않아서 아무것도 보이지 않습니다. 대신 별도 설정을 해줘야 하는데요, 다행히 검색해 보면 다음의 글에서 그 방법을 쉽게 찾을 수 있습니다.

What’s New in Fiddler 2.4.4.5
; http://fiddler2.com/blog/blog/2013/06/04/what-s-new-in-fiddler-2-4-4-5

위의 글에 따라 "Rules > Customize Rules" 메뉴를 선택하면 CustomRules.js 스크립트가 메모장으로 로드됩니다. WebSocket 통신을 모니터링하기 위해 다음과 같은 OnWebSocketMessage 메서드를 추가하고 FiddlerApplication.Log.LogString을 통해 Fiddler UI로 내용을 출력하면 됩니다.

import System;
import System.Windows.Forms;
import Fiddler;

// ... [생략] ...

class Handlers
{
    static function OnWebSocketMessage(oMsg: WebSocketMessage) 
    {
        FiddlerApplication.Log.LogString(oMsg.ToString());
    }

    // ... [생략] ...
}

이제 다시 "WebSocket.org - Echo Test" 페이지에 방문해서 "Connect", "Send", "Disconnect"를 테스트 삼아 눌러보면 다음과 같이 "Log" 탭에 FiddlerApplication.Log.LogString 메서드로 출력한 내용이 보여집니다.

fiddler_websocket_log_1.png




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 1/12/2014]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 



2021-04-02 10시45분
sta/websocket-sharp - is built as a single assembly, websocket-sharp.dll.
; https://github.com/sta/websocket-sharp

Golang으로 직접 WebSocket 통신 구현해보기
; https://docs.google.com/document/d/e/2PACX-1vRrf1SD1k4FyXv1G-DPlDbX9F3KsNMnKogF4SrUNqkA9X5P8F-w2yTGzgDunctdpfHIfmoQZaFZ3jm4/pub
정성태

... 136  137  [138]  139  140  141  142  143  144  145  146  147  148  149  150  ...
NoWriterDateCnt.TitleFile(s)
1635정성태2/14/201423649오류 유형: 221. SharePoint - System.InvalidOperationException: The farm is unavailable.
1634정성태2/14/201423872.NET Framework: 424. C# - CSharpCodeProvider로 컴파일한 메서드의 실행이 일반 메서드보다 더 빠르다? [1]파일 다운로드1
1633정성태2/13/201426724오류 유형: 220. 2014년 2월 13일 이후로 Visual Studio 2010 Macro가 동작하지 않는다면? [3]
1632정성태2/12/201444748.NET Framework: 423. C#에서 DirectShow를 이용한 미디어 재생 [2]파일 다운로드1
1631정성태2/11/201423501개발 환경 구성: 217. Realtek 사운드 장치에서 재생되는 오디오를 GraphEditor로 녹음하는 방법
1630정성태2/5/201423989개발 환경 구성: 216. Hyper-V에 올려진 윈도우 XP VM에서 24bit 컬러 및 ClearType 활성화하는 방법
1629정성태2/5/201433746개발 환경 구성: 215. DOS batch - 하나의 .bat 파일에서 다중 .bat 파일을 (비동기로) 실행하는 방법 [1]
1628정성태2/4/201435122Windows: 87. 윈도우 8.1에서 .NET 3.5 설치가 안된다면? [2]
1627정성태2/4/201430205개발 환경 구성: 214. SQL Server Reporting Services를 이용해 간단한 리포트 제작하는 방법
1626정성태2/4/201422233Windows: 86. 윈도우 8.1의 Skydrive 내용이 동기화가 안된다면?
1625정성태2/2/201429316.NET Framework: 422. C++과 C#의 Event 공유파일 다운로드1
1624정성태2/2/201424999.NET Framework: 421. ASP.NET에서 Server.CreateObject와 COM Interop 클래스 생성의 차이점
1623정성태2/1/201429782개발 환경 구성: 213. x86/x64별로 나뉘어진 어셈블리를 한 프로젝트에서 참조하는 방법 [1]파일 다운로드1
1622정성태1/31/201430080VC++: 74. 어떤 것을 쓰면 좋을까요? wvnsprintf, _vsnwprintf_s, StringCbVPrintfW [4]
1621정성태1/31/201421871.NET Framework: 420. 베트남의 11학년(한국의 고2)이 45분만에 푼다는 알고리즘 문제파일 다운로드1
1620정성태1/30/201431943.NET Framework: 419. C# - BigDecimal파일 다운로드1
1619정성태1/30/201428642VS.NET IDE: 85. T4를 이용한 INotifyPropertyChanged 코드 자동 생성파일 다운로드1
1618정성태1/29/201444251Linux: 2. 우분투에서 Active Directory 계정을 이용한 파일 공유
1617정성태1/29/201425542.NET Framework: 418. Thread.Abort 호출의 hang 현상 [1]
1616정성태1/29/201426127디버깅 기술: 63. windbg 디버깅 사례: AppDomain 간의 static 변수 사용으로 인한 crash
1615정성태1/29/201427932.NET Framework: 417. WPF WebBrowser 컨트롤에서 SHDocVw.IWebBrowser2 인터페이스를 구하는 방법 및 순수 WPF 웹 브라우저 컨트롤 소개
1614정성태1/29/201424955.NET Framework: 416. System.Net.Sockets.NetworkStream이 Thread-safe할까?파일 다운로드1
1613정성태1/29/201426902.NET Framework: 415. IIS 작업자 프로세스 재생(recycle)하는 방법 [1]
1612정성태1/29/201423620오류 유형: 219. IIS 500 Internal Server Error - Skydrive에 공유된 경우
1611정성태1/27/201455368.NET Framework: 414. C# - 컴퓨터에서 알아낼 수 있는 고윳값 정리 [3]파일 다운로드1
1610정성태1/26/201439136.NET Framework: 413. C# - chromiumembedded 사용 [11]파일 다운로드1
... 136  137  [138]  139  140  141  142  143  144  145  146  147  148  149  150  ...