使用しているのは下記ブログポストで紹介されているライブラリ。
ASP.NET MVC CAPTCHA
※最新のソースコードは下記ブログポストらしいのだが、ダウンロードしたバイナリをMVC 3の環境に組み込んでも参照しているアセンブリバージョンの兼ね合いでコンパイルができないので、今回はMy Clip実装時の上記ブログポストのソースコードで実装方法を紹介する。
MVC CAPTCHA for Preview Release 3
- 上記のリンクからソースコードをダウンロードし、ManagedFusion.Web のプロジェクトをコンパイルする
- コンパイルしてできた ManagedFusion.dll と ManagedFusion.Web.dll を ASP.NET MVC 3 のプロジェクトで参照する
3, 下記を web.config に追加する
<httpHandlers> <add verb="GET" path="captcha.ashx" validate="false" type="ManagedFusion.Web.Mvc.Handlers.CaptchaImageHandler, ManagedFusion.Web"/> </httpHandlers>
4, 下記を Global.asax に追加する
public static void RegisterRoutes(RouteCollection routes)
{
routes.IgnoreRoute("{handler}.ashx");
}
5, cshtml に下記を追加する
<div>
@Html.Raw(Html.CaptchaImage(50, 180))
</div>
<div>
@Html.Raw(Html.CaptchaTextBox("captcha"))
</div>
Html.Raw で囲んでいるのは CaptchaImage, CaptchaTextBox ともに文字列を返却するようになっているため。ソースコードを書き換えて各関数ともに文字列ではなく MvcHtmlString を返却するようにすれば Raw で囲む必要はなくなる。6, コントローラーアクションに下記属性を追加する
[CaptchaValidation("captcha")]
[HttpPost]
public ActionResult Register(RegisterModel model, bool captchaValid)
{
// Do something
}
captchaValid にキャプチャでの検証結果が代入されている。以上で5でコードを追加した cshtml を表示するばキャプチャが表示されているはずだ。