シンプルに設置できる数字Captcha「MathCaptcha」
スパム防止などで利用されているCaptchaですが、数字版で使えるものがないか探してみました。
この「MathCapthca」は非常にシンプルに設置できるのはいいですが、やっぱりクエスチョンの部分は画像のほうがいいですよね。私は別のを(探して)導入しようと思いますが、参考まで。ダウンロードから。
設置
コンポーネントディレクトリに配置して下さい。
app/controller/component/math_captcha.php
Controller
var $components = array('MathCaptcha'); // captcha表示 function mathcaptcha(){ $this->set( 'mathCaptcha', $this->MathCaptcha->generateEquation()); } // captchaチェック function mathcaptchatest(){ if ($this->RequestHandler->isPost()) { if ($this->MathCaptcha->validates( $this->data['Captcha']['security_code'])) { $this->set( 'result', 'OK'); } else { $this->set( 'result', 'NG'); } } }
View
echo $form->create( 'Captcha', array( 'url' => '/mathcaptchatest')); echo $form->input( 'security_code', array( 'label' => 'Please Enter the Sum of ' . $mathCaptcha)); echo $form->end(array( 'name' => 'Send', 'class' => 'input_btn'));
オプション
コンポーネントの設定の際にオプションを設定できます。
var $components = array( 'MathCaptcha' => array( // MathCaptcha 'operand' => '+', // 計算オペランド('+', '-', '*', '/') 'minNumber' => 1, // 最小数 'maxNumber' => 5, // 最大数 'numberOfVariables' => 2 // 変数の数 ) );
関連記事
-
-
Jsヘルパーを使用してAjax更新
更新処理でページ遷移を伴う場合、ページ全体をレスポンスするのに対して、Ajax処理ではページの一部のレスポンスが可能となるためサーバからの通信量を抑えることが可能となります。 Jsヘルパーを使用して
-
-
メール送信(qdmail)
CakePHP(+qdmail)でメール送信する処理を実装しました。 準備 2つのライブラリ(.php)をダウンロードし、以下のように配置して下さい。 app/controllers/compo
-
-
独自のバリデーションルール
CakePHPで組み込みバリデーションをつくる方法は色々あります。 参考:Data Validation — CakePHP Cookbook v1.3 documentation 上記リンク内に
-
-
Secutiryユーティリティ
CakePHPでは、データのハッシュ化もしくは暗号化のためのメソッドSecurityユーティリティが用意されています。 ソース: /cake/libs/security.php Security:
-
-
複数ファイルアップロード
CakePHPで複数ファイルのアップロードについて調べてみました。といっても普通のPHPのコードと同じではありますが、postするフィールド名に[]を付与して配列にします。 view
-
-
フィールド単位でバリデーション無効化
save処理の際に条件付でモデルのバリデーションをフィールド単位でスキップする処理のメモです。(最終的に使うことはなかったのでメモ) 関数は unset( $this->->validate[
-
-
CakePHP 1.3 インストール
使い古されている手ではありますが、表題の件とレンタルサーバへの配置方法などにも使えますので参考にしていただけたらと思います。 まずはレンタルサーバでCakePHPを動作させる CakePHPア
-
-
Textヘルパー
Textヘルパーには、テキスト処理に関する便利な機能があります。リンク付与やテキストの抜粋・ハイライトや切り取り処理など。ソース:/cake/libs/view/helpers/text.php
-
-
validateErrors と validationErrors
CakePHP試験中に気付いたことがあって、メモです。 $this->validateErrors自身バリデーション処理している 今まで、save時にバリデーションエラーメッセージををログに出力し
-
-
ログインに追加の条件を付与する「userScope」
「ユーザ登録」の続きです。 ユーザ登録後、activate(statusを0に設定するを)せずに「仮登録」のままで、正しいusernameとpasswordでログインを試したところ認証に引っかかって
- PREV
- 体(験)で覚える 1
- NEXT
- ユーザ登録(仮登録・メール・本登録)