標籤:efi fine 判斷 首頁 index.php lin style table keyword
登陸功能是PHP程式設計中常見的功能。本文ThinkPHP執行個體主要完成註冊成功後進入首頁,並告訴你是登入使用者的功能。具體實現步驟如下:
第一步:在config.php檔案中加上:
| 1 |
‘USER_AUTH_KEY‘=>‘authId‘ |
樣本如下:
| 1234567891011121314 |
<?phpif(!defined(‘THINK_PATH‘)) exit();return array(// 定義資料庫連接資訊‘DB_TYPE‘=> ‘mysql‘,// 指定資料庫是mysql‘DB_HOST‘=> ‘localhost‘,‘DB_NAME‘=>‘myuser‘, // 資料庫名‘DB_USER‘=>‘root‘,‘DB_PWD‘=>‘‘, //您的資料庫連接密碼‘DB_PORT‘=>‘3306‘,‘DB_PREFIX‘=>‘think_‘,//資料表首碼‘USER_AUTH_KEY‘=>‘authId‘);?> |
第二步:在AdminAction.class.php中的insert()代碼中用:
| 1 |
Session::set(C(‘USER_AUTH_KEY‘),$user); |
儲存登入使用者名稱到session。
完整實現代碼如下:
| 123456789101112131415161718 |
public function insert(){header(‘Content-Type:text/html; charset=utf-8‘);//防止出現亂碼$user=$_POST[‘user‘];$this->verifyCheck();$Pagemodel = D("user");$vo = $Pagemodel->create(); if(false === $vo) die($Pagemodel->getError());$topicid = $Pagemodel->add(); //add方法會返回新添加的記錄的主索引值if($topicid){//$_SESSION[C(‘USER_AUTH_KEY‘)]=$user;//不能用此句Session::set(C(‘USER_AUTH_KEY‘),$user);//dump(Session::get(‘authId‘)); echo "<script>alert(‘資料庫添加成功‘);location.href=‘http://127.0.0.1/zhuce/index.php/index‘;</script>";}else throw_exception("<script>alert(‘資料庫添加失敗‘);history.back();</script>");} |
第三步:在IndexAction.class.php檔案中用if(!Session::is_set(C(‘USER_AUTH_KEY‘)))判斷使用者登入了沒有。
Session::get(C(‘USER_AUTH_KEY‘))是擷取登入使用者的名。
具體代碼如下:
| 1234567891011121314 |
public function index(){if(!Session::is_set(C(‘USER_AUTH_KEY‘)))//if(!isset($_SESSION[‘USER_AUTH_KEY‘])||($_SESSION[‘USER_AUTH_KEY‘]==0))//不能用此句{$msg="使用者沒有登入"; }else{$msg=Session::get(C(‘USER_AUTH_KEY‘)).‘歡迎你回來‘;}$this->assign(‘msg‘,$msg);$this->display(); } |
第四步:首頁顯示模板,代碼如下:
| 1234 |
<body>{$msg}<br />這是我的首頁</body> |
小結:
登入代碼都是圍繞寫session,判斷session,讀session展開。
寫session用:Session::set(C(‘USER_AUTH_KEY‘),$user);
判斷session用:if(!Session::is_set(C(‘USER_AUTH_KEY‘)));
讀session用:Session::get(C(‘USER_AUTH_KEY‘))
上述就是ThinkPHP登入功能的實現方法全部內容。
--------------------------------------------------------------------------------------------------Deng
鄧_ ThinkPhp