摘要:目录初探用启动一个内存的妙用终于可以啦初级应用实现用户登录撰写中展望的局限性分析及我个人的期待撰写中回顾上节内存的妙用终于可以啦中我们了解了的数据库操作这节我们用来做演示开搞环境说明框架首先我们来做个用户登录页面代码我们
目录
初探 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; });
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/21838.html
摘要:本项目见这是一个初级练手的小项目该项目功能简单,主要实现监测币市行情变化达到预警效果的功能,大致的使用场景如下用户登录服务用户设置关注的币种及预警的走势价格当行情变化触发到用户的预警设置时,服务将自动发送提醒邮件通知用户整体功能简明,通过这 showImg(https://segmentfault.com/img/bVbm8he?w=260&h=278);本项目见GITHUB:mark...
摘要:当我们的用户进行系统登录时,用户名和密码的验证都是后端验证的。比如头部的登录按钮,在未登录状态是显示登录按钮,在登录后显示用户名和头像,这些都是判断是否有这个值具体实现里,相对来说更复杂一些。 当我们的用户进行系统登录时,用户名和密码的验证都是后端验证的。而且,用户登录状态也是要后端设置的,查询数据库后,用户名和密码正确,则在session中存储一个uuid,每个页面需要根据登录状态判...
摘要:前端最基础的就是。的原理浏览器发送请求,服务器给出响应。保持之前的界面不变化。的核心创建一个对象,用于发起请求设置为请求,请求发送请求。 前端最基础的就是 HTML+CSS+Javascript。掌握了这三门技术就算入门,但也仅仅是入门,现在前端开发的定义已经远远不止这些。前端小课堂(HTML/CSS/JS),本着提升技术水平,打牢基础知识的中心思想,我们开课啦(每周四)。 ajax ...
阅读 3356·2023-04-26 03:05
阅读 1466·2019-08-30 13:09
阅读 1913·2019-08-30 13:05
阅读 889·2019-08-29 12:42
阅读 1388·2019-08-28 18:18
阅读 3450·2019-08-28 18:09
阅读 519·2019-08-28 18:00
阅读 1720·2019-08-26 12:10