php實現(xiàn)的Cookies操作類實例,phpcookies類實例_PHP教程
Jul 13, 2016 am 10:18 AMphp實現(xiàn)的Cookies操作類實例,phpcookies類實例
本文實例講述了PHP實現(xiàn)的Cookies操作類及其用法,分享給大家供大家參考。具體分析如下:
一、功能:
1.保存,讀取,更新,清除cookies數(shù)據(jù)。
2.可設置前綴。
3.強制超時控制。
4.cookies數(shù)據(jù)可以是字符串,數(shù)組,對象等。
二、用法:
Cookies.class.php類文件如下:
<?php /** Cookies class 保存,讀取,更新,清除cookies數(shù)據(jù)??稍O置前綴。強制超時。數(shù)據(jù)可以是字符串,數(shù)組,對象等。 * Date: 2013-12-22 * Author: fdipzone * Ver: 1.0 * * Func: * public set 設置cookie * public get 讀取cookie * public update 更新cookie * public clear 清除cookie * public setPrefix 設置前綴 * public setExpire 設置過期時間 * private authcode 加密/解密 * private pack 將數(shù)據(jù)打包 * private unpack 將數(shù)據(jù)解包 * private getName 獲取cookie name,增加prefix處理 */ class Cookies{ // class start private $_prefix = ''; // cookie prefix private $_securekey = 'ekOt4_Ut0f3XE-fJcpBvRFrg506jpcuJeixezgPNyALm'; // encrypt key private $_expire = 3600; // default expire /** 初始化 * @param String $prefix cookie prefix * @param int $expire 過期時間 * @param String $securekey cookie secure key */ public function __construct($prefix='', $expire=0, $securekey=''){ if(is_string($prefix) && $prefix!=''){ $this->_prefix = $prefix; } if(is_numeric($expire) && $expire>0){ $this->_expire = $expire; } if(is_string($securekey) && $securekey!=''){ $this->_securekey = $securekey; } } /** 設置cookie * @param String $name cookie name * @param mixed $value cookie value 可以是字符串,數(shù)組,對象等 * @param int $expire 過期時間 */ public function set($name, $value, $expire=0){ $cookie_name = $this->getName($name); $cookie_expire = time() + ($expire? $expire : $this->_expire); $cookie_value = $this->pack($value, $cookie_expire); $cookie_value = $this->authcode($cookie_value, 'ENCODE', $this->_securekey); if($cookie_name && $cookie_value && $cookie_expire){ setcookie($cookie_name, $cookie_value, $cookie_expire); } } /** 讀取cookie * @param String $name cookie name * @return mixed cookie value */ public function get($name){ $cookie_name = $this->getName($name); if(isset($_COOKIE[$cookie_name])){ $cookie_value = $this->authcode($_COOKIE[$cookie_name], 'DECODE', $this->_securekey); $cookie_value = $this->unpack($cookie_value); return isset($cookie_value[0])? $cookie_value[0] : null; }else{ return null; } } /** 更新cookie,只更新內(nèi)容,如需要更新過期時間請使用set方法 * @param String $name cookie name * @param mixed $value cookie value * @return boolean */ public function update($name, $value){ $cookie_name = $this->getName($name); if(isset($_COOKIE[$cookie_name])){ $old_cookie_value = $this->authcode($_COOKIE[$cookie_name], 'DECODE', $this->_securekey); $old_cookie_value = $this->unpack($old_cookie_value); if(isset($old_cookie_value[1]) && $old_cookie_vlaue[1]>0){ // 獲取之前的過期時間 $cookie_expire = $old_cookie_value[1]; // 更新數(shù)據(jù) $cookie_value = $this->pack($value, $cookie_expire); $cookie_value = $this->authcode($cookie_value, 'ENCODE', $this->_securekey); if($cookie_name && $cookie_value && $cookie_expire){ setcookie($cookie_name, $cookie_value, $cookie_expire); return true; } } } return false; } /** 清除cookie * @param String $name cookie name */ public function clear($name){ $cookie_name = $this->getName($name); setcookie($cookie_name); } /** 設置前綴 * @param String $prefix cookie prefix */ public function setPrefix($prefix){ if(is_string($prefix) && $prefix!=''){ $this->_prefix = $prefix; } } /** 設置過期時間 * @param int $expire cookie expire */ public function setExpire($expire){ if(is_numeric($expire) && $expire>0){ $this->_expire = $expire; } } /** 獲取cookie name * @param String $name * @return String */ private function getName($name){ return $this->_prefix? $this->_prefix.'_'.$name : $name; } /** pack * @param Mixed $data 數(shù)據(jù) * @param int $expire 過期時間 用于判斷 * @return */ private function pack($data, $expire){ if($data===''){ return ''; } $cookie_data = array(); $cookie_data['value'] = $data; $cookie_data['expire'] = $expire; return json_encode($cookie_data); } /** unpack * @param Mixed $data 數(shù)據(jù) * @return array(數(shù)據(jù),過期時間) */ private function unpack($data){ if($data===''){ return array('', 0); } $cookie_data = json_decode($data, true); if(isset($cookie_data['value']) && isset($cookie_data['expire'])){ if(time()<$cookie_data['expire']){ // 未過期 return array($cookie_data['value'], $cookie_data['expire']); } } return array('', 0); } /** 加密/解密數(shù)據(jù) * @param String $str 原文或密文 * @param String $operation ENCODE or DECODE * @return String 根據(jù)設置返回明文活密文 */ private function authcode($string, $operation = 'DECODE'){ $ckey_length = 4; // 隨機密鑰長度 取值 0-32; $key = $this->_securekey; $key = md5($key); $keya = md5(substr($key, 0, 16)); $keyb = md5(substr($key, 16, 16)); $keyc = $ckey_length ? ($operation == 'DECODE' ? substr($string, 0, $ckey_length): substr(md5(microtime()), -$ckey_length)) : ''; $cryptkey = $keya.md5($keya.$keyc); $key_length = strlen($cryptkey); $string = $operation == 'DECODE' ? base64_decode(substr($string, $ckey_length)) : sprintf('%010d', 0).substr(md5($string.$keyb), 0, 16).$string; $string_length = strlen($string); $result = ''; $box = range(0, 255); $rndkey = array(); for($i = 0; $i <= 255; $i++) { $rndkey[$i] = ord($cryptkey[$i % $key_length]); } for($j = $i = 0; $i < 256; $i++) { $j = ($j + $box[$i] + $rndkey[$i]) % 256; $tmp = $box[$i]; $box[$i] = $box[$j]; $box[$j] = $tmp; } for($a = $j = $i = 0; $i < $string_length; $i++) { $a = ($a + 1) % 256; $j = ($j + $box[$a]) % 256; $tmp = $box[$a]; $box[$a] = $box[$j]; $box[$j] = $tmp; $result .= chr(ord($string[$i]) ^ ($box[($box[$a] + $box[$j]) % 256])); } if($operation == 'DECODE') { if((substr($result, 0, 10) == 0 || substr($result, 0, 10) - time() > 0) && substr($result, 10, 16) == substr(md5(substr($result, 26).$keyb), 0, 16)) { return substr($result, 26); } else { return ''; } } else { return $keyc.str_replace('=', '', base64_encode($result)); } } } // class end ?>
demo.php示例程序如下:
<?php require 'Cookies.class.php'; $type = isset($_GET['type'])? strtolower($_GET['type']) : ''; if(!in_array($type, array('set','get','update','clear'))){ exit('type not exists'); } $obj = new Cookies('member', 10); // obj switch($type){ case 'set': // 設置 $data = array( 'name' => 'fdipzone', 'gender' => 'male' ); $obj->set('me', $data, 5); echo 'set cookies'; break; case 'get': // 讀取 $result = $obj->get('me'); echo '<pre class="brush:php;toolbar:false">'; print_r($result); echo ''; echo 'get cookies'; break; case 'update': // 更新 $data = array( 'name' => 'angelababy', 'gender' => 'female' ); $flag = $obj->update('me', $data); if($flag){ echo 'update cookies success'; }else{ echo 'update cookies false'; } break; case 'clear': // 清除 $obj->clear('me'); echo 'clear cookies'; break; } ?>
本文完整實例源碼點擊此處本站下載。
希望本文所述對大家的PHP程序設計有所幫助。
//?set?the?cookies
setcookie("cookie[three]",?"cookiethree");
setcookie("cookie[two]",?"cookietwo");
setcookie("cookie[one]",?"cookieone");
//?after?the?page?reloads,?print?them?out
if?(isset($_COOKIE['cookie']))?{????
foreach?($_COOKIE['cookie']?as?$name?=>?$value)?{????????
echo?"$name?:?$value?
\n";????
}
}
?>
手冊上的例子
?
【IT168 技術文檔】必須在服務器傳送任何內(nèi)容給客戶瀏覽器之前為 Cookies 賦值。要做到這一點, cookies 的設置就必須放在 cookie 的名稱,是一個字符串,例如: "CookieID" 。其間不允許有冒號,逗號和空格。這個參數(shù)是必須的,而其它的所有參數(shù)都是可選的。如果只有這一個參數(shù)被給出,那么這個 cookie 將被刪除。
cookie 的值,通常是一個字符串變量,例如: $USERID 。也可以為它賦一個 ? 來略過值的設置。
cookie 失效的時間。如果被省略(或者被賦值為零), cookie 將在這個對話期( session )結束后失效。這個參數(shù)可以是一個絕對的時間,用 DD-Mon-YY HH:MM:SS 來表示,比如: "24-Nov-99 08:26:00" 。而更常用的是設置一個相對時間。這是通過 time() 函數(shù)或者 mktime 函數(shù)來實現(xiàn)的。比如 time()+3600 將使得 cookie 在一個小時后失效。
一個路徑,用來匹配 cookie 的。當在一個服務器上有多個同名的 cookie 的設置,為避免混淆,就要用到這個參數(shù)了。使用 "/" 路徑的和省略這個參數(shù)的效果是一樣的。要注意的是 Netscape 的 cookie 定義是把域名放在路徑的前面的,而 PHP 則與之相反。
服務器的域名,也是用來匹配 cookie 的。要注意的是:在服務器的域名前必須放上一個點( . )。例如: ".friendshipcenter.com" 。因為除非有兩個以上的點存在,否者這個參數(shù)是不能被接受的。
cookie 的安全級,是一個整數(shù)。 1 表示這個 cookie 只能通過“安全”的網(wǎng)絡來傳送。 0 或者省略則表示任何類型的網(wǎng)絡都可以
?

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)

