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

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

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

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

Q&A

解決済

1回答

20465閲覧

move_uploaded_fileの結果がfalseになってしまう理由

退会済みユーザー

退会済みユーザー

総合スコア0

PHP

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

1グッド

2クリップ

投稿2017/11/16 06:33

<test.php>

<body> <form enctype="multipart/form-data" action="#" method="post"> ファイル:<input type="file" name="myfile"/><br/> <input type="submit" value="送信"/> </form> <?php var_dump($_FILES["myfile"]["tmp_name"]); echo "<br>"; $filename = "upload_" .$_FILES["myfile"]["name"]; var_dump($filename); echo "<br>"; $test = move_uploaded_file($_FILES["myfile"]["tmp_name"], $filename); var_dump($test); ?> </body>

string(14) "/tmp/phpAns6lN"
string(15) "upload_test.php"
bool(false)
なってしまうのですがなぜvar_dump($test);がfalseとなってしまうのかがわかりません。
教えていただけないでしょうか?よろしくお願いいたします。

Unagiwani👍を押しています

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

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

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

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

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

guest

回答1

0

ベストアンサー

Apacheで動作させているなら
/var/log/error_log
にエラー内容出てませんでしょうか。

移動させる先に適切な権限設定されてなければfalseになるようです。

投稿2017/11/16 06:39

rururu3

総合スコア5545

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

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

退会済みユーザー

退会済みユーザー

2017/11/16 07:37

error_logがその場所にないためerror_logの場所の確認中です
rururu3

2017/11/16 07:39

すいません、パス間違えてました apacheだとデフォルト /var/log/httpd/error_log または /var/log/apache2/error.log です
退会済みユーザー

退会済みユーザー

2017/11/16 07:46 編集

/var/log/httpd/error_logにありました。ありがとうございます。 エラーは「move_uploaded_file(): Unable to move '/tmp/php8BV3am' to 'upload_test.php' in /vagrant/~/test.php on line 22, referer: http://192.168.33.10/test.php」 となっていました。 ただ具体的にエラーが起きている理由が書いていないため原因がわかりません。 どうすれば良いのでしょうか?
rururu3

2017/11/16 07:58

其のログのもうちょっと上の方にPermission denied in とか出てる想定してたのですが、出ておりませんか?
rururu3

2017/11/16 08:03

あと、SELinux有効だとそこら辺の権限設定も必要かも(Offにして試すのが手っ取り早いですが)
退会済みユーザー

退会済みユーザー

2017/11/16 08:05

すいませんありました。二行で1セットだったんですね。 move_uploaded_file(upload_test.php): failed to open stream: Permission denied in /vagrant/~/test.php on line 22, referer: http://192.168.33.10/test.php となっていました。
rururu3

2017/11/16 08:10

となるとファイルを移動しようとしてるところの権限周りを設定してください(権限設定などはそのエラーでググれば出て来ます&teratailで同様の質問してるのもありますし https://teratail.com/questions/200
退会済みユーザー

退会済みユーザー

2017/11/16 08:26 編集

ファイルに対する書き込み権限を付与しただけだとできなかったのですが、リンクに記載をされているようにディレクトリに「読み込み・書き込み・実行」の3つの権限を付与してみたらtrueに変わり無事upload_test.phpが作成できました。 本当にありがとうございます!助かりました!感謝しています!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問