Microsoft MVP성태의 닷넷 이야기
.NET Framework: 370. C# - WebKit .NET 사용 [링크 복사], [링크+제목 복사],
조회: 34437
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
(연관된 글이 1개 있습니다.)

C# - WebKit.NET 사용

일반적으로 Microsoft 플랫폼에서는 Internet Explorer 프로그램이 ActiveX로 제공되는 WebBrowser 컨트롤을 사용하게 되는데요. Web Renderer로서 오픈소스인 WebKit도 선택사항일 수 있습니다.

게다가 C#이 워낙 interop 기능이 훌륭해서 WebKit을 닷넷 응용 프로그램에서 사용하는 것도 가능한데요. 다행히 이것조차도 우리가 만들 필요 없이 이미 다음의 사이트에 공개되어 있습니다. ^^

WebKit .NET
; http://webkitdotnet.sourceforge.net/downloads.php

WebKit .NET 소스 코드는 WebKit이 컴파일 된 상태에서 WebKit.Interop.dll만으로 연동하는 형식을 취하고 있습니다. 따라서, 그냥 소스 코드를 다운로드해도 그다지 어렵지 않게 빌드할 수 있습니다.

그래서, 이 글에서는 WebKit .NET 소스 코드를 다운로드한 것으로 진행합니다.

압축 해제를 하면 WebKit.NET.sln 파일과 이하 프로젝트 파일들이 나오고 Visual Studio 2012에서도 WebKit.NET.sln 파일을 그냥 로드할 수 있습니다. 그럼 다음과 같은 2개의 프로젝트를 볼 수 있는데요.

  1. WebKitBrowser
  2. WebKitBrowserTest

WebKitBrowser 프로젝트가 WebKit을 WinForm UserControl로 노출시켜주는 역할을 하고, WebKitBrowserTest 프로젝트는 WebKitBrowser 사용자 컨트롤을 이용해 만든 간단한 웹 브라우저입니다.

그런데 빌드해 보면 약간 오류가 발생합니다. 우선, WebKit.interop.dll이 .NET 4.0으로 빌드된 것이기 때문에 각각 로드된 2개의 프로젝트 모두 Target Framework를 .NET Framework 4.0으로 바꿔줍니다.

그다음, 몇몇 소스 코드에서 webkit.interop.dll에는 구현 클래스를 인자로 받도록 되어 있지만 정작 인터페이스를 받도록 구현된 소스 코드들이 있는데요. 빌드 시 WebPolicyDelegate.cs에서 가장 먼저 오류가 발생하는데, 구현 함수의 signature를 각각 다음과 같이 변경해 주어야 합니다.

소스 코드: WebPolicyDelegate.cs

public void decidePolicyForMIMEType(WebView WebView, string type, IWebURLRequest request, webFrame frame, IWebPolicyDecisionListener listener)

==> public void decidePolicyForMIMEType(WebView WebView, string type, WebURLRequest request, webFrame frame, IWebPolicyDecisionListener listener)


public void decidePolicyForNavigationAction(WebView WebView, CFDictionaryPropertyBag actionInformation, IWebURLRequest request, webFrame frame, IWebPolicyDecisionListener listener)

==> public void decidePolicyForNavigationAction(WebView WebView, CFDictionaryPropertyBag actionInformation, WebURLRequest request, webFrame frame, IWebPolicyDecisionListener listener)
  
  
public void decidePolicyForNewWindowAction(WebView WebView, CFDictionaryPropertyBag actionInformation, IWebURLRequest request, string frameName, IWebPolicyDecisionListener listener)
    
==> public void decidePolicyForNewWindowAction(WebView WebView, CFDictionaryPropertyBag actionInformation, WebURLRequest request, string frameName, IWebPolicyDecisionListener listener)

이와 유사한 오류가 WebResourceLoadDelegate.cs, WebUIDelegate.cs 파일에도 발생하는데요. 역시 같은 방식으로 인터페이스 형식을 구현 클래스 형식으로 바꿔주는 식으로 해결하면 됩니다.

