検索
ホームページバックエンド開発PHPチュートリアルPHP ファイルアップロードクラスはサムネイルコードを生成可能_PHP チュートリアル

php教程文件上传类可生成缩略图代码

if ($_GET['action'] == 'save') {

$up = new Upload();       
$up->set_dir(dirname(__FILE__).'/upload/','{y}/{m}');       
$up->set_thumb(100,80);       
$up->set_watermark(dirname(__FILE__).'/jblog/images/watermark.png',6,90);       
$fs = $up->execute();       

var_dump($fs);       
}


?>       

       
テスト       
       
       
       
       
       
       
       
 

UClass アップロード {

var $ dir; // 添付ファイルには物理ディレクトリが保存されます
var $time; // カスタム ファイルのアップロード時間 var $allow_types; var $watermark_file; //ウォーターマーク画像アドレス
var $watermark_pos ; //ウォーターマークの位置
var $watermark_trans;//ウォーターマークの透明度



//コンストラクター関数
//$types: アップロードできるファイルの種類、$maxsize: 許可されるサイズ、$field: アップロード コントロール名、$time: アップロード時刻を定義してください function Upload($types = 'jpg|png', $maxsize = 102) 4、$field = ' '、$time = $this->maxsize = $$maxsize * 1 024;
/ファイルが特別に保存されているディレクトリを設定して作成します// $ basedir $ basedir、$ filedir = ''){

(array( '{y}'、 '{m}'、 '{d}')、 array(date('Y',$this->time),date('m',$this->time ),date('d',$this->time)),strto lower($filedir) );!//画像のサムネイル設定、サムネイルが生成されない場合は設定する必要はありません>thumb_width = $width;

//$file: ウォーターマーク画像、$pos: ウォーターマークの位置、$trans: ウォーターマークの透明度関数 set_watermark ($file, $pos = 6, $trans = 80) { $this->watermark_file = $file;
$this->watermark_pos = $pos; >watermark_trans = $trans; ----------- ------------------
ファイルアップロードを実行し、処理後、アップロードの成功または失敗を含むファイル情報の配列を返します。
その内: name はファイル名です。アップロードが成功した場合、それはサーバーにアップロードされたファイル名です。アップロードが失敗した場合、それはサーバー上に添付ファイルが保存される物理パスです。アップロードが失敗した場合、この値は存在しません。サイズは添付ファイルのサイズです。アップロードが失敗した場合、この値は存在しません


フラグはステータスを示します。1 は成功を意味し、-1 はファイル タイプが許可されていないことを意味し、-2 はファイル サイズが超過していることを意味します。
------------------------ ---------------------------- -------------------*/
functionexecute( ) { $files = array(); ( $keys as $key) { ['名前 '][$ key]); // ファイル拡張子を取得$filename = date('Ymdhis',$this->time).mt_rand(10,99).'.'.$fileext;ファイル名を作成します
$ FILEDIR = $ This- & GTR; // 実際のストレージ カタログを追加します
$ Filesize = $ _Files [$ Field] ['SIZE'] [$ Key] // ファイルの種類は許可されません
if (!in_array($fileext,$this->allow_types)) {                $files[$key]['name'] = $_FILES[$field]['name'][$key];       
$files[$key]['flag'] = -1;       
続けます。       
}

//文件大小超出
if ($filesize > $this->maxsize) {
$files[$key]['name'] = $_FILES[$field]['name'][$鍵];       
$files[$key]['name'] = $filesize;       
$files[$key]['flag'] = -2;       
続けます。       
}

$files[$key]['name'] = $filename;       
$files[$key]['dir'] = $filedir;       
$files[$key]['size'] = $filesize;       

//保存上传文件并删除临時文件
if (is_uploaded_file($_FILES[$field]['tmp_name'][$key])) {
move_uploaded_file($_FILES[$field]['tmp_name'][$キー],$filedir.$ファイル名);       
@unlink($_FILES[$field]['tmp_name'][$key]);       
$files[$key]['flag'] = 1;       

//对图片进行加水印和生成缩略图
if (in_array($fileext,array('jpg','png'))) {
if ($this->thumb_width) {
if ($this ->create_thumb($filedir.$filename,$filedir.'thumb_'.$filename)) {
$files[$key]['thumb'] = 'thumb_'.$filename;  //缩略图文件名
}
}
$this->create_ウォーターマーク($filedir.$ファイル名);       
} //サムネイルを作成、サムネイルを生成同じ拡張子を持つ
//$src_file: ソース画像のパス、$thumb_file: サムネイルのパス
function create_thumb ($ src_file,$thumb_file) If (!file_exists($src_file)) が返されるfalse; $ src_info = getImagesize($ src_file); ];真 // 実際のカラフルな縮小画像を作成します
$ Thumb_img = @imageCreateTrueColor ($ t_width, $ t_height) ('ImageCopyResampled') ) { ;
@ImageCopyResize($thumb_img, $src_img,0,0,0,0,$ t_width,$t_height,$src_info[0],$src_info[1]);
} }

