對(duì)象串行化
Jun 08, 2016 pm 05:33 PM串行化可以把變量包括對(duì)象,轉(zhuǎn)化成連續(xù)bytes數(shù)據(jù). 你可以將串行化后的變量存在一個(gè)文件里或在網(wǎng)絡(luò)上傳輸. 然后再反串行化還原為原來的數(shù)據(jù). 你在反串行化類的對(duì)象之前定義的類,PHP可以成功地存儲(chǔ)其對(duì)象的屬性和方法. 有時(shí)你可能需要一個(gè)對(duì)象在反串行化后立即執(zhí)行. 為了這樣的目的,PHP會(huì)自動(dòng)尋找__sleep和__wakeup方法.
當(dāng)一個(gè)對(duì)象被串行化,PHP會(huì)調(diào)用__sleep方法(假如存在的話). 在反串行化一個(gè)對(duì)象后,PHP 會(huì)調(diào)用__wakeup方法. 這兩個(gè)方法都不接受參數(shù). __sleep方法必須返回一個(gè)數(shù)組,包含需要串行化的屬性. PHP會(huì)拋棄其它屬性的值. 假如沒有__sleep方法,PHP將保存所有屬性.
例子6.16顯示了如何用__sleep和__wakeup方法來串行化一個(gè)對(duì)象. Id屬性是一個(gè)不打算保留在對(duì)象中的臨時(shí)屬性. __sleep方法保證在串行化的對(duì)象中不包含id屬性. 當(dāng)反串行化一個(gè)User對(duì)象,__wakeup方法建立id屬性的新值. 這個(gè)例子被設(shè)計(jì)成自我保持. 在實(shí)際開發(fā)中,你可能發(fā)現(xiàn)包含資源(如圖像或數(shù)據(jù)流)的對(duì)象需要這些方法.
Listing 6.16 Object serialization
class User
{
public $name;
public $id;
function __construct()
{
//give user a unique ID 賦予一個(gè)不同的ID
$this->id = uniqid();
}
function __sleep()
{
//do not serialize this->id 不串行化id
return(array("name"));
}
function __wakeup()
{
//give user a unique ID
$this->id = uniqid();
}
}
//create object 建立一個(gè)對(duì)象
$u = new User;
$u->name = "Leon";
//serialize it 串行化 注重不串行化id屬性,id的值被拋棄
$s = serialize($u);
//unserialize it 反串行化 id被重新賦值
$u2 = unserialize($s);
//$u and $u2 have different IDs $u和$u2有不同的ID
print_r($u);
print_r($u2);
?>

Hei?e KI -Werkzeuge

Undress AI Tool
Ausziehbilder kostenlos

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem v?llig kostenlosen KI-Gesichtstausch-Tool aus!

Hei?er Artikel

Hei?e Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Hei?e Themen

AgneeratorinphpiSamemory-effizientes WaytoiterateOverlargedatasetsByyieldingValueatimeinsteadofReturningThemallatonce.1.GeneratorsusetheyieldKeywordtoproduktenvaluesonDemand, ReducingMemoryUsage.2.TheyareusefulforfulforfulfordlingBiglopploups, Lesebiglochen, Leselungen, Lesebigs, Leselung, oder

In PHP k?nnen Sie quadratische Klammern oder lockige Klammern verwenden, um Zeichenfolgenspezifikationsspezifische Indexzeichen zu erhalten, aber quadratische Klammern werden empfohlen. Der Index startet von 0 und der Zugriff au?erhalb des Bereichs gibt einen Nullwert zurück und kann keinen Wert zugewiesen; MB_SUBSTR ist erforderlich, um Multi-Byte-Zeichen zu verarbeiten. Zum Beispiel: $ str = "Hallo"; echo $ str [0]; Ausgabe H; und chinesische Zeichen wie Mb_Substr ($ str, 1,1) müssen das richtige Ergebnis erzielen. In den tats?chlichen Anwendungen sollte die L?nge der Zeichenfolge vor dem Schleifen überprüft werden, dynamische Zeichenfolgen müssen für die Gültigkeit verifiziert werden, und mehrsprachige Projekte empfehlen, Multi-Byte-Sicherheitsfunktionen einheitlich zu verwenden.

Um eine Entführung der Sitzung in PHP zu verhindern, müssen die folgenden Ma?nahmen ergriffen werden: 1. Verwenden Sie HTTPS, um die übertragung zu verschlüsseln und die Sitzung zu setzen. Cookie_secure = 1 in php.ini; 2. Setzen Sie die Sicherheits -Cookie -Attribute, einschlie?lich Httponly, sicherer und samesit; 3.. CALL Session_regenerate_id (true) Wenn sich der Benutzer anmeldet oder die Berechtigungen ?ndern, um die Sitzung zu ?ndern; 4. Begrenzen Sie den Sitzungslebenszyklus, konfigurieren Sie die Aktivit?tszeit des Benutzers angemessen. 5. Verbot die SessionID der URL und setzen

