php混淆把this混淆了
❶ php this和self的區別
面向對象編程(OOP,Object Oriented Programming)現已經成為編程人員的一項基本技能。利用OOP的思想進行PHP的高級編程,對於提高PHP編程能力和規劃web開發構架都是很有意義的。
PHP5 經過重寫後,對OOP的支持額有了很大的飛躍,成為了具備了大部分面向對象語言的特性的語言,比PHP4有了很多的面向對象的特性。這里我主要談的是 this,self,parent 三個關鍵字之間的區別。從字面上來理解,分別是指 這、自己、父親。先初步解釋一下,this是指向當前對象的指針(可以看成C裡面的指針),self是指向當前類的指針,parent是指向父類的指針。 我們這里頻繁使用指針來描述,是因為沒有更好的語言來表達。關於指針的概念,大家可以去參考網路。
下面我們就根據實際的例子結合來講講。
class name //建立了一個名為name的類
{
private $name; //定義屬性,私有
//定義構造函數,用於初始化賦值
function __construct( $name )
{
$this->name = $name; //這里已經使用了this指針語句①
}
//析構函數
function __destruct(){}
//列印用戶名成員函數
function printname()
{
print( $this->name ); //再次使用了this指針語句②,也可以使用echo輸出
}
}
$obj1 = new name( "PBPHome" ); //實例化對象 語句③
//執行列印
$obj1->printname(); //輸出: PBPHome
echo "
"; //輸出:回車
//第二次實例化對象
$obj2 = new name( "PHP" );
//執行列印
$obj2->printname(); //輸出:PHP
?>
說 明:上面的類分別在 語句①和語句②使用了this指針,那麼當時this是指向誰呢?其實this是在實例化的時候來確定指向誰,比如第一次實例化對象的時候(語句③),那 么當時this就是指向$obj1對象,那麼執行語句②的列印時就把 print( $this->name ),那麼當然就輸出了"PBPHome"。第二個實例的時候,print( $this->name )變成了print( $obj2->name ),於是就輸出了"PHP"。所以說,this就是指向當前對象實例的指針,不指向任何其他對象或類。
{二}。PHP中this,self,parent的區別之二self篇
此篇我們就self的用法進行講解
首 先我們要明確一點,self是指向類本身,也就是self是不指向任何已經實例化的對象,一般self使用來指向類中的靜態變數。假如我們使用類裡面靜態 (一般用關鍵字static)的成員,我們也必須使用self來調用。還要注意使用self來調用靜態變數必須使用 :: (域運算符號),見實例。
class counter //定義一個counter的類
{
//定義屬性,包括一個靜態變數$firstCount,並賦初值0 語句①
private static $firstCount = 0;
private $lastCount;
//構造函數
function __construct()
{
$this->lastCount = ++self::$firstCount; //使用self來調用靜態變數 語句②
}
//列印lastCount數值
function printLastCount()
{
print( $this->lastCount );
}
}
//實例化對象
$obj = new Counter();
$obj->printLastCount(); //執行到這里的時候,程序輸出 1
?>
這 里要注意兩個地方語句①和語句②。我們在語句①定義了一個靜態變數$firstCount,那麼在語句②的時候使用了self調用這個值,那麼這時候我們 調用的就是類自己定義的靜態變數$frestCount。我們的靜態變數與下面對象的實例無關,它只是跟類有關,那麼我調用類本身的的,那麼我們就無法使 用this來引用,因為self是指向類本身,與任何對象實例無關。然後前面使用的this調用的是實例化的對象$obj,大家不要混淆了。
關於self就說到這里,結合例子還是比較方便理解的。第二篇結束。
{三}PHP中this,self,parent的區別之三parent篇
此篇我們就parent的用法進行講解。
首先,我們明確,parent是指向父類的指針,一般我們使用parent來調用父類的構造函數。實例如下:
//建立基類Animal
class Animal
{
public $name; //基類的屬性,名字$name
//基類的構造函數,初始化賦值
public function __construct( $name )
{
$this->name = $name;
}
}
//定義派生類Person 繼承自Animal類
class Person extends Animal
{
public $personSex; //對於派生類,新定義了屬性$personSex性別、$personAge年齡
public $personAge;
//派生類的構造函數
function __construct( $personSex, $personAge )
{
parent::__construct( "PBPHome" ); //使用parent調用了父類的構造函數 語句①
$this->personSex = $personSex;
$this->personAge = $personAge;
}
//派生類的成員函數,用於列印,格式:名字 is name,age is 年齡
function printPerson()
{
print( $this->name. " is " .$this->personSex. ",age is " .$this->personAge );
}
}
//實例化Person對象
$personObject = new Person( "male", "21");
//執行列印
$personObject->printPerson(); //輸出結果:PBPHome is male,age is 21
?>
里 面同樣含有this的用法,大家自己分析。我們注意這么個細節:成員屬性都是public(公有屬性和方法,類內部和外部的代碼均可訪問)的,特別是父類 的,這是為了供繼承類通過this來訪問。關鍵點在語句①: parent::__construct( "heiyeluren" ),這時候我們就使用parent來調用父類的構造函數進行對父類的初始化,這樣,繼承類的對象就都給賦值了name為PBPHome。我們可以測試下, 再實例化一個對象$personObject1,執行列印後name仍然是PBPHome。
總結:this是指向對象實例的一個指針,在實例化的時候來確定指向;self是對類本身的一個引用,一般用來指向類中的靜態變數;parent是對父類的引用,一般使用parent來調用父類的構造函數。
❷ 解密PHP混淆代碼,求解碼(過程)完整方法。。
不知道你給的代碼全不全,解密後只有這一段
<?php
$v000000=;
if(preg_match(O0O0000O0('.'),$v000002[1],$v000003))
{
$v000000=str_replace(O0O0000O0(',,$y[0]);
$content=str_replace('),,$v000000);
$v000000=base64_decode($v000000);
}
?>
❸ 這個PHP的加密代碼怎樣破解,這個是什麼原碼來的
可以用黑刀Dezender來試試,我不擔保可以解出來的哦, 從黑刀Dezender4.3版之後,將著力對混淆函數以及自定義函數的解密進行應對。 大家下載壓縮包並解壓後,會發現有一個「config.ini」的文件,這就是混淆函數庫啦! 打開後,可自行編輯其中的內容,當然,也可以通過黑刀Dezender的升級程序直接下載官方最新的混淆函數庫文件。這個混淆函數庫就相當於是一個字典文件了,在保證格式不變的情況下,大家可以在【黑刀部落】下載《黑刀超級字典生成器》生成字典來掛入主程序進行解密,正確步驟為:先備份、改名自己的config.ini文件,生成的字典文件在第一行加入「[OBFUSCATE_NAME]」,將字典文件改名為config.ini,開始解密。 同時,黑刀部落網站的「項目中心」欄目也開設了用戶提交自己已知程序被混淆的函數列表,這樣的話,就能讓Dezender變得越來越強了。再也不怕混淆函數了。呵呵。 什麼是混淆函數?混淆函數,是從Zend Guard 4.0之後新增的一項功能,能把PHP文件中的所有函數名都進行混淆,混淆後變成以「_OBFUSCATE_」開頭的一串「亂碼」,這種加密方式感覺有點類似Md5,因為函數名已經不是原來的樣子了,所以解密出來的PHP文件是不能正常執行的。黑刀Dezender在4.3版之後,新增加了掛入混淆函數庫參與解密的功能,而混淆函數庫,就像是一個包含了已知函數名的字典,利用這個字典,來與被混淆了的函數名(就是所謂的「亂碼」)進行比對,如果比對結果相同,則解密出來的文件,基本上就可以恢復到加密前的樣子了。如果混淆函數庫中沒有包含該PHP文件中使用的函數名,那麼解密結果依然還是會存在「亂碼」的。掌握了這個原理,我們就可以去想辦法解決問題了。 方式有以下幾種: 第一,使用黑刀超級字典生成器產生一個字典,字典的內容可以自己把握,修改字典文件名為「config.ini」,然後打開字典文件,在第一行插入「[OBFUSCATE_NAME]」標記(注意,方括弧也是需要的,也就是引號內的內容都要加進去),將字典文件拷貝入黑刀Dezender主程序所在目錄,同時注意備份原有的config.ini文件。這種辦法費時費力,也要看運氣,不過卻是最實際的解決辦法。 第二,常看別人源代碼的朋友,可以把自己已經掌握了的混淆函數的真實函數名提交到我的網站上來。操作步驟:進入網站首頁,進入項目中心的「DeZender混淆函數庫更新表」,提交。我會定期查看大家提交上來的數據,加入到官方的混淆函數庫中,不斷的增強和完善官方混淆函數庫,大家可以利用黑刀Dezender的自動升級功能對其進行升級!