switch ($fileext) { ImageJPEG($thumb_img,$thumb_file); _ファイル); 休憩;ファイルcreate create_watermark($ file){getImagesize '))$ gd_allow_types [' image/gif '] =' 'PNG から画像を作成'

        //获取文件情報
$fileinfo = getImageSize($file);       
$wminfo = getImageSize($this->watermark_file);       

if ($fileinfo[0]
if (array_key_exists($fileinfo['mime'],$gd_allow_types)) {
if (array_key_exists($wminfo['mime'],$gd_allow_types)) {

//从文件创建图像
$temp = $ gd_allow_types[$fileinfo['mime']]($file);       
$temp_wm = $gd_allow_types[$wminfo['mime']]($this->watermark_file);       

//水印の位置
switch ($this->watermark_pos) {
case 1 : //顶部居左
$dst_x = 0; $dst_y = 0;壊す;                     
case 2 : //顶部居中
$dst_x = ($fileinfo[0] - $wminfo[0]) / 2; $dst_y = 0;壊す;                       
case 3 : //顶部居右
$dst_x = $fileinfo[0]; $dst_y = 0;壊す;                      
case 4 : //底部居左
$dst_x = 0; $dst_y = $fileinfo[1];壊す;                      
case 5 : //底部居中
$dst_x = ($fileinfo[0] - $wminfo[0]) / 2; $dst_y = $fileinfo[1];壊す;            
case 6 : //底部居右
$dst_x = $fileinfo[0]-$wminfo[0]; $dst_y = $fileinfo[1]-$wminfo[1]; $dst_x = mt_ rand(0,$fileinfo[0]-$wminfo[0]) ])$ dst_y = mt_rand($ fileinfo [1] - $ temp_wm、true); ,$temp_wm,$dst_x,$dst_y,0,0,$wminfo[0],$wminfo[1]); ~ 'image/jpeg' : 「画像/png」: /gif' :
@imageGIF($temp ,$file);//ゼロタイム画像strrchr($ filename、 '。')、1,10);



http://www.bkjia.com/PHPjc/444941.html

www.bkjia.com

tru​​e

http://www.bkjia.com/PHPjc/444941.html
技術記事
PHP チュートリアル ファイルのアップロード クラスはサムネイル コードを生成できますか?php if ($_GET['action'] == 'save') { $up = new Upload(); $up-set_dir(dirname(__FILE__).'/upload/ ' ,'{y}/{m}'); $up-set_thumb(100,80...

)
声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
PHPセッションを失敗させる可能性のあるいくつかの一般的な問題は何ですか?PHPセッションを失敗させる可能性のあるいくつかの一般的な問題は何ですか?Apr 25, 2025 am 12:16 AM

PHPSESSIONの障害の理由には、構成エラー、Cookieの問題、セッションの有効期限が含まれます。 1。構成エラー:正しいセッションをチェックして設定します。save_path。 2.Cookieの問題:Cookieが正しく設定されていることを確認してください。 3.セッションの有効期限:セッションを調整してください。GC_MAXLIFETIME値はセッション時間を延長します。

PHPでセッション関連の問題をどのようにデバッグしますか?PHPでセッション関連の問題をどのようにデバッグしますか?Apr 25, 2025 am 12:12 AM

PHPでセッションの問題をデバッグする方法は次のとおりです。1。セッションが正しく開始されるかどうかを確認します。 2.セッションIDの配信を確認します。 3.セッションデータのストレージと読み取りを確認します。 4.サーバーの構成を確認します。セッションIDとデータを出力し、セッションファイルのコンテンツを表示するなど、セッション関連の問題を効果的に診断して解決できます。

session_start()が複数回呼び出されるとどうなりますか?session_start()が複数回呼び出されるとどうなりますか?Apr 25, 2025 am 12:06 AM

session_start()への複数の呼び出しにより、警告メッセージと可能なデータ上書きが行われます。 1)PHPは警告を発し、セッションが開始されたことを促します。 2)セッションデータの予期しない上書きを引き起こす可能性があります。 3)session_status()を使用してセッションステータスを確認して、繰り返しの呼び出しを避けます。

