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

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

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

ファイルとは、文字列に基づいた名前又はパスからアクセスすることができる、任意の情報のブロック又は情報を格納するためのリソースです。

PHP

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

ループ

ループとは、プログラミングにおいて、条件に合致している間、複数回繰り返し実行される箇所や、その制御構造を指します

関数

関数(ファンクション・メソッド・サブルーチンとも呼ばれる)は、はプログラムのコードの一部であり、ある特定のタスクを処理するように設計されたものです。

コードレビュー

コードレビューは、ソフトウェア開発の一工程で、 ソースコードの検査を行い、開発工程で見過ごされた誤りを検出する事で、 ソフトウェア品質を高めるためのものです。

Q&A

1回答

640閲覧

【PHP】掲示板に指定した行だけ削除できる機能をつけたい

aki9062

総合スコア0

ファイル

ファイルとは、文字列に基づいた名前又はパスからアクセスすることができる、任意の情報のブロック又は情報を格納するためのリソースです。

PHP

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

ループ

ループとは、プログラミングにおいて、条件に合致している間、複数回繰り返し実行される箇所や、その制御構造を指します

関数

関数(ファンクション・メソッド・サブルーチンとも呼ばれる)は、はプログラムのコードの一部であり、ある特定のタスクを処理するように設計されたものです。

コードレビュー

コードレビューは、ソフトウェア開発の一工程で、 ソースコードの検査を行い、開発工程で見過ごされた誤りを検出する事で、 ソフトウェア品質を高めるためのものです。

0グッド

0クリップ

投稿2023/02/18 12:14

実現したいこと

ここに実現したいことを箇条書きで書いてください。

  • phpで簡易掲示板に「削除機能」を付加し、指定された番号の投稿だけ削除できるようにしたい

前提・実現したいこと

PHPで簡易掲示板を作っています。
投稿に通し番号をつけて表示できる掲示板に「削除機能」を付加し、指定された番号の投稿だけブラウザとテキストファイルから削除できるようにしたいです。
しかし、削除ボタンを押しても削除されずエラーメッセージが表示されてしまいます。

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

Warning: fwrite(): supplied resource is not a valid stream resource in /public_html/pre1.php on line 66 Warning: fclose(): supplied resource is not a valid stream resource in /public_html/pre1.php on line 67

該当のソースコード

PHP

1<!DOCTYPE html> 2<html lang="ja"> 3<head> 4 <meta charset="UTF-8"> 5 <title>pre1</title> 6</head> 7<body> 8 9 <form action="" method="post"> 10 <!--名前とコメントの入力フォーム--> 11 <input type="text" name="name" placeholder="名前"> 12 <input type="text" name="coment" placeholder="コメント"> 13 <input type="submit" name="submit"> 14 <!--削除対象番号のの入力フォーム--> 15 <input type="number" name="number" placeholder="削除対象番号"> 16 <input type="submit" name="delete" value="削除"> 17 </form> 18 19 <?php 20 error_reporting(E_ALL & ~E_NOTICE); 21 /*送信されたものを変数に代入*/ 22 $name = $_POST["name"]; 23 $coment = $_POST["coment"]; 24 $date = date("Y/m/d/H:i:s"); 25 $number = $_POST["number"]; 26 /*名前・コメント・日付をひとつの変数にまとめる*/ 27 $date1 = $name."<>".$coment."<>".$date; 28 29 /*テキストファイルに通し番号をつけた投稿を書き込む*/ 30 if(!empty($name) && !empty($coment)) { 31 $filename = "pre1.txt"; 32 $fp = fopen($filename,"r+"); 33 $count = 1; 34 while(fgets($fp) != false) { 35 $count ++; 36 } 37 fwrite($fp, $count."<>".$date1.PHP_EOL); 38 fclose($fp); 39 40 /*ブラウザに通し番号をつけた投稿を表示する*/ 41 if(file_exists($filename)){ 42 $lines = file($filename,FILE_IGNORE_NEW_LINES); 43 foreach($lines as $line){ 44 $rows = explode("<>",$line); 45 foreach($rows as $row){ 46 echo $row." " ; 47 } 48 echo "<br>"; 49 } 50 } 51 } 52 53 54 /* 削除操作*/ 55 if(!empty($number)) { 56 /*ファイルを読み込む*/ 57 $filename = "pre1.txt"; 58 $fp = fopen($filename,"r+"); 59 $lines = file($filename,FILE_IGNORE_NEW_LINES); 60 /*テキストファイルの中身を一行ずつ走査*/ 61 foreach($lines as $line){ 62 /*行を"<>"で区切り文字列ごとに分ける*/ 63 $rows = explode("<>",$line); 64 /*削除番号と行番号が一致しない場合はその行をテキストファイルに書き込む*/ 65 if($number != $count) { 66 fwrite($fp, $count."<>".$date1.PHP_EOL); 67 fclose($fp); 68 } 69 70 } 71 72 /*指定された行だけ削除されたテキストをブラウザに表示する*/ 73 if(file_exists($filename)){ 74 $lines = file($filename,FILE_IGNORE_NEW_LINES); 75 foreach($lines as $line){ 76 $rows = explode("<>",$line); 77 foreach($rows as $row){ 78 echo $row." " ; 79 } 80 echo "<br>"; 81 } 82 } 83 } 84 ?> 85</body> 86</html>

試したこと

ここに問題に対して試したことを記載してください。

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

ここにより詳細な情報を記載してください。

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

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

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

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

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

guest

回答1

0

2つ以上の投稿がある際に、61行目の foreach が2回以上ループします。
1回目のループの際に67行目の fclose でファイルが閉じられるため、2回目のループで66行目の fwrite が実行できません。

なので、ファイルを閉じる処理をループの外側に書いてあげると良いと思います。

投稿2023/02/27 14:05

chiroruxx

総合スコア25

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問