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

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

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

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

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

Q&A

解決済

1回答

298閲覧

html内のvalue=""にphpコードを設置したい

accr

総合スコア1

PHP

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

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

0グッド

0クリップ

投稿2023/01/06 02:01

前提

MAMP・phpを使ったログイン・新規登録機能を作っています。

実現したいこと

csrf対策として新規登録時にワンタイムトークンを使用したい。

発生している問題

ソースコード内<input type="hidden" name="csrf_token" value="">のvalueに該当のphpコードを埋め込んだとき、それ以降のコードが読み込まれなくなってしまう問題。

該当のソースコード

PHP

1<?php 2require_once '../functions.php'; 3?> 4<!DOCTYPE html> 5<html lang="en"> 6<head> 7 <meta charset="UTF-8"> 8 <meta http-equiv="X-UA-Compatible" content="IE=edge"> 9 <meta name="viewport" content="width=device-width, initial-scale=1.0"> 10 <title>サインアップ</title> 11</head> 12<body> 13 <h2>登録フォーム</h2> 14 <form action="register.php" method="POST"> 15 <p> 16 <label for="username">Username:</label> 17 <input type="text" name="username"> 18 </p> 19 <p> 20 <label for="email">E-mail:</label> 21 <input type="email" name="email"> 22 </p> 23 <p> 24 <label for="password">Password:</label> 25 <input type="password" name="password"> 26 <p> 27 <label for="password_conf">Confirm Password:</label> 28 <input type="password" name="password_conf"> 29 </p> 30 <input type="hidden" name="csrf_token" value="<?php echo h(setToken()); ?>"> 31<!--ここから下のコードが読み込まれず、Registerボタンが表示されない--> 32 <p> 33 <input type="submit" value="Register"> 34 </p> 35 </form> 36</body> 37</html>

functions.phpのソースコード

PHP

1<?php 2/** 3 * XSS対策;エスケープ処理 4 * 5 * @param string $str 対象の文字列 6 * @return string 処理された文字列 7 */ 8function h($str) { 9 return htmlspecialchars($str, END_QOTES, 'UTF-8'); 10} 11 12/** 13 * CSRF対策 14 * @param void 15 * @return string $csrf_token 16 */ 17function setToken() { 18 //token生成 19 //formからtoken送信 20 //送信後のtoken照会 21 //token削除 22 session_start(); 23 $csrf_token = bin2hex(random_bytes(32)); 24 $_SESSION['csrf_token'] = $csrf_token; 25 26 return $csrf_token; 27} 28

分かっている情報

イメージ説明
chrome開発者ツールを使用して確認してみたところ、value"以降が読み込まれなくなってしまっているようです。

PHP初心者のため、何か回答に必要な情報が不足していましたらすぐに追加させて頂きます。
この場合どうすればRegisterボタンを表示させられるか、ご教授お願い致します。m(_ _ )m

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

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

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

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

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

guest

回答1

0

ベストアンサー

END_QOTESという定数が正しくありません。おそらく、ENT_QUOTESではないかと思われます。

投稿2023/01/06 02:04

maisumakun

総合スコア145184

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

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

accr

2023/01/06 02:08 編集

あ!! formのコードばかり確認していてそちらに全然気づきませんでした... かなり初歩的なミスでお恥ずかしい限りでございます。 迅速な回答、本当にありがとうございました!
otn

2023/01/06 03:52

HTML生データ(右クリック→「ページのソースを表示」)を見ていれば気づけたかと思います。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問