シンプルに設置できる数字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    // 変数の数
    )
);

CakePHP 2.x版

  • このエントリーをはてなブックマークに追加

関連記事

no image

Debugkitをインストール

CakePHPのデバッグツールとしてはデファクトスタンダードといってもいいDebugkitをインストールしました。 ダウンロード CakePHP 1.3用 https://github.com

Cookieログイン

今回は、「keep me logged in」などログイン画面でよくみかけるクッキーログインの機能を使ってみます。 CakePHPには、Cookieコンポーネントがあります。(PHPのsetcook

Textヘルパー

Textヘルパーには、テキスト処理に関する便利な機能があります。リンク付与やテキストの抜粋・ハイライトや切り取り処理など。ソース:/cake/libs/view/helpers/text.php

メール送信(qdmail)

CakePHP(+qdmail)でメール送信する処理を実装しました。 準備 2つのライブラリ(.php)をダウンロードし、以下のように配置して下さい。 app/controllers/compo

no image

ログローテーション

CakePHP1.3では標準ではログはタイプごとに出力されるだけで、定期的なローテーションを行ってくれません。放っておくとひたすら1つのファイルにアペンドされていきます。app/tmp/logs以下に

CakePHP 1.3 インストール

使い古されている手ではありますが、表題の件とレンタルサーバへの配置方法などにも使えますので参考にしていただけたらと思います。 まずはレンタルサーバでCakePHPを動作させる CakePHPア

no image

Secutiryユーティリティ

CakePHPでは、データのハッシュ化もしくは暗号化のためのメソッドSecurityユーティリティが用意されています。 ソース: /cake/libs/security.php Security:

フィールド単位でバリデーション無効化

save処理の際に条件付でモデルのバリデーションをフィールド単位でスキップする処理のメモです。(最終的に使うことはなかったのでメモ) 関数は unset( $this->->validate[

複数データベースの追加と切替

CakePHPで複数のデータベースに切替を行うということがあると思います。(個人的にはあまりない) 今回、CakePHPからWordpressのデータベースへの接続を行う機会があったので設定を試して

ログインに追加の条件を付与する「userScope」

「ユーザ登録」の続きです。 ユーザ登録後、activate(statusを0に設定するを)せずに「仮登録」のままで、正しいusernameとpasswordでログインを試したところ認証に引っかかって

Message

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です

*

PAGE TOP ↑