从此不求人:自主研发一套PHP前端开发框架(20-2)

这节我们来用到登陆上(cookie处理)

目前我们用户登陆的处理
1.加载UserModel,并对相应的项进行赋值
2.json_encode 这个UserModel,并且保存到cookie中
3.下次取出cookie内容后进行json_decode

<?php function load_db(){ $db_path=LKPHP_PATH.'/Libary/DataBase/myDataBase.php'; if(!class_exists('myDataBase')){ require($db_path); } return new MyDataBase(); } function load_model($modelName){ $_Model_Path = LKPHP_PATH.'/MVC/Model/_Model.inc';//基类Model if(!class_exists('_Model')){ require($_Model_Path); } $_mdPath = LKPHP_PATH.'/MVC/Model/'.$modelName.'.inc';//基类Model if(!class_exists($modelName)){ require($_mdPath); } return new $modelName(); } //加载虚拟类 function load_class($class){ $classPath = LKPHP_PATH.'/Libary/Class/myClass.php'; if(!class_exists('myClass')){ require($classPath); } return new myClass($class); } // the_XXX系列 /* * 获取get参数 * 当$ispost是true是代表获取post参数 默认是false */ function the_get($get_key,$ispost=false) { $parameters=$ispost?$_POST:$_GET; if(!isset($parameters[$get_key])) return ""; $str=$parameters[$get_key]; //过滤危险字符、敏感字符通用函数 //第一步:通过正则过滤掉我需要过滤的标记 $farr = array( "/<(\/?)(script|i?frame|style|html|body|title|link|meta|\?|\%)([^>]*?)>/isU"); //过滤类似 <script> <style> <object> <meta 等 $str = preg_replace($farr,"",$str); $str=addslashes($str); //对单引号、双引号等预定义字符 前面加上反斜杠 如'变成\' //第二步 过滤敏感词汇 $str=str_replace(explode(",", LKPHP_UNSAFEWORDS),"***",$str); return trim($str); } /* * 获取当前用户的IP地址,无参数 */ function the_ip() { if (getenv("HTTP_CLIENT_IP") && strcasecmp(getenv("HTTP_CLIENT_IP"), "unknown")) $ip = getenv("HTTP_CLIENT_IP"); else if (getenv("HTTP_X_FORWARDED_FOR") && strcasecmp(getenv("HTTP_X_FORWARDED_FOR"), "unknown")) $ip = getenv("HTTP_X_FORWARDED_FOR"); else if (getenv("REMOTE_ADDR") && strcasecmp(getenv("REMOTE_ADDR"), "unknown")) $ip = getenv("REMOTE_ADDR"); else if (isset ($_SERVER['REMOTE_ADDR']) && $_SERVER['REMOTE_ADDR'] && strcasecmp($_SERVER['REMOTE_ADDR'], "unknown")) $ip = $_SERVER['REMOTE_ADDR']; else $ip = "unknown"; return ($ip); } /* * 获取当前登录用户 * 返回值是个model 如果用户没有登录则返回false */ function the_user() { //可以使用cookie 也可以使用session $md = json_decode(myDecrypt($_COOKIE[LKPHP_USERCOOKIE],LKPHP_DESKEY)); return isset($_COOKIE[LKPHP_USERCOOKIE])?$md :false; } //根据cacheKey或来获得缓存内容 function the_cache($cacheKey) { //这里我们使用memcached return false; } ?>
<?php //is_XX系列 如判断用户是否登录 字符串格式 /* * 判断用户是否登录 */ function is_login() { //用户是否登录 if(the_user()) return true; return false; } //判断字符串是否符合email格式  function is_email($email) { return ereg("/^[a-z]([a-z0-9]*[-_\.]?[a-z0-9]+)*@([a-z0-9]*[-_]?[a-z0-9]+)+[\.][a-z]{2,3}([\.][a-z]{2})?$/i",$email); } ?>
<?php //set_XX系列,譬如更新缓存或者更新一个model //更新缓存 function set_cache($cacheKey) { } //更新一个model function set_model($model) { } //设置当前登录用户 function set_user($md,$time){ if($time<0){ //代表注销 setcookie(LKPHP_USERCOOKIE,'',time()-3600,'/'); }else{ //代表登录成功 $md = myCrypt(json_encode($md),LKPHP_DESKEY); setcookie(LKPHP_USERCOOKIE,$md,time()+$time,'/');//对对象进行json编码 } } function pkcs5_pad ($text, $blocksize) { //加密时的字节填充,保持和java 一致 $pad = $blocksize - (strlen($text) % $blocksize); return $text . str_repeat(chr($pad), $pad); } function myCrypt($input,$key) //加密 { $size = mcrypt_get_block_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_ECB); $input =pkcs5_pad($input, $size); $td = mcrypt_module_open(MCRYPT_RIJNDAEL_128, '', MCRYPT_MODE_ECB, ''); $iv = mcrypt_create_iv (mcrypt_enc_get_iv_size($td), MCRYPT_RAND); mcrypt_generic_init($td, $key, $iv); $data = mcrypt_generic($td, $input); mcrypt_generic_deinit($td); mcrypt_module_close($td); $data = base64_encode($data); return $data; } function myDecrypt($str,$key) //解密 { $decrypted= mcrypt_decrypt( MCRYPT_RIJNDAEL_128, $key, base64_decode($str), MCRYPT_MODE_ECB ); $dec_s = strlen($decrypted); $padding = ord($decrypted[$dec_s-1]); $decrypted = substr($decrypted, 0, -$padding); return $decrypted; } ?>

你可能感兴趣的:(从此不求人:自主研发一套PHP前端开发框架(20-2))