마지막으로 오류 하나가 WebKitBrowser.cs에서 발생하는데,

public void Navigate(string url)
{
    if (loaded)
    {
        // prepend with "http://" if url not well formed
        if (!Uri.IsWellFormedUriString(url, UriKind.Absolute))
            url = "http://" + url;

        activationContext.Activate();

        WebMutableURLRequest request = new WebMutableURLRequestClass();
        request.initWithURL(url, _WebURLRequestCachePolicy.WebURLRequestUseProtocolCachePolicy, 60);
        request.setHTTPMethod("GET");

        webView.mainFrame().loadRequest(request); // 컴파일 오류!

        activationContext.Deactivate();
    }
    else
    {
        initialUrl = url.Length == 0 ? null : new Uri(url);
    }
}

왜냐하면, loadRequest의 첫 번째 인자는 WebURLRequest 형식을 받는데, WebMutableURLRequest는 WebURLRequest 타입 상속을 받지 않고 IWebURLRequest 인터페이스 상속을 받으므로 사실상 2개는 암시적 변환에 위배되므로 그와 같은 오류가 발생하는 것입니다.

따라서, 다음과 같이 적당한 변환을 해주면 컴파일도 되고 실행도 정상적으로 됩니다.

WebMutableURLRequest request = new WebMutableURLRequestClass();
request.initWithURL(url, _WebURLRequestCachePolicy.WebURLRequestUseProtocolCachePolicy, 60);
request.setHTTPMethod("GET");

IWebURLRequest req = request as IWebURLRequest;
WebURLRequest req2 = req as WebURLRequest;

webView.mainFrame().loadRequest(req2);

복잡한가요? ^^ 그래서 제가 첨부 파일에 위의 변경 사항을 모두 적용한 Visual Studio 2012용 프로젝트를 올려 두었으니 그냥 다운로드해 Ctrl + F5 키로 실행만 해주시면 됩니다. 그럼 다음과 같이 예제 웹 브라우저가 실행되는 것을 볼 수 있습니다.

webkit_browser_1.png

대강의 사용법은 WebKitBrowserTest 프로젝트의 소스 코드를 참고해도 되지만 다음의 글에서도 자세하게 설명하고 있으니 참고하시면 됩니다.

Tutorial - The Basics
; http://webkitdotnet.sourceforge.net/basics.php

참고로, Visual Studio에서 F5 디버깅을 하면 몇몇 NotImplementedException에서 멈출 수가 있습니다. 이것은 의도된 것이니 그냥 디버깅을 계속하면 정상적으로 실행되므로 무시하시면 됩니다.




와~~~ 그래서 기쁜 마음으로, 우리 회사 제품인 Jennifer .NET의 모니터링 화면을 보려고 했는데요. ^^ 현재 제니퍼 4.5 버전은 Java Applet을 사용하고 있는데 WebKitBrowserTest 프로그램으로 방문하니 ^^; 비정상 종료가 되어 버립니다. 자바의 hs_err_pid...log 파일이 남는 걸로 봐서 JVM과의 충돌이 발생한 듯 싶은데요. 이것이 .NET 층이 생겨서 그런 것인지, WebKit .NET에 포함된 WebKit의 문제인지는 판단할 수가 없었습니다. (테스트해 보니, JRE 6/7 모두 비정상 종료!)

결국, Applet이나 ActiveX가 없는 제한된 상황에서나 WebKit.NET이 선택 옵션으로 들어갈 것 같습니다. ^^




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 6/26/2021]

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

비밀번호

댓글 작성자
 



2013-06-06 11시51분
[짜두] 윈포에서 다른 브라우저를 쓴다는 생각이 전환이 대단해보입니다~ㅎ 멋지다는~ ^^
[guest]
2013-06-08 02시25분
요거 말고, chromium을 기반으로 한 웹 브라우저 컨트롤도 있어요. 조만간 소개할께요. ^^
정성태

