摘要:目錄初探用啟動一個內存的妙用終于可以啦初級應用實現用戶登錄撰寫中展望的局限性分析及我個人的期待撰寫中回顧上節內存的妙用終于可以啦中我們了解了的數據庫操作這節我們用來做演示開搞環境說明框架首先我們來做個用戶登錄頁面代碼我們
目錄
初探 Swoole -- 用 Swoole 啟動一個 hello world
內存的妙用 -- PHP終于可以 vs JAVA啦
初級應用 -- 實現用戶登錄 [撰寫中]
展望 -- Swoole 的局限性分析及我個人的期待 [撰寫中]
上節內存的妙用 -- PHP終于可以 vs JAVA啦中, 我們了解了 Swoole 的MYSQL數據庫 CURD 操作, 這節我們用 MongoDB來做演示.
開搞環境說明:
MacOS X El Captain 10.11.6
PHP 7.0.8 with MongoDB support
MongoDB 1.1.8
CSS框架 Bootstrap3
首先, 我們來做個用戶登錄頁面
/tpl/login.html
Login
PHP代碼
我們引入MongoDB
selectDatabase($dbname); self::$dbname = $dbname; } return self::$db; } public static function id($id){ return new MongoDBBSONObjectID($id); } public function __call($name, $arguments){ return self::$db->selectCollection(self::$dbname, $name); } }
Swoole啟動代碼
_GLOBAL_SESSION = []; $http->mongo = Mongo::instance("db"); $http->db = new stdClass(); # 使用預加載, 提前將用戶數據加載到內存. 登錄都無需網絡/磁盤IO if("user"){ echo "加載用戶數據 "; $http->db->user = []; $users = $http->mongo->user->find([]); foreach ($users as $i => $user) { $user["_id"] = $user["_id"]->__toString(); $http->db->user[$user["username"]] = $user; } echo "用戶數據加載完成 "; unset($user);unset($users); }
主邏輯:
on("request", function(swoole_http_request $req, swoole_http_response $res) use($http) { if (!isset($req->cookie) || !isset($req->cookie["sid"]) || !$req->cookie["sid"]) { $req->cookie["sid"] = md5(password_hash(time().mt_rand(100000, 999999), 1)); $res->cookie("sid", $req->cookie["sid"], time() + 60 * 60 * 24 * 365 * 10, "/", "", false, true); } $_SESS_ID = $req->cookie["sid"]; if (!is_array($http->_GLOBAL_SESSION[ $_SESS_ID ])) $http->_GLOBAL_SESSION[ $_SESS_ID ] = []; $_SESSION = &$http->_GLOBAL_SESSION[ $_SESS_ID ]; if ( $req->server["request_uri"] == "/" ) { $res->status(302); $res->header("Location", "/login/"); $res->end(); return; }else if ( $req->server["request_uri"] == "/login/" ) { if ($_SESSION["user"]) { $res->status(302); $res->header("Location", "/i/"); $res->end(); return; } $html = file_get_contents(dirname(__FILE__)."/tpl/"."login.html"); $res->write($html); $res->end(); unset($html); return; }else if ( $req->server["request_uri"] == "/dologin/" ) { $user = $http->db->user[$req->post["username"]]; if (!$user || !password_verify($req->post["password"], $user["password"])) { $res->write("bad_account_or_password"); $res->end(); return; } $_SESSION["user"] = $user; unset($user); $res->status(302); $res->header("Location", "/vul/"); $res->end(); return; }else if ( $req->server["request_uri"] == "/i/" ) { $res->write("You currently logged in as".$_SESSION["user"]["username"]); $res->end(); return; } $res->status(404); $res->end(); return; });
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/21838.html
摘要:本項目見這是一個初級練手的小項目該項目功能簡單,主要實現監測幣市行情變化達到預警效果的功能,大致的使用場景如下用戶登錄服務用戶設置關注的幣種及預警的走勢價格當行情變化觸發到用戶的預警設置時,服務將自動發送提醒郵件通知用戶整體功能簡明,通過這 showImg(https://segmentfault.com/img/bVbm8he?w=260&h=278);本項目見GITHUB:mark...
摘要:當我們的用戶進行系統登錄時,用戶名和密碼的驗證都是后端驗證的。比如頭部的登錄按鈕,在未登錄狀態是顯示登錄按鈕,在登錄后顯示用戶名和頭像,這些都是判斷是否有這個值具體實現里,相對來說更復雜一些。 當我們的用戶進行系統登錄時,用戶名和密碼的驗證都是后端驗證的。而且,用戶登錄狀態也是要后端設置的,查詢數據庫后,用戶名和密碼正確,則在session中存儲一個uuid,每個頁面需要根據登錄狀態判...
摘要:前端最基礎的就是。的原理瀏覽器發送請求,服務器給出響應。保持之前的界面不變化。的核心創建一個對象,用于發起請求設置為請求,請求發送請求。 前端最基礎的就是 HTML+CSS+Javascript。掌握了這三門技術就算入門,但也僅僅是入門,現在前端開發的定義已經遠遠不止這些。前端小課堂(HTML/CSS/JS),本著提升技術水平,打牢基礎知識的中心思想,我們開課啦(每周四)。 ajax ...
閱讀 3338·2023-04-26 03:05
閱讀 1459·2019-08-30 13:09
閱讀 1908·2019-08-30 13:05
閱讀 887·2019-08-29 12:42
閱讀 1385·2019-08-28 18:18
閱讀 3447·2019-08-28 18:09
閱讀 513·2019-08-28 18:00
閱讀 1713·2019-08-26 12:10