Benutzerspracheingabe wird erfasst und über die Mediarecorder-API des Front-End-JavaScript an das PHP-Backend gesendet. 2. PHP speichert das Audio als tempor?re Datei und ruft STTAPI (z. B. Google oder Baidu Voiceerkennung) auf, um sie in Text umzuwandeln. 3. PHP sendet den Text an einen KI -Dienst (wie OpenAigpt), um intelligente Antwort zu erhalten. 4. PHP ruft dann TTSAPI (wie Baidu oder Google Voice -Synthese) auf, um die Antwort in eine Sprachdatei umzuwandeln. 5. PHP streams die Sprachdatei zurück zum Spielen, um die Interaktion abzuschlie?en. Der gesamte Prozess wird von PHP dominiert, um eine nahtlose Verbindung zwischen allen Links zu gew?hrleisten.

Die Kernmethode zum Aufbau sozialer Freigabefunktionen in PHP besteht darin, dynamisch Freigabelinks zu generieren, die den Anforderungen jeder Plattform entsprechen. 1. Erhalten Sie zuerst die aktuelle Seite oder die angegebenen URL- und Artikelinformationen. 2. Verwenden Sie Urlencode, um die Parameter zu codieren. 3.. Splei? und generieren Teilenverbindungen gem?? den Protokollen jeder Plattform; 4. Zeigen Sie Links im vorderen Ende an, damit Benutzer klicken und freigeben k?nnen. 5. generieren Sie Dynamik OG -Tags auf der Seite, um die Anzeige der Freigabe inhaltlich zu optimieren. 6. Achten Sie darauf, dass Sie den Benutzereingaben entkommen, um XSS -Angriffe zu verhindern. Diese Methode erfordert keine komplexe Authentifizierung, weist nur geringe Wartungskosten auf und eignet sich für die meisten Anforderungen an den Inhaltsaustausch.