... [106]  107  108  109  110  111  112  113  114  115  116  117  118  119  120  ...
NoWriterDateCnt.TitleFile(s)
11274정성태8/22/201719363.NET Framework: 674. Thread 타입의 Suspend/Resume/Join 사용 관련 예외 처리
11273정성태8/22/201721630오류 유형: 415. 윈도우 업데이트 에러 Error 0x80070643
11272정성태8/21/201724784VS.NET IDE: 120. 비주얼 스튜디오 2017 버전 15.3.1 - C# 7.1 공개 [2]
11271정성태8/19/201719212VS.NET IDE: 119. Visual Studio 2017에서 .NET Core 2.0 프로젝트 환경 구성하는 방법
11270정성태8/17/201730699.NET Framework: 673. C#에서 enum을 boxing 없이 int로 변환하기 [2]
11269정성태8/17/201721480디버깅 기술: 93. windbg - 풀 덤프에서 .NET 스레드의 상태를 알아내는 방법
11268정성태8/14/201721045디버깅 기술: 92. windbg - C# Monitor Lock을 획득하고 있는 스레드 찾는 방법
11267정성태8/10/201725103.NET Framework: 672. 모노 개발 환경
11266정성태8/10/201724906.NET Framework: 671. C# 6.0 이상의 소스 코드를 Visual Studio 설치 없이 명령행에서 컴파일하는 방법
11265정성태8/10/201753147기타: 66. 도서: 시작하세요! C# 7.1 프로그래밍: 기본 문법부터 실전 예제까지 [11]
11264정성태8/9/201724055오류 유형: 414. UWP app을 signtool.exe로 서명 시 0x8007000b 오류 발생
11263정성태8/9/201719538오류 유형: 413. The C# project "..." is targeting ".NETFramework, Version=v4.0", which is not installed on this machine. [3]
11262정성태8/5/201718244오류 유형: 412. windbg - SOS does not support the current target architecture. [3]
11261정성태8/4/201720830디버깅 기술: 91. windbg - 풀 덤프 파일로부터 강력한 이름의 어셈블리 추출 후 사용하는 방법
11260정성태8/3/201718924.NET Framework: 670. C# - 실행 파일로부터 공개키를 추출하는 방법
11259정성태8/2/201718158.NET Framework: 669. 지연 서명된 어셈블리를 sn.exe -Vr 등록 없이 사용하는 방법
11258정성태8/1/201718950.NET Framework: 668. 지연 서명된 DLL과 서명된 DLL의 차이점파일 다운로드1
11257정성태7/31/201719152.NET Framework: 667. bypassTrustedAppStrongNames 옵션 설명파일 다운로드1
11256정성태7/25/201720645디버깅 기술: 90. windbg의 lm 명령으로 보이지 않는 .NET 4.0 ClassLibrary를 명시적으로 로드하는 방법 [1]
11255정성태7/18/201723204디버깅 기술: 89. Win32 Debug CRT Heap Internals의 0xBAADF00D 표시 재현 [1]파일 다운로드3
11254정성태7/17/201719548개발 환경 구성: 322. "Visual Studio Emulator for Android" 에뮬레이터를 "Android Studio"와 함께 쓰는 방법
11253정성태7/17/201719880Math: 21. "Coding the Matrix" 문제 2.5.1 풀이 [1]파일 다운로드1
11252정성태7/13/201718437오류 유형: 411. RTVS 또는 PTVS 실행 시 Could not load type 'Microsoft.VisualStudio.InteractiveWindow.Shell.IVsInteractiveWindowFactory2'
11251정성태7/13/201717118디버깅 기술: 88. windbg 분석 - webengine4.dll의 MgdExplicitFlush에서 발생한 System.AccessViolationException의 crash 문제 (2)
11250정성태7/13/201720683디버깅 기술: 87. windbg 분석 - webengine4.dll의 MgdExplicitFlush에서 발생한 System.AccessViolationException의 crash 문제 [1]
11249정성태7/12/201718514오류 유형: 410. LoadLibrary("[...].dll") failed - The specified procedure could not be found.
... [106]  107  108  109  110  111  112  113  114  115  116  117  118  119  120  ...