🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
PHP

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

MAMP

Mac 上で WordPress などの動的ページのサイトが作れるように環境を構築するフリーソフト

Q&A

解決済

1回答

2147閲覧

PHPのheader関数でリダイレクトできません。

kikimt

総合スコア1

PHP

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

MAMP

Mac 上で WordPress などの動的ページのサイトが作れるように環境を構築するフリーソフト

0グッド

1クリップ

投稿2021/02/14 12:38

前提・実現したいこと

現在、入力された会員情報の確認ページで送信ボタンを押した時に会員情報がデータベースに挿入されてページが遷移する機能を実装しています。
ですが遷移先URIに使用しているheader関数でsyntaxエラーが発生しています。
もしよろしければ解決策をご教授いただければと思います。
■■な機能を実装中に以下のエラーメッセージが発生しました。

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

syntax error, unexpected 'header' (T_STRING)

該当のソースコード

php

1<?php 2session_start(); 3require('../dbconnect.php'); 4 5if (!isset($_SESSION['join'])) { 6 header('Location: index.php'); 7 exit(); 8} 9// 会員情報をdbに送信してtrueであれば保存する 10if (!empty($_POST)) { 11 $statement = $db->prepare('INSERT INTO member SET name=?, email=?, password=?, 12 picture=?, created=NOW()'); 13 echo $statement->execute(array( 14 $_SESSION['join']['name'], 15 $_SESSION['join']['email'], 16 sha1($_SESSION['join']['password']), 17 $_SESSION['join']['image'] 18 )); 19 unset($_SESSION['join']); //重複してデータが保存される可能性があるので。unsetで会員情報を削除する。 20 21 header('Location: thanks.php'); 22 exit(); 23} 24?> 25 26<!DOCTYPE html> 27<html lang="ja"> 28<head> 29 <meta charset="UTF-8"> 30 <meta name="viewport" content="width=device-width, initial-scale=1.0"> 31 <meta http-equiv="X-UA-Compatible" content="ie=edge"> 32 <title>会員登録</title> 33 34 <link rel="stylesheet" href="../style.css" /> 35</head> 36<body> 37<div id="wrap"> 38<div id="head"> 39<h1>会員登録</h1> 40</div> 41 42<div id="content"> 43<p>記入した内容を確認して、「登録する」ボタンをクリックしてください</p> 44<form action="" method="post"> 45 <input type="hidden" name="action" value="submit" /> 46 <dl> 47 <dt>ニックネーム</dt> 48 <dd> 49 <?php print(htmlspecialchars($_SESSION['join']['name'], 50 ENT_QUOTES)); ?> 51 </dd> 52 <dt>メールアドレス</dt> 53 <dd> 54 <?php print(htmlspecialchars($_SESSION['join']['email'], 55 ENT_QUOTES)); ?> 56 </dd> 57 <dt>パスワード</dt> 58 <dd> 59 【表示されません】 60 </dd> 61 <dt>写真など</dt> 62 <dd> 63 <!-- $_SESSIONに保存された画像ファイルがからでなければ、imgタグで画像を出力する。 --> 64 <?php if ($_SESSION['join']['image'] !== ''): ?> 65 <img src="../member_picture/<?php print(htmlspecialchars 66 ($_SESSION['join']['image'], ENT_QUOTES)); ?>"> 67 <?php endif; ?> 68 </dd> 69 </dl> 70 <div><a href="index.php?action=rewrite">&laquo;&nbsp;書き直す</a> | <input type="submit" value="登録する" /></div> 71</form> 72</div> 73 74</div> 75</body> 76</html> 77

php

1<?php 2try { 3 $db = new PDO('mysql:dbname=mini_bbs:localhost;port=8889;charset=utf8', 4 'root', 'root'); 5} catch(PDOException $e) { 6 print('DB接続エラー:' . $e->getMessage()); 7} 8?>

試したこと

ファイルを保存する時にBOM有りの設定になっている可能性を考えて
.editorconfigを作って

root = true [*.{php}] charset = utf-8

としてみましたが変わらずです。

補足情報(FW/ツールのバージョンなど)

PHP 7.3.11
MAMP
VScode
Mysql

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

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

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

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

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

guest

回答1

0

ベストアンサー

下記のコメントの前に全角空白があるのが原因のようです

PHP

1 //重複してデータが保存される可能性があるので。unsetで会員情報を削除する。

投稿2021/02/14 12:45

ockeghem

総合スコア11705

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

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

kikimt

2021/02/24 13:16

返信が遅れて申し訳ありません。 ご指摘の通りで全角空白があることが原因でした。 修正したところ、ちゃんと動きました! ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問