お世話になります。
現在CakePHP3で動かしているサイトの問合せフォームにスパムが多く届くため、Google reCAPTCHA v3の導入を検討しています。
通常の静的サイトと同様にコードを入れてみましたが、問い合わせ送信を行うと「Error
The request has been black-holed」と表示されました。
(静的ページ設置の際に参考にしたサイト様: https://www.ii-sys.jp/notes/1108 )
記載したのは以下の通りです。
・Template(送信ボタン前にhidden追加、form->end後にscript追加)
<input type="hidden" name="recaptchaResponse" id="recaptchaResponse" /> <?= $this->Form->button('送信する', ['escape' => false]); ?>
<?= $this->Form->end(); ?> <script type="text/javascript" src="/js/contactvalidation.js"></script> <script src="https://www.google.com/recaptcha/api.js?render=(site_key)"></script> <script> grecaptcha.ready(function() { grecaptcha.execute('(site_key)', {action: 'homepage'}).then(function(token) { var recaptchaResponse = document.getElementById('recaptchaResponse'); recaptchaResponse.value = token; }); }); </script>
・ContactForm.php(reCAPTCHAのスコア分岐を設置し、0.7以上の時のみ送信処理を行うよう変更)
protected function _execute(array $data) { if (isset($_POST['recaptchaResponse']) && !empty($_POST['recaptchaResponse'])) { $secret = '(sec_key)'; $verifyResponse = file_get_contents('https://www.google.com/recaptcha/api/siteverify?secret='.$secret.'&response='.$_POST['recaptchaResponse']); $reCAPTCHA = json_decode($verifyResponse); if ($reCAPTCHA->score >= 0.7) { // メールを送信する $email = new Email('default'); if(isset($data['articlename'])){ $valueArray = [ 'name' => $data['name'], 'email' => $data['email'], 'tel' => $data['tel'], 'elements' => $data['body'], 'id' => $data['id'] ]; }else{ $valueArray = [ 'name' => $data['name'], 'email' => $data['email'], 'tel' => $data['tel'], 'elements' => $data['body'] ]; } $email->setFrom(['web-master@example.com' => 'お問合せフォーム']) ->setEmailFormat('text') ->setTemplate('email') ->setTo($data['email']) ->setSubject('お問い合わせありがとうございました。') ->setViewVars($valueArray) ->send(); return true; } else { return; } } }
設置後、問合せフォームを確認するとreCAPTCHAの安全マークはついていましたが送信するとエラーが出る状態です。
原因や、cakePHPでのreCAPTCHAの設置の仕方等調べてみましたが見つけきれませんでした(そもそもgoogle reCAPTCHAをcakePHPで使う事が間違いなのでしょうか…?)
お手数ですが、何か原因等ございましたらお教えいただけましたら幸いです。
よろしくお願いいたします。
あなたの回答
tips
プレビュー