誰かこのコードを確認するのを手伝ってくれませんか? 画像は正常にアップロードされましたが、画像が見つかりません。
<!DOCTYPE html><html> <head> <title>Test the input</title> </head> <body> <form action="upload.php" method="post" enctype="multipart/form-data"> <label for="picture">PICTURE:</label><br /> <input type="file" name="picture" id="picture"/><br/> <input type="submit" name="submit" value="submit"/> </form> </body></html>
<?php $photo_dir='/var/www/images/'; if(!is_dir($photo_dir)||is_writeable($photo_dir)){ die('No dir exist or can write'); } if($_FILES['picture']['error']>0){ echo 'Error:'.$_FILES['picture']['error'].'<br/>'; } else{ echo "Upload:".$_FILES['picture']['name'].'<br />'; echo "Type:".$_FILES['picture']['type'].'<br />'; echo "Size:".($_FILES['picture']['size']/1024).'kb<br/>'; echo "Stred in:".$_FILES['picture']['tmp_name'].'<br />'; if(file_exists('/var/www/images/'.$_FILES['picture']['name'])) { echo $_FILES['picture']['name'].'already exists'; } else { $gpy=move_uploaded_file($_FILES['picture']['tmp_name'],'/var/www/images/'.$_FILES['picture']['name']); if(gpy) { echo 'Succed'; } echo 'Stored in:'.'images/'.$_FILES['picture']['name']; } }?>
このコードは、実際にはアップロードが成功したことを示していますが、アップロードされたファイルが設定したファイル パスに見つかりません。
ディスカッションに返信 (解決策)
/var/www/images/ ここにアップロードした写真はありませんか?
ディレクトリ権限の問題、画像フォルダーに www-data への書き込み権限が与えられていますか?
確認してください。そのパスの下にアップロードされたファイルは本当にありませんか?
さらに、エラープロンプト機能をオンにして、アップロードプロセス中にエラーメッセージがあるかどうかを確認します。
アップロード後に表示されるコンテンツを投稿します
ディレクトリ権限の問題、画像フォルダーには www-data 書き込み権限が与えられていますか?
どのような権限を指しますか? /var/www/image を Web 上で読み書きできるように設定しました。これは正しいですか?
そのパスにアップロードされたファイルが実際にないかどうかを注意深く確認してください。
さらに、エラープロンプト機能をオンにして、アップロードプロセス中にエラーメッセージがあるかどうかを確認します。
いいえ、エラー プロンプト機能をオンにするにはどうすればよいですか? php を学んだばかりです
ディレクトリのアクセス許可に問題があります。画像フォルダーには www-data の書き込みアクセス許可が与えられていますか?
どのようなアクセス許可を指しますか? /var/www/image を Web 上で読み書きできるように設定しました。これは正しいですか?
あなたの画像ディレクトリには一般ユーザーの書き込み権限がありません
送信されたページのコンテンツを確認できます。「成功」という文字がないはずです
画像フォルダに www-data が与えられているかどうかに問題があります。書き込み権限?
聞きたいのですが、権限とは何ですか? /var/www/image を Web 上で読み書きできるように設定しました。これは正しいですか?
web は自分で作成したユーザーであり、Apache のユーザー名は www-data です
あなたの画像ディレクトリには一般ユーザーの書き込み権限がありません
送信後にページの内容を確認できます 単語があってはなりません。 「成功しました」
ファイルを送信すると表示されます このように、確かに成功です…
一般ユーザーでも書けますか?これを変更するにはどうすればよいですか?
ディレクトリ権限の問題。画像フォルダーには www-data 書き込み権限が与えられていますか?
どのような権限を指しますか? /var/www/image を Web 上で読み書きできるように設定しました。これは正しいですか?
web は自分で作成したユーザーで、Apache のユーザー名は www-data です
Apache ユーザーはそれを変更できますか? ubantu linux を使用して自分で環境を構築し、コードもローカルで実行されています
if(gpy)
明らかに間違っています。
if($gpy) であるはずです
つまり、あなたの判断は間違っており、if を入力するのが正常です。
php のすべてのプロンプトを開きます。画像には書き込み権限がないはずです。
if(gpy)
は明らかに間違っています。
if($gpy) であるはずです
つまり、あなたの判断は間違っており、if を入力するのが正常です。
php のすべてのプロンプトを開きます。画像には書き込み権限がないはずです。
権限を変更したので、ファイル パスでエラーが報告され始めていますか?ファイルパスはどのように書けばよいのでしょうか?
ディレクトリ権限の問題、画像フォルダーには www-data 書き込み権限が与えられていますか?
どのような権限を指しているのでしょうか? /var/www/image を Web 上で読み書きできるように設定しました。これは正しいですか?
Web は自分で作成したユーザーで、Apache のユーザー名は www-data です
Apache ユーザーは変更できますか? ubantu linux を使用して環境を自分で構築し、コードもローカルで実行されています
いいえ、なぜ変更する必要がありますか?画像ディレクトリに www-data 書き込み権限を追加するだけで十分ではないでしょうか?
さらに、コードをもう一度調べました:
if(!is_dir($photo_dir)||is_writeable($photo_dir))
これはおそらく論理エラーです。
if(!is_dir($photo_dir)|| !is_writeable($photo_dir)) であるはずです
さらに、コードをもう一度調べました:
if(!is_dir($photo_dir)||is_writeable($photo_dir))
これはおそらく論理エラーです。
if(!is_dir($photo_dir)|| !is_writeable($photo_dir)) であるはずです
あはは、あまりにもずさんですが、$_FILES['picture']['error をパスすることを期待して、以前の if 判定をすべて削除しました'] とエラー メッセージが表示されますが、まだ 0 です。これは、書き込みに問題がないことを意味します
ディレクトリ権限の問題、画像フォルダーには www-data 書き込み権限が与えられていますか?
どのような権限を指しているのでしょうか? /var/www/image を Web 上で読み書きできるように設定しました。これは正しいですか?
Web は自分で作成したユーザーで、Apache のユーザー名は www-data です
Apache ユーザーは変更できますか? ubantu linux を使用して環境を自分で構築し、コードもローカルで実行されています
いいえ、なぜ変更する必要がありますか?画像ディレクトリに www-data 書き込み権限を追加するだけで十分ではないでしょうか? 間違ったボタンをクリックすると、レンガが失われます。 。 。しかし、$_FILES['name']['error'] を使用すると、エラーが書き込みによって引き起こされたかどうかを確認できるはずですが、プロンプトはまだ 0 です。これは、何が起こっているのかを意味します。が掲載されています。
さらに、コードをもう一度調べました:
if(!is_dir($photo_dir)||is_writeable($photo_dir))
if(!is_dir($photo_dir)|| !is_writeable($photo_dir)) であるはずです
あはは、あまりにもずさんですが、$_FILES['picture']['error をパスすることを期待して、以前の if 判定をすべて削除しました'] とエラーメッセージが表示されますが、まだ 0 です。つまり、書き込み可能な問題はありません。
$_FILES['picture']['error'] は、アップロード時にエラーが発生することです。 、move_uploaded_file プロセスが失敗しました。
$photo_dir='images/';
if(!file_exists($photo_dir))
{
mkdir($photo_dir);
}
if($_FILES['picture']['error']>0){
echo 'Error:'.$_FILES['picture']['error'].'
';
}
else{
echo "アップロード:".$_FILES['写真']['名前'].'
';
echo "Type:".$_FILES['picture']['type'].'
';
echo "サイズ:".($_FILES['picture']['size']/1024).'kb
';
echo "文字列:".$_FILES['picture']['tmp_name'].'
';
echo "エラー:".$_FILES['picture']['error'].'
';
if(file_exists('/var/www/images/'.$_FILES['picture']['name']))
{
echo $_FILES['picture ']['名前'].'すでに存在します' ;
else
{
$gpy=move_uploaded_file($_FILES['picture' ]['tmp_name'],$photo_dir.$_FILES['picture']['name']);
if($gpy)
{
「成功しました」をエコーします。'
echo '保存場所:'.'/var/www/images/'.$_FILES['写真']['名前'];
echo '';
?>
エラーメッセージが掲載されます。
さらに、コードをもう一度調べました:
if(!is_dir($photo_dir)||is_writeable($photo_dir))
これはおそらく論理エラーです。
if(!is_dir($photo_dir)|| !is_writeable($photo_dir)) であるはずです
あはは、あまりにもずさんですが、$_FILES['picture']['error をパスすることを期待して、以前の if 判定をすべて削除しました'] とエラーメッセージが表示されますが、まだ 0 です。つまり、書き込み可能な問題はありません。
$_FILES['picture']['error'] は、アップロード時にエラーが発生することです。 、move_uploaded_file プロセスが失敗しました。
やっと分かりました、
if(!file_exists($photo_dir))
がないのは奇妙です以前にアップロードした新しい画像ファイルも突然表示されました。 。 。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









Laravelは、直感的なフラッシュメソッドを使用して、一時的なセッションデータの処理を簡素化します。これは、アプリケーション内に簡単なメッセージ、アラート、または通知を表示するのに最適です。 データは、デフォルトで次の要求のためにのみ持続します。 $リクエスト -

PHPクライアントURL(CURL)拡張機能は、開発者にとって強力なツールであり、リモートサーバーやREST APIとのシームレスな対話を可能にします。尊敬されるマルチプロトコルファイル転送ライブラリであるLibcurlを活用することにより、PHP Curlは効率的なexecuを促進します

Laravelは簡潔なHTTP応答シミュレーション構文を提供し、HTTP相互作用テストを簡素化します。このアプローチは、テストシミュレーションをより直感的にしながら、コード冗長性を大幅に削減します。 基本的な実装は、さまざまな応答タイプのショートカットを提供します。 Illuminate \ support \ facades \ httpを使用します。 http :: fake([[ 'google.com' => 'hello world'、 'github.com' => ['foo' => 'bar']、 'forge.laravel.com' =>

顧客の最も差し迫った問題にリアルタイムでインスタントソリューションを提供したいですか? ライブチャットを使用すると、顧客とのリアルタイムな会話を行い、すぐに問題を解決できます。それはあなたがあなたのカスタムにより速いサービスを提供することを可能にします

記事では、PHP 5.3で導入されたPHPの後期静的結合(LSB)について説明し、より柔軟な継承を求める静的メソッドコールのランタイム解像度を可能にします。 LSBの実用的なアプリケーションと潜在的なパフォーマ

この記事では、フレームワークにカスタム機能を追加し、アーキテクチャの理解、拡張ポイントの識別、統合とデバッグのベストプラクティスに焦点を当てています。

記事では、入力検証、認証、定期的な更新など、脆弱性から保護するためのフレームワークの重要なセキュリティ機能について説明します。