Um die Textfehlerkorrektur und die Syntaxoptimierung mit AI zu realisieren, müssen Sie die folgenden Schritte ausführen: 1. W?hlen Sie ein geeignetes AI -Modell oder ein geeignetes AI -Modell oder ein geeignetes AI -Modell wie Baidu, Tencent API oder Open Source NLP -Bibliothek aus; 2. Rufen Sie die API über die Curl oder das Guzzle von PHP auf und verarbeiten Sie die Rückgabeergebnisse. 3.. Informationen zur Fehlerkorrektur in der Anwendung anzeigen und erm?glichen den Benutzern, zu w?hlen, ob sie angenommen werden sollen. 4. Verwenden Sie PHP-L und PHP_CODESNIFFER für die Syntaxerkennung und -codeoptimierung. 5. sammeln Sie kontinuierlich Feedback und aktualisieren Sie das Modell oder die Regeln, um den Effekt zu verbessern. Konzentrieren Sie sich bei der Auswahl von AIAPI auf die Bewertung von Genauigkeit, Reaktionsgeschwindigkeit, Preis und Unterstützung für PHP. Die Codeoptimierung sollte den PSR -Spezifikationen folgen, Cache vernünftigerweise verwenden, zirkul?re Abfragen vermeiden, den Code regelm??ig überprüfen und x verwenden

