/*
* 名前: CnkknD PHP ログイン クラス
* 説明: MySQL に基づく PHP ログイン クラス
* 著者: Daniel King、cnkknd@163.com
* 日付: 2003/8/25
* /
クラスログイン
{
var $username; //パスワード
var $userid; //ユーザーレベル
var $authtable="アカウント"; /検証用データテーブル
var $usecookie=true; //セッションIDを保存するためにCookieを使用します
var $cookiepath='/' //Cookieパス
var $cookietime=108000 //Cookie有効期限
var $err_mysql; ="mysql エラー"; //mysql エラー プロンプト
var $err_username="ユーザー名が無効です"; //ユーザー名が無効ですプロンプト
var $err_user="ユーザーが無効です" //ユーザーが無効なプロンプト (禁止されています)
var $err_password= "password error"; //パスワードエラーメッセージ
var $err; //エラーメッセージ
function Login($dbserv,$dbport,$dbpass,$) dbname) //コンストラクター、データベースに接続します
{
if(@mysql_pconnect($dbserv.":".$dbport,$dbuser,$dbpass))
{
mysql_select_db($dbname);
}
else
{
$this->errReport($this->err_mysql);
$this->err=$this->err_mysql;
}
}
function isLoggedin() //ログインするかどうかを決定する
{
if(isset($_COOKIE['sid'])) //クッキーにsidが保存されている場合
{
session_id($_COOKIE['sid']);
session_start();
$this->username =$ _SESSION['username'];
$this->userid=$_SESSION['userid'];
$this->userlevel=$_SESSION['userlevel'];
return true;
}
else / /if SID が Cookie に保存されていない場合は、セッションを直接確認します
{
session_start();
if(isset($_SESSION['username']))
return true;
}
return false;
}
function userAuth($username ,$userpass) //ユーザー認証
{
$this->username=$username;
$this->userpass=$userpass;
$query="select * from `".$ this->authtable. "` where `username`='$username';";
$result=mysql_query($query);
if(mysql_num_rows($result)!=0) // このユーザーを検索します
{
$row=mysql_fetch_array($ result);
if($row['bannd']==1) //このユーザーは禁止されています
{
$this->errReport($this->err_user);
$this ->err=$ this->err_user;
return false;
}
elseif(md5($userpass)==$row['userpass']) //パスワード照合
{
$this->userid= $row['id' ];
$this->userlevel=$row['userlevel'];
return true;
}
else //パスワードが一致しません
{
$this->errReport($this ->err_password);
$this->err=$this->err_password;
return false;
}
}
else //このユーザーは見つかりませんでした
{
$this->errReport($this ->err_username);
$ this->err=$this->err_username;
return false;
}
}
function setSession() //セッションを設定します
{
$sid=uniqid('sid' ); // sid
session_id ($sid);
session_start();
$_SESSION['username']=$this->username; // セッション変数に値を代入します
$_SESSION['userid' ]=$this->userid; // ..
$_SESSION['userlevel']=$this->userlevel; // ..
if($this->use_cookie) // Cookie を使用する場合sid を保存
{
if(!setcookie('sid' ,$sid,time()+$this->cookietime,$this->cookiepath))
$this->errReport("cookie の設定に失敗しました") ;
}
else
setcookie('sid',' ',time()-3600); //Cookie の sid をクリアします
}
関数 userLogout() //ユーザーログアウト
{
session_start();
unset($_SESSION['username']); //セッション内のユーザー名をクリアします
if(setcookie('sid','',time()-3600))
//Cookie 内の sid をクリアします
return true;
else
return false;
}
function errReport($str ) //エラーレポート
{
if($this->error_report)
echo "ERROR: $str";
}
}
?> の構造mysql のテーブル
コード:
CREATE TABLE `account` (
`id` bigint(20) NOT NULL auto_increment,
`username` varchar(255) NOT NULL
例を使用してください
PHP コード:
< ;?
include "../myclasses/Login.php";
$dbserv="localhost";
$dbport="3306";
$dbuser="root";
$dbpass="123456";
$dbname ="テスト";