ホームページ > バックエンド開発 > PHPチュートリアル > PHP単一ファイルアップロード機能のカプセル化

PHP単一ファイルアップロード機能のカプセル化

WBOY
リリース: 2016-07-25 08:43:27
オリジナル
1168 人が閲覧しました
  1. //単一ファイルアップロード機能のカプセル化
  2. //ファイルアップロードの原理:クライアントファイルをサーバーにアップロードし、サーバー上の一時ファイルを指定されたディレクトリに移動します。
  3. //ファイルの方向: クライアント -> サーバー (一時ファイル) -> ディレクトリを指定します。ファイルがサーバーに入ると、一時ファイルになります。このとき、一時ファイルの名前は tmp_name として使用されます。操作。
  4. //顧客がソース コードを通じて制限を変更できるため、クライアントでアップロード ファイルの制限 (ファイルの種類とサイズ) を設定するのは安全ではないため、ここでサーバーで制限を設定します。
  5. //中国語の文字化けを避けるためにエンコーディングを UTF-8 に設定します
  6. header('Content-Type: text/html;charset=utf-8');
  7. //$_FILES を通じてアップロードされたファイル情報を受信します
  8. $fileInfo = $ _FILES ['myFile'];
  9. function UploadFile($fileInfo,$uploadPath='uploads',$flag=true,$allowExt=array('jpeg','jpg','png','gif'),$maxSize = 2097152){
  10. //エラー番号を判断してください。0 または UPLOAD_ERR_OK のみです。エラーは発生せず、アップロードは成功です
  11. if($fileInfo['error']>0){
  12. //注意!エラーメッセージは no です。 5
  13. switch($fileInfo['error']){
  14. case 1:
  15. $mes= 'アップロードされたファイルは、PHP 設定ファイルの Upload_max_filesize オプションの値を超えています';
  16. Break;
  17. case 2 :
  18. $mes= 'HTML フォームのサイズ MAX_FILE_SIZE 制限を超えました';
  19. Break;
  20. case 3:
  21. $mes= 'ファイルは部分的にアップロードされました';
  22. Break;
  23. case 4:
  24. $mes= 'オプションなしファイルをアップロードします';
  25. Break;
  26. case 6:
  27. $mes= '一時ディレクトリが見つかりません';
  28. Break;
  29. case 7:
  30. $mes= 'ファイルの書き込みに失敗しました';
  31. Break;
  32. case 8:
  33. $ mes= 'アップロードされたファイルは PHP 拡張プログラム Break によって削除されました';
  34. Break;
  35. }
  36. exit($mes);
  37. }
  38. $ext=pathinfo($fileInfo['name'],PATHINFO_EXTENSION);
  39. // $allowExt=array('jpeg',' jpg','png','gif');
  40. //アップロードされたファイルの種類を検出します
  41. if(in_array($ext,$allowExt)){
  42. exit('illegalファイルタイプ');
  43. }
  44. // アップロードしたファイルのファイルサイズが仕様を満たしているか確認します
  45. //$maxSize = 2097152;//2M
  46. if($fileInfo['size']>$maxSize){
  47. exit('アップロードされたファイルが大きすぎます');
  48. }
  49. //画像が実際の画像タイプかどうかを確認します
  50. //$flag=true;
  51. if($flag){
  52. if(!getimagesize($) fileInfo['tmp_name'])){
  53. exit('実際の画像ではありません Type');
  54. }
  55. }
  56. //HTTP POST 経由でアップロードされているかどうかを確認します
  57. if(!is_uploaded_file($fileInfo['tmp_name'] )){
  58. exit('ファイルは HTTP POST 経由でアップロードされていません ');
  59. }
  60. //$uploadPath='uploads';
  61. //そのようなフォルダーが存在しない場合は、作成します
  62. if(!file_exists($) UploadPath)){
  63. mkdir( $uploadPath, 0777, true) ;
  64. chmod( $uploadPath, 0777 );
  65. }
  66. //新しいファイル名は一意です
  67. $uniName = md5 ( uniqid( microtime(true),true) ).'.'.$ext;
  68. $destination = $uploadPath. '/'.$uniName;
  69. //@ 記号は、顧客にエラー メッセージが表示されないようにするためのものです
  70. if(! @move_uploaded_file($fileInfo['tmp_name' ], $destination )){
  71. exit('ファイルの移動に失敗しました') ;
  72. }
  73. //echo 'ファイルは正常にアップロードされました';
  74. //return array(
  75. // 'newName'=>$destination,
  76. / / 'size'=>$fileInfo['size'],
  77. // 'type'=>$fileInfo['type']
  78. //);
  79. return $destination;
  80. }
  81. ?>
コードをコピー

ファイルアップロード、PHP


ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート