我是一个新手程序员,我很困惑。我正在编写一个简单的代码,它从mysql db获取一些数据并将其发布在我的CMS(umi cms)网页上。问题是cms希望我将这段代码放入自定义模块(.php文件,其中包含我需要在其中创建函数的新类)。我做到了,但它看起来并不优雅,因为我想使数据库连接变量成为类全局且安全的。将来我将在这里编写更多使用数据库连接的函数。这是我的模块类文件和底部 lib() 和 getlib() 中的 2 个函数。你有什么建议?不知何故只返回方法以在目标div 中输出数据
class modulelements extends def_module {
public $per_page;
public function __construct() {
parent::__construct();
//module default code
}
//module default functions
// here are my functions: ))
public function lib ($template = "default", $per_page = false) {
$begin = "<table>
<tr>
<td>Название</td>
<td>Автор</td>
<td>Год</td>
<td>Число экземпляров</td>
<td>Выдано</td>
</tr> " . $this->getlib() ;
$stop = mysqli_close($conn) . "</table>" ;
return $begin . $stop ;
}
public function getlib() {
$servername = "server";
$username = "name";
$password = "pass";
$dbname = "jum";
$conn = mysqli_connect($servername, $username, $password, $dbname);
$sql = "SELECT name, author, year, number, towhom FROM lib";
$conn->set_charset("utf8");
$result = mysqli_query($conn, $sql);
$stop = mysqli_close($conn) ;
// Check connection
if (!$conn) {
die("Connection failed: " . mysqli_connect_error());
}
$outlib = Array();
if (mysqli_num_rows($result) > 0) {
// output data of each row into a string
while($row = mysqli_fetch_assoc($result)) {
$outlib[] = "<tr>
<td> ". $row["name"] . " </td>
<td>". $row["author"]. "</td>
<td> ". $row["year"] ."</td>
<td>". $row["number"]. "</td>
<td>". $row["towhom"]. "</td>
</tr> " ;
}
$string=implode("",$outlib);
return $string;
} else {
return "0 results";
}
}
};
要使变量在类中的任何位置都可以访问,只需在函数外部定义它们即可。如果您不希望在课程之外访问它们,则可以将它们设为私有:
class modulelements extends def_module {
private $servername = "server";
private $username = "name";
private $password = "pass";
private $dbname = "jum";
}
然后,您可以使用此值访问类中的任何位置,例如。
$this->servername
如果它们对于类的所有实例都相同,则可以使用类常量:
const SERVERNAME = "server";
然后,您可以使用 self:
self::SERVERNAME;
你可以
把这些变量$servername
、$username
、$password
和$dbname
常量。
文件中包含以下代码,假设database_config.php
并在必要时需要它:
<?php
define("SERVERNAME", "server");
define("USERNAME", "name");
define("PASSWORD", "pass");
define("DBNAME", "jum");
然后你可以像这样使用它们:
<?php
require 'database_config.php';
$conn = mysqli_connect(SERVERNAME, USERNAME, PASSWORD, DBNAME);
乐
摘自 php.net 恒定手册的网站:
像超全局变量一样,常量的范围是全局的。您可以访问 脚本中任意位置的常量,而不考虑范围。
您可以在类中将它们定义为常量:
class foo {
const servername = "server";
....
//Or retrieve them by a function
function getServername() { return self::servername; }
}
并在任何地方使用它们:
$fooObject = new foo();
$server = $fooObject::servername;
$server = $fooObject->getServername();
更多信息: php.net