2011-10-28 3 views
0

인터넷에서 발견 된 샘플을 기반으로 샘플 IE 추가 기능을 작성했습니다. 이 addon은 로그 파일을 만들고 OnDocumentComplete 및 OnBeforeNavigate2 이벤트에서 정보를 씁니다. 불행하게도이 기능이 작동하지 않습니다. 나는 IE에서이 Addon을 성공적으로 설치했고 눈에 띄었다 - 그러나 내가 말한 것처럼, 그것은 작동하지 않는다 (정보는 로그 파일에 기록되지 않는다).내 Internet Explorer 추가 기능이 작동하지 않습니다.

using System; 
using System.Collections.Generic; 
using System.Text; 
using SHDocVw; 
using mshtml; 
using System.IO; 
using Microsoft.Win32; 
using System.Runtime.InteropServices; 
using System.Security.AccessControl; 

namespace BHO_SampleApp 
{ 

    [ComVisible(true), 
    Guid("8a194578-81ea-4850-9911-13ba2d71efbd"), 
    ClassInterface(ClassInterfaceType.None) 
    ] 
    public class BHO:IObjectWithSite 
    { 
     WebBrowser webBrowser; 
     public void OnDocumentComplete(object pDisp, ref object URL) 
     { 
      using (StreamWriter sw = new StreamWriter(@"C:\log.txt")) 
      { 
       sw.WriteLine(String.Format("site: {0}, {1}", URL, DateTime.Now.ToString("dd-MM-yyyy HH:mm:ss"))); 
      } 
     } 

     public void OnBeforeNavigate2(object pDisp, ref object URL, ref object Flags, ref object TargetFrameName, ref object PostData, ref object Headers, ref bool Cancel) 
     { 
      using (StreamWriter sw = new StreamWriter(@"C:\log.txt")) 
      { 
       sw.WriteLine(String.Format("site: {0}, {1}", URL, DateTime.Now.ToString("dd-MM-yyyy HH:mm:ss"))); 
      }   
     } 

     #region BHO Internal Functions 
     public static string BHOKEYNAME = "Software\\Microsoft\\Windows\\CurrentVersion\\Explorer\\Browser Helper Objects"; 

     [ComRegisterFunction] 
     public static void RegisterBHO(Type type) 
     { 
      RegistryKey registryKey = Registry.LocalMachine.OpenSubKey(BHOKEYNAME, true); 

      if (registryKey == null) 
       registryKey = Registry.LocalMachine.CreateSubKey(BHOKEYNAME); 

      string guid = type.GUID.ToString("B"); 
      RegistryKey ourKey = registryKey.OpenSubKey(guid); 

      if (ourKey == null) 
       ourKey = registryKey.CreateSubKey(guid); 

      ourKey.SetValue("Alright", 1); 
      registryKey.Close(); 
      ourKey.Close(); 
     } 

     [ComUnregisterFunction] 
     public static void UnregisterBHO(Type type) 
     { 
      RegistryKey registryKey = Registry.LocalMachine.OpenSubKey(BHOKEYNAME, true); 
      string guid = type.GUID.ToString("B"); 

      if (registryKey != null) 
       registryKey.DeleteSubKey(guid, false); 
     } 

     public int SetSite(object site) 
     { 
      if (site != null) 
      { 
       webBrowser = (WebBrowser)site; 
       webBrowser.DocumentComplete += new DWebBrowserEvents2_DocumentCompleteEventHandler(this.OnDocumentComplete); 
       webBrowser.BeforeNavigate2+=new DWebBrowserEvents2_BeforeNavigate2EventHandler(this.OnBeforeNavigate2); 
      } 
      else 
      { 
       webBrowser.DocumentComplete -= new DWebBrowserEvents2_DocumentCompleteEventHandler(this.OnDocumentComplete); 
       webBrowser.BeforeNavigate2 -= new DWebBrowserEvents2_BeforeNavigate2EventHandler(this.OnBeforeNavigate2); 
       webBrowser = null; 
      } 
      return 0; 
     } 

     public int GetSite(ref Guid guid, out IntPtr ppvSite) 
     { 
      IntPtr punk = Marshal.GetIUnknownForObject(webBrowser); 
      int hr = Marshal.QueryInterface(punk, ref guid, out ppvSite); 
      Marshal.Release(punk); 

      return hr; 
     } 
     #endregion 
    } 

    [ 
    ComVisible(true), 
    InterfaceType(ComInterfaceType.InterfaceIsIUnknown), 
    Guid("FC4801A3-2BA9-11CF-A229-00AA003D7352") 
    ] 
    public interface IObjectWithSite 
    { 
     [PreserveSig] 
     int SetSite([MarshalAs(UnmanagedType.IUnknown)]object site); 
     [PreserveSig] 
     int GetSite(ref Guid guid, out IntPtr ppvSite); 
    } 
} 

이 부가 기능 잘못된 것입니다 : 여기

그리고이 부가 기능의 코드?

+0

코드에 큰 문제가 있습니다. 디버깅을 위해 무엇을 했습니까? 로깅 구문이 성공적인지, try try 구문이 보이지 않아 단순히 오류가 발생했을 가능성이 높습니다. 이 방법으로 레지스트리에 글을 쓰지 마십시오. –

+2

그냥 읽으십시오 - http://stackoverflow.com/questions/352217/how-do-i-create-a-ie-add-on-in-net –

답변

0

브라우저가 보호 모드 (기본값) 인 경우 추가 기능에 c : \ log.txt에 쓸 수있는 권한이 없습니다. 보호 모드가 작동하기 시작했는지 확인하려면 보호 모드를 비활성화하십시오.

관련 문제