PHPでセッションのライフタイムをどのように構成しますか?PHPでセッションのライフタイムをどのように構成しますか?Apr 25, 2025 am 12:05 AM

PHPでのセッションライフサイクルの構成は、session.gc_maxlifetimeとsession.cookie_lifetimeを設定することで達成できます。 1)session.gc_maxlifetimeサーバー側のセッションデータのサバイバル時間を制御します。 0に設定すると、ブラウザが閉じているとCookieが期限切れになります。

セッションを保存するためにデータベースを使用することの利点は何ですか?セッションを保存するためにデータベースを使用することの利点は何ですか?Apr 24, 2025 am 12:16 AM

データベースストレージセッションを使用することの主な利点には、持続性、スケーラビリティ、セキュリティが含まれます。 1。永続性:サーバーが再起動しても、セッションデータは変更されないままになります。 2。スケーラビリティ:分散システムに適用され、セッションデータが複数のサーバー間で同期されるようにします。 3。セキュリティ:データベースは、機密情報を保護するための暗号化されたストレージを提供します。

PHPでカスタムセッション処理をどのように実装しますか?PHPでカスタムセッション処理をどのように実装しますか?Apr 24, 2025 am 12:16 AM

PHPでのカスタムセッション処理の実装は、SessionHandlerInterfaceインターフェイスを実装することで実行できます。具体的な手順には、次のものが含まれます。1)CussentsessionHandlerなどのSessionHandlerInterfaceを実装するクラスの作成。 2)セッションデータのライフサイクルとストレージ方法を定義するためのインターフェイス(オープン、クローズ、読み取り、書き込み、破壊、GCなど)の書き換え方法。 3)PHPスクリプトでカスタムセッションプロセッサを登録し、セッションを開始します。これにより、データをMySQLやRedisなどのメディアに保存して、パフォーマンス、セキュリティ、スケーラビリティを改善できます。

セッションIDとは何ですか?セッションIDとは何ですか?Apr 24, 2025 am 12:13 AM

SessionIDは、ユーザーセッションのステータスを追跡するためにWebアプリケーションで使用されるメカニズムです。 1.ユーザーとサーバー間の複数のインタラクション中にユーザーのID情報を維持するために使用されるランダムに生成された文字列です。 2。サーバーは、ユーザーの複数のリクエストでこれらの要求を識別および関連付けるのに役立つCookieまたはURLパラメーターを介してクライアントに生成および送信します。 3.生成は通常、ランダムアルゴリズムを使用して、一意性と予測不可能性を確保します。 4.実際の開発では、Redisなどのメモリ内データベースを使用してセッションデータを保存してパフォーマンスとセキュリティを改善できます。

ステートレス環境(APIなど)でセッションをどのように処理しますか?ステートレス環境(APIなど)でセッションをどのように処理しますか?Apr 24, 2025 am 12:12 AM

APIなどのステートレス環境でのセッションの管理は、JWTまたはCookieを使用して達成できます。 1。JWTは、無国籍とスケーラビリティに適していますが、ビッグデータに関してはサイズが大きいです。 2.cookiesはより伝統的で実装が簡単ですが、セキュリティを確保するために慎重に構成する必要があります。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

SecLists

SecLists

SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

SublimeText3 Linux 新バージョン

SublimeText3 Linux 新バージョン

SublimeText3 Linux 最新バージョン

DVWA

DVWA

Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強力な PHP 統合開発環境

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。