PHP_PHP チュートリアルに基づいてアップロードされた画像の名前を変更するための 6 つのソリューションの詳細な紹介
1. 該当するシナリオ: データベースから返された自己増加する番号を使用して、アップロードされた画像の名前を変更することはできません。
これは、画像またはファイルをアップロードするプロセスによって決まります。
一般的な画像アップロード プロセスでは、まず画像をサーバーにアップロードし、名前を変更してからデータベースに挿入します。
つまり、データベース内で非常に簡単に取得できる自己増加IDは、ファイル名の重複を避けるためにアップロードされた写真の名前を変更するのに使用できません
データベースから最大のIDを取得して1を加算する方法が使用されます。データベースを増やす 接続数は高い同時実行性と大量のデータには適していません
2番目の通常プラン:
1、guid: 32 文字の 16 進数。
形式: GUID の形式は「xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx」です。各 x は、0 ~ 9 または a ~ f の範囲の 32 桁の 16 進数です。たとえば、6F9619FF-8B86-D011-B42D-00C04FC964FF は有効な GUID 値です。
長所: 重複はほとんどありません。
短所: アップロードされた写真の名前を変更するにはまだ時間がかかります。
使用法:
/*
com_create_guid() は、php5 バージョンでサポートされている関数です。サポートされていないバージョンの場合は、自分で定義できます。
function guid() {
if (function_exists('com_create_guid')){
return com_create_guid();
}else{
mt_srand((double)microtime()*10000);//php 4.2.0 以降ではオプション.
echo(m t_rand ());
$charid = strtoupper(md5(uniqid(rand(), true)));
$hyphen = chr(45);// "-"
$uuid = chr(123 )// "{"
.substr($charid, 0, 8).$hyphen
. .substr($charid,16 , 4).$hyphen
.substr($charid,20,12)
.chr( 125);// "}"
guid と同じ 32 文字の 16 進数を出力する点が異なり、md5 は入力データに基づいて生成される必要があります。
例、
コードをコピーします
コードは次のとおりです:
$str = "Hello";echo md5($str);?>出力、
コードをコピーします
コードは次のとおりです:
8b1a9953c4611296a827abf8c47804d7
コードをコピーします
コードは次のとおりです:
/** time() 関数と組み合わせて使用され、1970 年から現在時刻までの秒数を使用します。シード番号。 */$str=time();echo md5($str);?>
3, uniqid(): 13 桁または 23 桁の文字列を返します。
特に、名前が重複する可能性を減らすために文字列プレフィックスとして差分識別子を使用できるため、uniqid() は md5() の改良版のようなものです。
同時実行性が高くないなどの極端な状況では、すでに一般的なニーズを満たすことができるこの関数を使用することをお勧めします。
詳細、
定義: uniqid() 関数は、マイクロ秒単位の現在時刻に基づいて一意の ID を生成します。
使用法: uniqid(prefix,more_entropy)
説明: prefix は出力文字列にプレフィックスを追加できます。 more_entropy パラメーターが true の場合、23 ビットの文字列が出力されます。
コードをコピーします
コードは次のとおりです:
var_dump(uniqid());var_dump(uniqid("a"));?>
出力結果は次のとおりです:
string(13) "51734aa562254" string(14) "a51734aa562257"
利点: 13桁の文字列の長さは許容可能なファイル名の長さのプレフィックスを追加でき、結果にはデータの難読化が含まれるため、元のデータの逆推論を回避できます。
欠点: md5 と同様、同時実行性が高く、シード データとして秒を使用するため、やはり重複が発生します。
3. アップグレードバージョンの計画:
1、fast_uuid: 17 桁を返します。
これは、uniqid() の不完全なカスタマイズ版に似ています。この関数に登場する「シード番号開始時間」の概念は非常に分かりやすいです。
time() と uniqid() で使用されるデフォルトの時刻は 1970 年から計算され、長さは 10 桁 (1366512439) です。「シード番号開始時刻」を使用すると、実際には必要なため、この値を減らすことができます。これは単なる値です。自動的に成長する可能性があります。
開始時間をカスタマイズすると、長さが短縮されるだけでなく、混乱を招く可能性もあります。
/*
* パラメータ suffix_len は、生成された ID 値に追加されるランダムな桁の数を指定します。デフォルト値は 3 です。
* アルゴリズムを提供してくれた「Ivan Tan| Tan Junqing DrinChing (at) Gmail.com」に感謝します。
* @param intsuffix_len
* @returnstring
*/
functionfast_uuid($ suffix_len = 3){
$ time = explode( ''、microtime());
$ id =($ time [1] - $ being_timestamp)。
29832412631099013
2、時間()+乱数:
1 秒間に発生する複数のリクエストを解決するために、上記の例で乱数の使用がすでに登場しています。次のように 2 つの関数を提供します。
コードは次のとおりです:
PHP_VERSION for($i = 0; $i .= $chars[mt_rand(0, $max)];
} return $hash;
}
function random2($length, $numeric = 0) {
?>
4、最終計画:
アイデア: ユーザー ID + 秒 + 乱数。このうち、「userid+秒」は10進数から64桁に変換され、桁数が減ります。
説明:
1、ユーザー ID: 10 進数に変換された「ZZZZ」の最大値は「16777215」に等しく、10 進数に変換された「ZZZ」の最大値は「262143」に等しくなります。
2、秒: を設定します。自分の時間のスタート地点。
$less=time()-strtotime('2012-4-21'); 16進数の「1SpRe」、5桁に変換します
$less=time()-strtotime('2013-3-21'); 16 進数 "_jHY"; 4 桁
3、乱数: 3 桁の乱数を生成するには、random(3) を使用します。
最終結果:
4 桁のユーザー ID + 4 桁の秒 + 3 桁の乱数 = 11 桁の文字列。結果は uniqid() と似ていますが、堅牢性が向上しています。
5、10進数から16進数への変換アルゴリズム:
1、アルゴリズム 1:
コードをコピーします コードは次のとおりです:
View Code
const KeyCode = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ_$';
/**
* 64 進数の数値文字列を 10 進数の数値文字列に変換します
* @param $m string 64 進数の数値文字列
* @param $len integer 文字列の長さを返します。長さが十分でない場合は、0 パディングを使用します, 0はパディングなしを意味します
* @return string
* @author 野马
*/
function hex64to10($m, $len = 0) {
$m = (文字列)$m;
$hex2 = '';
$Code = KeyCode;
for($i = 0, $l = strlen($Code); $i $KeyCode[] = $Code[$i];
}
$ KeyCode = array_flip($KeyCode);
for($i = 0, $l = strlen($m); $i $one = $m[$i];
$ hex2 .= str_pad(decbin($KeyCode[$one]), 6, '0', STR_PAD_LEFT);
}
$return = binding($hex2);
if($len) {
$clen = strlen( $return);
if($clen >= $len) {
return $return;
}
else {
return str_pad($return, $len, ' 0', STR_PAD_LEFT);
}
}
return $ return;
}
/**
* 10進数の数値文字列を64ベースの数値文字列に変換します
* @param $m string 10進数の数値文字列
* @param $len integer 文字列の長さを返します。長さが十分でない場合は、0パディング、0を使用します。パディングなしを意味します
* @return string
* @author 野马
*/
function hex10to64($m, $len = 0) {
$KeyCode = KeyCode;
$hex2 = decbin($m);
$hex2 = str_rsplit($ hex2, 6);
$hex64 = array();
foreach($hex2 as $one) {
$t = binding($one);
$hex64[] = $KeyCode[$t];
}
$ return = preg_replace('/^0*/', '', implode('', $hex64));
if($len) {
$clen = strlen($return);
if($clen >= $len) {
return $return;
}
else {
return str_pad($return, $len, '0', STR_PAD_LEFT);
}
}
return $return;
}
/**
* 16進数の数値文字列を16進数の数値文字列に変換します
* @param $m string 16進数の数値文字列
* @param $len integer 文字列の長さを返します。長さが十分でない場合は、0パディングを使用します。0はパディングなしを意味します
* @return string
* @author 野马
*/
function hex16to64($m, $len = 0) {
$KeyCode = KeyCode;
$hex2 = array();
for($i = 0, $j = strlen( $m); $i $hex2[] = str_pad($m[$i], 16, 2), '0', STR_PAD_LEFT);
$hex2 = implode('', $hex2);
$hex2 = str_rsplit($hex2, 6);
foreach($hex2 as $one) {
$hex64[] = $KeyCode[bindec($one)] ;
}
$return = preg_replace('/^0*/', '', implode('', $hex64));
if($len) {
$clen = strlen($return);
if( $clen >= $len) {
return $return;
}
else {
return str_pad($return, $len, '0',
}
}
return $return;
}
/ **
* PHPのネイティブ関数str_splitに近いですが、切り取る場合は端から数えます
* @param $str string 切り取る文字列
* @param $len integer 各文字列の長さ
* @return ワイルド馬
*/
function str_rsplit($str, $len = 1) {
if($str == null || $str == false || $str == '') return false;
$strlen = strlen($str);
if($strlen $headlen = $strlen % $len;
if($headlen == 0) {
return str_split($ str, $len);
}
$return = array(substr($str, 0, $headlen));
return array_merge($return, str_split(substr($str, $headlen), $len));
}
echo "rn
e:" 。 hex10to64($a);
echo "rn
e:" 。 hex64to10(hex10to64($a));
コードを表示
function dec2s4($dec) {
$base = '0123456789_$abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
$result = '';
{
$result = $base[$dec % 64] を実行します。 $結果;
$dec = intval($dec / 64);
} while ($dec != 0);
$result を返す;
}
function s42dec($sixty_four) {
$base_map = array ( '0' => 0, '1' => 1, '2' => 2, '3' => 3, ' 4' => 4、 '5' => 5、 '7' => 8、 '9' => => 10、 '$' => 11、 'b' => 14、 'd' => ; 16、「f」 => 18、「h」 => 20、「k」 => 22 、 'l' => 24、 'n' => 26、 'q' => 28、 r' => 29、 's' => 31、 'v' => 34、 'x' => 35、 'y' => 37、 'B' => 39、 'C' => ; 41、「E」 => 43、「G」 => 45、「I」 => 47 、 'K' => 49、 'M' => 51、 'P' => ' Q' => 54、「R」 => 55、「S」 => 56、 'T' => 57、 'U' => 58、 'V' => 59、 'W' => 60、 'X' => 61、 'Y' => 62、 'Z' => 63、 );
$結果 = 0;
$len = strlen($sixty_four);
for ($n = 0; $n $result *= 64;
$result += $base_map[$sixty_four{$n}];
}
$result を返します。
}
$a=idate("U");
var_dump(dec2s4($a));
var_dump(s42dec(dec2s4($a)));
3,算法效率测试:
コードを表示
$strarr = array();
$time1 = microtime(true);
for($i = 0; $i $str = idate("U")+$i ;
$strarr[] = "{$i}->$strrn
";
}
$time2 = microtime(true);
$time3 = $time2 - $time1;
$time1 = microtime(true);
for($i = 0; $i $str = dec2s4(idate("U")+$i);
$strarr[ ] = "{$i}->$strrn
";
}
$time2 = microtime(true);
echo "rn
运行10000回使用時間(秒):" . ($time2 - $time1 - $time3);
4. テスト結果
アルゴリズム 1: 0.1687250137329
アルゴリズム 2: 0.044965028762817
5. 結論: アルゴリズム 1 は、md5 によって生成された 16 進数を 16 進数に変換でき、md5 を使用する必要がある場合に使用できます。文字列環境の中で。
6 番目の概要
この記事では、アップロードされた画像の名前を変更するために使用できるいくつかの方法について説明します。重要な点は、文字列を減らすために 10 進数を 16 進数に変更することです。
例えば、fast_uuid で生成された 17 桁の数値は、たった 7 文字の 16 進数に変換されます。
具体的な使い方は、状況に応じて柔軟に使用できます。
参考:
1、GUID Baidu 百科事典: http://baike.baidu.com/view/185358.htm
2、com_create_guid() 公式ガイド: http://www.php.net/manual/zh/function.com-create -guid.php
3、MD5() 関数の説明: http://www.w3school.com.cn/php/func_string_md5.asp
4、time() 関数の説明: http://www.w3school.com.cn /php/func_date_time.asp
5、uniqid() 関数の説明: http://www.w3school.com.cn/php/func_misc_uniqid.asp

phpssionscanStorestrings、numbers、arrays、andobjects.1.strings:textdatalikeusernames.2.numbers:integersorfloatsforcounters.3.arrays:listslikeshoppingcarts.4.objects:complextructuresthataresialized。

tostartaphpsession、outsession_start()atthescript'sbeginning.1)placeitbe foreanyouttosetthesscookie.2)usesionsionsionsionserdatalikelogintatussorshoppingcarts.3)再生セッションインドストップレベントフィックスアタック

セッション再生とは、新しいセッションIDを生成し、セッション固定攻撃の場合にユーザーが機密操作を実行するときに古いIDを無効にすることを指します。実装の手順には次のものが含まれます。1。感度操作を検出、2。新しいセッションIDを生成する、3。古いセッションIDを破壊し、4。ユーザー側のセッション情報を更新します。

PHPセッションは、アプリケーションのパフォーマンスに大きな影響を与えます。最適化方法には以下が含まれます。1。データベースを使用してセッションデータを保存して応答速度を向上させます。 2。セッションデータの使用を削減し、必要な情報のみを保存します。 3.非ブロッキングセッションプロセッサを使用して、同時実行機能を改善します。 4.セッションの有効期限を調整して、ユーザーエクスペリエンスとサーバーの負担のバランスを取ります。 5.永続的なセッションを使用して、データの読み取り時間と書き込み時間を減らします。

phpsesionsareserver-side、whilecookiesareclient-side.1)Sessionsionsionsoredataontheserver、aremoresecure.2)cookiesstoredataontheclient、cookiestoresecure、andlimitedinsizeisize.sesionsionsionivationivationivationivationivationivationivationivate

phpidentifiesauser'ssessionsingsinssessionCookiesIds.1)whensession_start()iscalled、phpgeneratesauniquesidstoredsored incoookienadphpsessidontheuser'sbrowser.2)thisidallowsphptortorieSessiondatadata fromthata

PHPセッションのセキュリティは、次の測定を通じて達成できます。1。session_regenerate_id()を使用して、ユーザーがログインまたは重要な操作である場合にセッションIDを再生します。 2. HTTPSプロトコルを介して送信セッションIDを暗号化します。 3。Session_Save_Path()を使用して、セッションデータを保存し、権限を正しく設定するためのSecure Directoryを指定します。

phpsessionFilesToredInthededirectoryspecifiedBysession.save_path、通常/tmponunix-likesystemsorc:\ windows \ temponwindows.tocustomizethis:1)uesession_save_path()tosetaCustomdirectory、ensuringit'swritadistradistradistradistradistra


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

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

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

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

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

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

ホットトピック









