2011-10-28 6 views
0

私はインターネット上のサンプルに基づいてサンプルIEのアドオンを書いています。このアドオンはログファイルを作成し、OnDocumentCompleteイベントとOnBeforeNavigate2イベントからの情報を書き込みます。 不運にも、これは機能しません。私は正常にIEでこのアドオンをインストールし、それは表示されます - しかし、私が言ったように、それは動作していません(情報はログファイルに書き込まれません)。私の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への書き込み権がありません。保護モードを無効にして、動作しているかどうかを確認してください。

関連する問題