エラーの再現ができなくなりましたが、原因が不明なままのため、回答を受け付けています。
ローカル環境でPHPの学習をしています。
PHPの環境はこちらを参考にdockerを使用して構築しました。
ドキュメントルート(/var/www/html)の中に練習用のファイル「form.php」を作成したところ、ブラウザ(localhost:8080/form.php)で以下のようなエラーが表示されます。
Not Found The requested URL was not found on this server. Apache/2.4.53 (Debian) Server at localhost Port 8080
試しに「form_1.php」というファイル名に変更したところ、エラーが消え、正常に表示されたのですが、なぜ「form.php」というファイル名だとエラーが発生するのでしょうか。
■調べたこと
・Googleで以下ワードで検索
「+"form.php"」
「php ファイル名 使ってはいけない」
「php docker form.php」
「form.php notfound エラー」
・ターミナル上でファイルの状態を確認
shell
1# ファイルの属性を確認 2root@70f949dfba74:/var/www/html# ls -l 3ls: cannot access 'form.php': No such file or directory 4total 8 5-????????? ? ? ? ? ? form.php 6-rw-r--r-- 1 root root 884 May 25 03:45 fundamental.php 7-rw-r--r-- 1 www-data www-data 40 May 25 03:46 index.php 8 9# form.phpは存在するのに"cannot access"となる 10 11# ファイル名の変更もできない 12root@70f949dfba74:/var/www/html# mv form.php form_1.php 13mv: cannot stat 'form.php': No such file or directory 14 15# catを使うこともできない 16root@70f949dfba74:/var/www/html# cat form.php 17cat: form.php: No such file or directory 18 19# lsでは表示される 20root@70f949dfba74:/var/www/html# ls 21form.php fundamental.php index.php 22 23###### 24Finder上でファイル名を「form_1.php」に変更 25###### 26 27 28root@70f949dfba74:/var/www/html# ls -l 29total 12 30-rw-r--r-- 1 www-data www-data 586 May 25 04:06 form_1.php 31-rw-r--r-- 1 root root 884 May 25 03:45 fundamental.php 32-rw-r--r-- 1 www-data www-data 40 May 25 03:46 index.php 33 34# 名前を変更すると、属性がちゃんと表示された。 35# ブラウザ上でのエラーも消えた。
■追記
日をまたいで再度「form_1.php」を「form.php」にしたところ、問題なく表示されました。
原因はわかりませんが、この間ブラウザやVScodeを一度終了しています。
ご回答いただいた皆様、エラー時に試せず申し訳ございません。
原因に当たりがつけられる方がいらっしゃいましたらご回答いただけると幸いです。
form.html
abc.html
abc.php
も試してみてください。
私が知ってる範囲だと何の問題もないファイル名、URLです。
lsの結果を見る限り、ファイルが破損していたのではないかと推測できますが、原因は不明ですね。
touch form.php
でファイルを作っても同じ結果になるのでしょうか?
現状エラーを再現できませんが、問題なく再現できました。
form.php を置く前にurlを入力して表示されたエラーがキャッシュされているだけだったりして。
ブラウザで開発者ツールを表示させた状態で更新ボタン長押し -> キャッシュの消去とハードの再読み込み を行っていたのでこちらが原因ではなさそうです。