摘要:加密解密類由于開始廢棄傳統的加密函數而改用,因此該類支持的版本為簡易加解密類通用秘鑰所有可用的加密類型可參考構造函數加密類型。
加密解密類
由于 PHP7.1 開始廢棄傳統的加密函數 mcrypt_encrypt 而改用 openssl_encrypt,因此該類支持的 PHP 版本為: (PHP 5 >= 5.3.0, PHP 7)
METHOD = $method; } } /** * 加密字符串 * * @param String 待加密數據 * @param string 加密秘鑰,若為空,則使用通用秘鑰 * @return void */ public function encrypt($input, $key = "") { if (empty($key)) $key = $this->KEY; $data = openssl_encrypt($input, $this->METHOD, $key, OPENSSL_RAW_DATA); $data = base64_encode($data); return $data; } /** * 解密字符串 * * @param String 待解密字符串 * @param string 解密秘鑰,若為空,則使用通用秘鑰 * @return void */ public function decrypt($input, $key = "") { if (empty($key)) $key = $this->KEY; $data = openssl_decrypt(base64_decode($input), $this->METHOD, $key, OPENSSL_RAW_DATA); return $data; } }發送郵件類
先下載 PHPMailer,解壓后,將其放置你的項目中,并修改類中的引入路徑。
_init(); $this->_baseURL = $_SERVER["REQUEST_SCHEME"] . "://" . $_SERVER["HTTP_HOST"]; } private function _init() { if ($this->_email == null) { $mail = new PHPMailer(true); try { $mail->SMTPDebug = 0; $mail->isSMTP(); $mail->Host = get_global_config("mail.Host"); $mail->SMTPAuth = true; $mail->Username = get_global_config("mail.Username"); $mail->Password = get_global_config("mail.Password"); $mail->SMTPSecure = get_global_config("mail.SMTPSecure"); $mail->Port = get_global_config("mail.Port"); $mail->setFrom(get_global_config("mail.Username"), get_global_config("mail.Fromname")); $this->_email = $mail; return true; } catch (Exception $e) { // return null; return false; } } return true; } public function sendEmail($toEmail, $toUsername, $subject, $body) { if (!$this->_email) return false; try { $this->_email->addAddress($toEmail, $toUsername); $this->_email->isHTML(true); $this->_email->Subject = $subject; $this->_email->Body = $body; // 當郵件不支持 HTML 時顯示的郵件內容 $this->_email->AltBody = $body; $this->_email->send(); // echo "Message has been sent"; return true; } catch (Exception $e) { return false; // echo "Message could not be sent."; // echo "Mailer Error: " . $this->_email->ErrorInfo; } } }模擬鎖
使用 Redis 模擬進程鎖,參考至 discuz 的進程鎖源碼。
cache = Roc::redis(); $this->cache->select(Roc::get("redis.db")); } /** * 是否被鎖 * * @param string 鎖名 * @param integer 上鎖時間 * @return boolean */ public function islocked($process, $ttl = 0) { $ttl = $ttl < 1 ? 600 : intval($ttl); return $this->_status("get", $process) || $this->_find($process, $ttl); } /** * 解鎖 * * @param string 鎖名 * @return void */ public function unlock($process) { $this->_status("rm", $process); $this->_cmd("rm", $process); } private function _status($action, $process) { static $plist = array(); switch ($action) { case "set" : $plist[$process] = true; break; case "get" : return !empty($plist[$process]); break; case "rm" : $plist[$process] = null; break; case "clear" : $plist = array(); break; } return true; } private function _find($name, $ttl) { if(!$this->_cmd("get", $name)) { $this->_cmd("set", $name, $ttl); $ret = false; } else { $ret = true; } // $this->_status("set", $name); return $ret; } private function _cmd($cmd, $name, $ttl = 0) { return $this->_process_cmd_memory($cmd, $name, $ttl); // static $allowmem; // if($allowmem === null) { // $allowmem = Roc::get("redis.db"); // } // if($allowmem) { // return self::_process_cmd_memory($cmd, $name, $ttl); // } else { // return false; // // return self::_process_cmd_db($cmd, $name, $ttl); // } } private function _process_cmd_memory($cmd, $name, $ttl = 0) { $ret = ""; $name = "process_lock_".$name; switch ($cmd) { case "set" : $ret = $this->cache->setex($name, time(), $ttl); // $ret = memory("set", "process_lock_".$name, time(), $ttl); break; case "get" : $ret = $this->cache->get($name); // $ret = memory("get", "process_lock_".$name); break; case "rm" : $ret = $this->cache->delete($name); // $ret = memory("rm", "process_lock_".$name); } echo $cmd . ":"; var_dump($ret); return $ret; } private function _process_cmd_db($cmd, $name, $ttl = 0) { $ret = ""; switch ($cmd) { case "set": $ret = C::t("common_process")->insert(array("processid" => $name, "expiry" => time() + $ttl), FALSE, true); break; case "get": $ret = C::t("common_process")->fetch($name); if(empty($ret) || $ret["expiry"] < time()) { $ret = false; } else { $ret = true; } break; case "rm": $ret = C::t("common_process")->delete_process($name, time()); break; } return $ret; } }Redis
一個簡易的 Redis 操作類,支持在查找不到緩存時,進行相對應的回調操作。
cache = new Redis(); } // ============= String 操作 /** * 設置緩存 * * @param String 緩存key值 * @param String/Object 緩存數據,可為字符串可為數組。 * @param Int 過期時間 * @return Boolean */ public function set($key, $value, $ttl = null) { if (is_array($value)) $value = serialize($value); if ($ttl !== null && $ttl > 0) return $this->cache->setex($this->_key($key), $ttl, $value); else return $this->cache->set($this->_key($key), $value); } /** * 獲取緩存數據 * * @param String 值 * @param Data 默認值,設置后,如果緩存沒有數據則返回默認值 * @return Data */ public function get($key, $callback = false) { $res = $this->cache->get($this->_key($key)); if ($res === false && $callback === true) { $method_name = "_$key"; if (method_exists($this, $method_name)) { return $this->$method_name(); } else { return false; } } // 如果反序列化成功,則返回反序列化的數據。 // @防止報 warning。 if (@unserialize($res) !== false) return unserialize($res); return $res; } /** * 刪除緩存 * * @param String 需要刪除的鍵名 * @return true or false */ public function rm($key) { return $this->cache->delete($this->_key($key)); } public function inc($key, $step = 1) { return $this->cache->incr($this->_key($key), $step); } public function dec($key, $step = 1) { return $this->cache->decr($this->_key($key), $step); } private function _key($key) { return $this->prefix . $key; } public function getMultiple($keys) { $_keys = []; foreach ($keys as $key) $_keys[] = $this->_key($key); return $this->cache->getMultiple($_keys); } // ============== Hash 操作 public function hset($hash, $key, $value) { return $this->cache->hSet($hash, $key, $value); } public function hget($hash, $key) { return $this->cache->hGet($hash, $key); } public function hgetall($hash) { return $this->cache->hGetAll($hash); } public function hvals($hash) { return $this->cache->hVals($hash); } public function hkeys($hash) { return $this->cache->hKeys($hash); } // ================ 通用回調 // Your callback code here. }
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/26208.html
摘要:請求未通過的驗證時會拋出此異常。異常處理是非常重要但又容易讓開發者忽略的功能,這篇文章簡單解釋了內部異常處理的機制以及擴展異常處理的方式方法。 異常處理是編程中十分重要但也最容易被人忽視的語言特性,它為開發者提供了處理程序運行時錯誤的機制,對于程序設計來說正確的異常處理能夠防止泄露程序自身細節給用戶,給開發者提供完整的錯誤回溯堆棧,同時也能提高程序的健壯性。 這篇文章我們來簡單梳理一下...
摘要:介紹下一個新項目,后端該如何從零去搭建。我們先假設這個項目由兩部組成提供給站點使用的提供給運營人員使用的管理后臺。因此通過回顧,我們得出我們的后端項目需要一個的層次,來存放業務邏輯。 這是 后端開發者從零做一個移動應用 的后端部分第二篇。介紹下一個新項目,后端該如何從零去搭建。我們先假設這個項目由兩部組成 提供給wap站點、app使用的api; 提供給運營人員使用的管理后臺。 整個...
摘要:,跨站腳本攻擊。實際發的請求就是,用于表示這是一個請求。,用于告知服務器根據這個參數獲取回調函數的名稱,通常約定就叫。,回調函數的名稱,也是前面參數的值,可省略,會自動生成。 本次課程主要圍繞 PHP 面試和筆試中經常會出現的一些知識點,但是面試官會在筆試題基礎上深入擴展,那么你知道如何更好的回答讓面試官滿意嗎?題目收集自騰訊,迅雷,美圖等公司的筆試面試題,以及本人面試經歷中印象中的知...
摘要:入門,第一個這是一門很新的語言,年前后正式公布,算起來是比較年輕的編程語言了,更重要的是它是面向程序員的函數式編程語言,它的代碼運行在之上。它通過編輯類工具,帶來了先進的編輯體驗,增強了語言服務。 showImg(https://segmentfault.com/img/bV1xdq?w=900&h=385); 新的一年不知不覺已經到來了,總結過去的 2017,相信小伙們一定有很多收獲...
閱讀 2950·2021-11-23 09:51
閱讀 3776·2021-11-22 15:29
閱讀 3226·2021-10-08 10:05
閱讀 1552·2021-09-22 15:20
閱讀 952·2019-08-30 15:56
閱讀 1069·2019-08-30 15:54
閱讀 732·2019-08-26 11:54
閱讀 2635·2019-08-26 11:32