質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.46%
PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

2回答

816閲覧

クロスサイトリクエストフォージェリ対策、トークンの発行で未定義の変数エラー

pompompompi

総合スコア0

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

0クリップ

投稿2021/02/07 13:29

お問い合わせフォームのクロスサイトリクエストフォージェリ対策、トークンの発行で未定義の変数エラー

「PHP入門 確認画面付きのお問い合わせフォームをつくりながらPHPを学ぶ(第2版)」で学んでいる初学者です。
クロスサイトリクエストフォージェリ対策で、ワンタイムチケットの発行をする必要があるとのことで
お問い合わせ確認画面に下記コードを実装しました。

変数は$tokenで定義しているかと思うのですが、エラーの解消法がわからずつまってしまいました。
大変初歩的な問題ですが、ご教授くださいますと幸いです。

発生している問題・エラーメッセージ

お問い合わせフォームに入力、確認画面に進むと下記エラーメッセージが出ます。

Fatal error: Uncaught Error: Call to undefined function openssl_random_pseudo_bytes() ~

該当のソースコード

<?php session_start() ; if(isset($_SESSION['name'])) { $name = $_SESSION['name'] ; $email = $_SESSION['email'] ; $subject = $_SESSION['subject'] ; $body = $_SESSION['body'] ; } $_SESSION['token'] = base64_encode(openssl_random_pseudo_bytes(48)); $token = htmlspecialchars($_SESSION['token'], ENT_QUOTES); ?> <!DOCTYPE html> <html lang="ja"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>確認画面 | お問い合わせ</title> </head> <body> <form action ="thanks.php" method ="post"> <input type ="hidden" name ="token" value ="<?php echo $token ?>"> <table> <tr> <th>お名前</th> <td><?php echo $name; ?></td> </tr> <tr> <th>メールアドレス</th> <td><?php echo $email; ?></td> </tr> <tr> <th>お問い合わせの種類</th> <td><?php echo $subject; ?></td> </tr> <tr> <th>お問い合わせ内容</th> <td><?php echo nl2br($body) ; ?></td> </tr> <tr> <td colspan="2"> <input type="submit" name="submit" value="送信する"></td> </tr> </table> </form> <p><a href="form.php?action=edit">入力画面に戻る</a></p> </body> </html>

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

hentaiman

2021/02/07 13:44

環境構築手順にミスが無いか確認しましょう。 書籍通りにやっていて動作しないのなら訂正があるかもしれないので出版元サイトの訂正情報でも確認してみましょう。
guest

回答2

0

XAMPPをお使いなら、以下の記事が参考になると思います。

XAMPP for WindowsでSSLを有効にする

要点を書くなら、php.iniに下記の設定を有効にするということです。

extension=php_openssl.dll

以下のようにコメントアウトされている場合は、冒頭のセミコロンを削除してください。

;extension=php_openssl.dll ↓ セミコロンを削除する extension=php_openssl.dll

投稿2021/02/08 01:31

ockeghem

総合スコア11701

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

どういう環境でやっているかが書いてないので分かりませんが、その環境ではopenssl関係が使えないんじゃないですかね?

Windowsなら同じようなことで悩んでいた人が過去にもいたようですよ
https://teratail.com/questions/68304
ということで、質問するときは開発してる環境(OS、PHPのバージョンなど)をしっかり明記された方が良いと思います。

PHP7以降であれば代わりにrandom_bytesを使うとかにすればいいと思います。

投稿2021/02/07 16:16

AbeTakashi

総合スコア4594

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.46%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問