我可能會在這裏丟失一些東西,我不確定。谷歌搜索也沒有真正幫助。如何在另一個類中創建一個類的實例
我想要做的就是調用databaseServer類,並在我的userControl類中使用它的方法。這裏是我的lib_class.php文件:
<?php
include('definitions.php');
class databaseServer {
var $con;
var $db;
var $close;
var $qry;
var $sql;
function connect($host,$user,$pw,$db) {
$this->con = mysql_connect($host,$user,$pw);
if (!$this->con) {
die('Could not connect: ' . mysql_error());
}
else {
echo "Database Connected";
}
$this->selectDb($db);
}
function selectDb($database) {
$this->db = mysql_select_db($database,$this->con);
if (!$this->db) {
echo "Could not Select database";
}
else {
echo "Database Selected";
}
}
function disconnect() {
$this->close = mysql_close($this->con);
if ($this->close) {
echo "Disconnected";
}
}
function query($test) {
if (!mysql_query($test)) {
die("Error: " . mysql_error());
}
}
} // databaseServer
class cookie {
var $expireTime;
function set($name,$value,$expiry) {
$this->expireTime = time()+60*60*24*$expiry;
setcookie($name,$value,$expireTime);
}
function delete($name) {
setcookie($name,"",time()-3600);
}
function check($name) {
if (isset($_COOKIE["$name"]))
echo "Cookie Set";
else
echo "Cookie failed";
}
} //cookie
class userControl {
public function __construct(databaseServer $server) {
$this->server = new databaseServer();
}
function createUser($uname,$pword) {
$this->server->connect(DB_HOST,DB_USER,DB_PASS,DB_NAME);
$result = $this->server->query("SELECT * FROM user_list WHERE uname='" . $this->server->real_escape_string($uname) . "'");
if ($this->result->num_rows() === 0) {
if ($this->server->query("INSERT INTO user_list (uname, pword)
VALUES ('" . $this->server->real_escape_string($uname) . "','" . $this->server->real_escape_string($pword) . "')") {
echo "User Added Successfully!";
}
else {
echo "Error Adding User!";
}
}
else {
echo "User Already Exists!";
}
} // createUser
} // userControl
?>
但是,這是行不通的,我不明白爲什麼。當我從文件中省略userControl類時,我的databaseServer和cookie類正常工作,所以我知道錯誤必須在某個地方。 OOP是我試圖學習的東西,我一直在磕磕絆絆。
databaseServer類中的回聲僅供我測試。我在index.php文件執行類如下:
<?php
include('definitions.php');
include('class_lib.php');
$bmazed = new databaseServer();
$bmazed->connect(DB_HOST,DB_USER,DB_PASS,DB_NAME);
$sql = "INSERT INTO blah
VALUES ('testing 92')";
$bmazed->query($sql);
$bmazed->disconnect();
// $control = new userControl();
// $uname = "Test1";
// $pword = "test1";
// $control->createUser($uname,$pword);
echo "<br />";
echo "<br />";
?>
線已註釋掉用於測試目的,所以我不必不斷重新編寫代碼。
我真的不知道問題出在哪裏,我檢查過語法,看起來一切正常。
我試過所有建議的答案,但他們都沒有看到腳本工作。我編輯了原始問題以顯示更多我的代碼。如前所述,代碼純粹是爲了測試目的,所以在那裏有一些奇怪的東西,如看似隨機的回聲。 – 2010-08-19 17:45:32
@Saladin運行'php -l lib_class.php',你會發現它抱怨在你執行'INSERT'的'if'塊中意外的'{'和'else'。那是因爲你在這個if塊上丟失了關閉''''。在開發代碼時,確保你啓用了'error_reporting'和'display_errors'。 – Gordon 2010-08-19 18:22:33