GeckoFX

提供: MonoBook
ナビゲーションに移動 検索に移動

GeckoFX(読み:げっこーえふえっくす)とは、.NET FrameworkおよびMonoからGeckoエンジンを扱うためのラッパークラスである。

大雑把にいうとC#Firefoxを操るためのライブラリと思ってほぼ間違いない。LinuxLinux Mint 12)上のMonoFirefoxの組み合わせでも問題なく動作している。

概要[編集 | ソースを編集]

.NET Frameworkには最初期からウェブブラウザを手軽に自作できる純正のWebBrowserクラスが用意されている。これはC#以前のDelphiVCLの時代から存在している。ただ互換性を維持するためか、一切改善されることなく常に腐っており、実用には程遠い代物でもある。

その代用としてGeckoFXは有望である。またGeckoFXは一般的なウェブブラウザのみならず、JavaScriptCSSCookieの制御できるためHTML5に依存したウェブサイトなどを対して高精度にウェブスクレイピングするなどの用途にも用いることができる。

ただしGeckoFXにも欠点があり、別途Firefox(に同梱されるXPCOM)のインストールが必須であるため、場合によっては配布方法などにおいて面倒なことになる。なおXPCOMは単体でも配布されており、こちらをアプリに同梱してしまう方法もある[1]

注意[編集 | ソースを編集]

2012年4月10日現在、Googleのウェブ検索において「geckofx」と検索すると、GeckoFX 1.xまで使われていた古いサイト[2]Googleコード)が上位表示され、現在の公式サイト[3]bitbucket)が上位表示されておらず、「古い情報しかない」「更新が止まってる」と誤認識してしまう恐れがあるので、他人に教えるときは注意すること。

利用方法[編集 | ソースを編集]

GeckoFXの利用には、別途Geckoエンジンコンポーネント化したXPCOMCross Platform Component Object Model)が必要であり、利用時にはXPCOMのインストールパスを設定する。

XPCOMはMozilla公式サイトから単体でダウンロード[4]してきてもいいし、Mozilla Firefoxにも同梱されているのでFirefoxのインストールディレクトリを指定しても動く。同梱する場合は単品の方が確実であると思われる。

バージョン番号[編集 | ソースを編集]

GeckoFX2.0までは独自のバージョン番号であったが、以降は最近はFirefoxのメジャーバージョン番号と同一になっているので、XPCOMとして用いる「Firefoxが10.x」ならば「GeckoFX10.x」を用いること。マイナーバージョンは気にしなくてよい。

また近年のFirefoxのラピッドリリースサイクルの導入に伴い、GeckoFXも平行して物凄い勢いでフォーク(バージョンアップ)しまくっている。FirefoxおよびGeckoFXの両方のインターフェイスなどもガンガン書き換えられているので、常に最新バージョンを用いればいいというものでもなく、基本的に開発開始時に用いたFirefoxとGeckoFXを拾ってくれば間違いない。

2012年6月26日現在まで使ってみた感じでは、Firefoxの自動アップデート後にGeckoFXを使ったアプリが壊滅したという事例があり、Firefox 10をベースとしたFirefox ESR版[5]を使う、またはFirefoxの自動アップデートを無効化して使うのが望ましいように思われる。

x64での動作について[編集 | ソースを編集]

Mozillaが配布しているGeckox86専用でありGeckoFXもx86専用となっている。

Windows Server 2008 R2x64)上で動いているASP.NET Web APIを使ったオレオレWeb API群に、URLを渡すとGeckoFXを用いてWebページスクリーンショットを撮るというプログラムを追加した際にこの点が問題となったので記載しておく。あまりに大雑把で強引な解決方法であり一般人にはオススメはしない。

  1. GeckoFXのソースコードダウンロードしてくる
  2. GeckoFXをターゲット「Any CPU」または「x64」に変更しビルドする
    • 面倒なので秀丸slnファイルcsprojファイルを開いて「x86」という文字列を「AnyCPU」に一括置換である。これでも一応動いたがオススメはしない。ちゃんと1個1個設定しよう。
    • この状態でx86版のFirefoxを指定して動かすとDllImportで落ちる。
  3. Waterfox(Firefoxの非公式x64バージョン)をダウンロード[6]インストールする
  4. Xpcom.Initializeメソッドの引数にWaterfoxのインストールディレクトリを指定する
    • 毎回フルパス指定は面倒なので以下のようにして「ProgramFile/Waterfox」を探させるようにした。これまたオススメしない。
      • Geckofx-Coreプロジェクトの
      • XULRunnerLocatorクラスの
      • GetXULRunnerLocationWindowsメソッドの
      • folderSearch変数(string配列)に「Waterfox」という文字列を追加する

使用例[編集 | ソースを編集]

関連項目[編集 | ソースを編集]

参考文献[編集 | ソースを編集]

外部リンク[編集 | ソースを編集]

Firefox
GeckoFX