前提・実現したいこと
レンタルサーバーで動かしたいがエラーが出てしまう。
ローカル環境では正常に動作します。
発生している問題・エラーメッセージ
Warning: Cannot modify header information - headers already sent by
該当のソースコード
PHP
1<?php 2require('dbconnect.php'); 3require('hour.php'); 4//URLパラメータを指定せずにアクセスしようとした場合はheader('Location: index.php'); 5if(empty($_REQUEST['id'])){ 6 header('Location: index.php'); 7 exit(); 8} 9 10//記事 11$posts = $db->prepare('SELECT * FROM article WHERE id=?'); 12$posts->execute(array( 13 $_REQUEST['id'] 14)); 15$post = $posts->fetch(); 16 17//コメントが入力されているかどうか 18if(!empty($_POST)){ 19 //エラー判定 20 if($_POST['name'] === ''){ 21 $errer['name']='blank'; 22 } 23 if($_POST['comment'] === ''){ 24 $errer['comment']='blank'; 25 } 26} 27//コメント 28$comments = $db->prepare('SELECT * FROM comments WHERE article_id=? ORDER BY created DESC'); 29$comments->execute(array( 30 $_REQUEST['id'] 31)); 32$comments->execute(); 33 34//コメント投稿 35//if 投稿するボタンが押されたとき 36if(!empty($_POST)){ 37 $URL = 'view.php?id='.$_REQUEST['id']; 38 //下のテキストエリアがname="comment"のため($_POST['comment']である 39 if($_POST['comment'] !== '' && $_POST['name'] !== ''){ 40 $message = $db->prepare('INSERT INTO comments SET name=?, comment=?, article_id=?, created=NOW()'); 41 $message->execute(array( 42 $_POST['name'], 43 $_POST['comment'], 44 $_REQUEST['id'] 45 )); 46 header('Location:'.$URL); 47 //リロードされて同じメッセージが誤送信されることを防ぐ 48 exit(); 49 } 50 } 51//<p>その投稿は削除されたか、URLが間違えています。</p>かどうかのフラグ 52//記事が存在するときは0 53 $noArticle = 0; 54//createdを整形する 55$date = date('Y/m/d', strtotime($post['created'])); 56?> 57
試したこと
PHP.iniにmbstring.output_bufferingがなかったため、
ini_set('mbstring.output_buffering', 'On');
をしてみたがエラーは変化しませんでした。
https://kotori-blog.com/php/cmhi_error/
こちらのブログを参考にしました。
補足情報(FW/ツールのバージョンなど)
レンタルサーバーはXfreeです。