Sie k?nnen substr () oder mb_substr () verwenden, um die ersten N -Zeichen in PHP zu erhalten. Die spezifischen Schritte sind wie folgt: 1. Verwenden Sie Substr ($ String, 0, n), um die ersten N -Zeichen abzufangen, was für ASCII -Zeichen geeignet ist und einfach und effizient ist; 2. Bei der Verarbeitung von Multi-Byte-Zeichen (z. B. Chinesisch), mb_substr ($ string, 0, n, 'utf-8') und sicherstellen, dass die Mbstring-Erweiterung aktiviert ist; 3. Wenn die Zeichenfolge HTML- oder Whitespace -Zeichen enth?lt, sollten Sie zun?chst Strip_Tags () verwenden, um die Tags zu entfernen und die R?ume zu reinigen (), um die R?ume zu reinigen, und diese dann abfangen, um sicherzustellen, dass die Ergebnisse sauber sind.

Die Funktion urlencode () wird verwendet, um Strings in URL-sichere Formate zu codieren, in denen nicht alphanumerische Zeichen (au?er-, _ und.) Durch ein prozentuales Zeichen ersetzt werden, gefolgt von einer zweistelligen Hexadezimalzahl. Zum Beispiel werden Leerzeichen in Zeichen konvertiert, Ausrufezeichen in! Und chinesische Zeichen werden in ihr UTF-8-Codierungsformular umgewandelt. Bei der Verwendung sollten nur die Parameterwerte codiert werden, nicht die gesamte URL, um zu vermeiden, dass die URL -Struktur besch?digt wird. Für andere Teile der URL, wie z. B. Pfadsegmente, sollte die Funktion rawurlencode () verwendet werden, die den Raum in den Raum umwandelt. Bei der Verarbeitung von Array -Parametern k?nnen Sie http_build_query () verwenden, um urlencode () automatisch für jeden Wert zu codieren oder manuell aufzurufen, um eine sichere Datenübertragung sicherzustellen. Nur

Es gibt zwei Hauptmethoden, um die letzten N-Zeichen einer Zeichenfolge in PHP zu erhalten: 1. Verwenden Sie die Funktion substr (), um durch die negative Ausgangsposition abzufangen, die für Einzelbyte-Zeichen geeignet ist. 2. Verwenden Sie die Funktion mb_substr (), um mehrsprachige und UTF-8-Codierung zu unterstützen, um nicht englische Zeichen zu vermeiden. 3.. Bestimmen Sie optional, ob die Saitenl?nge ausreicht, um Grenzsituationen zu behandeln. 4. Es wird nicht empfohlen, die Kombinationsmethode von strrev () substr () zu verwenden, da sie für Multi-Byte-Zeichen nicht sicher und ineffizient ist.

Um Sitzungsvariablen in PHP festzulegen und zu erhalten, müssen Sie zun?chst die Sitzung für Sitzung_start () oben im Skript aufrufen, um die Sitzung zu starten. 1. Wenn Sie Sitzungsvariablen festlegen, verwenden Sie $ _Session Hyperglobal Array, um bestimmten Schlüssel Werte zuzuweisen, wie z. Es kann Zeichenfolgen, Zahlen, Arrays und sogar Objekte speichern, aber vermeiden, zu viele Daten zu speichern, um die Leistung zu vermeiden. 2. Wenn Sie Sitzungsvariablen erhalten, müssen Sie zuerst Session_start () anrufen und dann über den Schlüssel auf das $ _Session -Array zugreifen, z. B. Echo $ _Session ['Benutzername']; Es wird empfohlen, ISSet () zu überprüfen, ob die Variable vorhanden ist, um Fehler zu vermeiden

Zu den Schlüsselmethoden zur Verhinderung der SQL -Injektion in PHP geh?ren: 1.. Verwenden Sie Vorverarbeitungsanweisungen (wie PDO oder MySQLI), um SQL -Code und Daten zu trennen; 2. Schalten Sie den simulierten Vorverarbeitungsmodus aus, um eine echte Vorverarbeitung zu gew?hrleisten. Filtern und überprüfen Sie die Benutzereingabe, z. B. die Verwendung von is_numeric () und filter_var (); 4. Vermeiden Sie direkt SQL -Zeichenfolgen und verwenden Sie stattdessen Parameterbindung. 5. Schalten Sie die Fehleranzeige in der Produktionsumgebung aus und zeichnen Sie Fehlerprotokolle aus. Diese Ma?nahmen verhindern umfassend das Risiko einer SQL -Injektion von Mechanismen und Details.