1. Maximierung des kommerziellen Wertes des Kommentarsystems erfordert die Kombination der pr?zisen Lieferung native Werbung, benutzerbezahlte Wertsch?pfungsdienste (z. B. Bilder hochladen, Aufladungskommentare), den Incentive-Mechanismus basierend auf der Qualit?t der Kommentare und der Anonymen Daten Insight-Monetarisierung von Compliance; 2. Die Prüfungsstrategie sollte eine Kombination aus dynamischer Keyword-Filterung und Benutzerkennungsmechanismen vorab der Auditing einsetzen, die durch die Qualit?t der Kommentarqualit?t erg?nzt werden, um die hierarchische Inhaltsbelastung zu erreichen. 3. Die Anti-Pushing erfordert die Konstruktion einer mehrschichtigen Verteidigung: Recaptchav3 sensorlose überprüfung, Honeypot-Honeypot-Feldkennungroboter, IP und Zeitstempelfrequenzgrenze verhindert die Bew?sserung, und die Erkennung von Inhalten markiert verd?chtige Kommentare und st?ndig mit Angriffen.

PHP führt nicht direkt die KI-Image-Verarbeitung durch, sondern integriert sich über APIs, da es in der Webentwicklung und nicht in Bezug auf Computerintensive Aufgaben gut ist. Die API -Integration kann die professionelle Arbeitsteilung erreichen, die Kosten senken und die Effizienz verbessern. 2. Integration von Schlüsseltechnologien umfasst die Verwendung von Guzzle oder Curl zum Senden von HTTP-Anforderungen, JSON-Datencodierung und -decodierung, API-Schlüsselsicherheitsauthentifizierung, asynchroner Warteschlangenverarbeitungsaufgaben, robuster Fehlerbehebung und Wiederholungsmechanismus, Bildspeicherung und Anzeige. 3. Die gemeinsamen Herausforderungen sind API -Kosten au?er Kontrolle, unkontrollierbare Erzeugungsergebnisse, schlechte Benutzererfahrung, Sicherheitsrisiken und schwieriges Datenmanagement. In den Antwortstrategien werden Benutzerquoten und -darstellungen festgelegt, die Auswahl von ProPT-Anleitungen und mehrfizierende Auswahl, asynchrone Benachrichtigungen und Fortschrittsaufforderungen, wichtige Speicher- und Inhaltsprüfungen sowie Cloud-Speicher vorhanden.

PHP sorgt für die Inventarabzugsatomizit?t durch Datenbanktransaktionen und Forupdate -Reihenschl?sser, um eine hohe gleichzeitige überverl?ssigkeit zu verhindern. 2. Multi-Plattform-Inventarkonsistenz h?ngt von zentraler Verwaltung und ereignisgesteuerter Synchronisation ab, die API/Webhook-Benachrichtigungen und Nachrichtenwarteschlangen kombiniert, um eine zuverl?ssige Datenübertragung sicherzustellen. 3. Der Alarmmechanismus sollte in verschiedenen Szenarien niedrige Lagerbest?nde, Null/Negativ -Inventar, unerwünschte Verkaufszyklen, Nachschubzyklen und abnormale Schwankungsstrategien festlegen und die Auswahl von Dingtalk, SMS oder E -Mail -Verantwortlichen gem?? der Dringlichkeit ausw?hlen, und die Alarminformationen müssen vollst?ndig und frei sein, um die Anpassung und die Vergewaltigungsreaktion zu erreichen.

PhpisstillrelevantinMoDernEnterpriseEnvironments.1.ModerPhp (7.xand8.x) Angebote, strenge, jitkompilation und moderne Syntax, machte ma?geschneiderte Foreiglableforlarge-ScaleApplikationen

W?hlen Sie den entsprechenden AI -Spracherkennungsdienst und integrieren Sie PHPSDK. 2. Verwenden Sie PHP, um FFMPEG aufzurufen, um Aufzeichnungen in API-geforderte Formate (z. B. WAV) umzuwandeln. 3. Laden Sie Dateien in Cloud -Speicher hoch und rufen Sie API Asynchrone Recognition auf. 4. Analysieren Sie JSON -Ergebnisse und organisieren Sie Text mithilfe der NLP -Technologie. 5. Word- oder Markdown -Dokumente generieren, um die Automatisierung der Besprechungsunterlagen abzuschlie?en. Der gesamte Prozess muss sicherstellen, dass die Datenverschlüsselung, die Zugriffskontrolle und die Einhaltung der Datenschutz und Sicherheit gew?hrleistet sind.
