我有一个类文件,并在类文件中有一些代码。 如何跨多个页面共享代码。 该代码解决了在使用预准备语句
时使用获取结果集的问题代码是这样的。如何重用函数mps_fetch_assoc。我只想在一个地方使用代码。
<?php
//http://localhost:8080/altenaontw/index.php?-action=showclient
class actions_showclient
{
// find here http://www.meetup.com/austinphp/messages/boards/thread/2022681
private function mps_fetch_assoc(&$stmt)
{
$meta = $stmt->result_metadata();
$retval[] = &$stmt;
$tmp;
$names;
while ($field = $meta->fetch_field())
{
$names[] = $field->name;
}
$tmp = $names;
for ($c = 0; $c < count($names); $c++)
{
$retval[] = &$tmp[$c];
}
call_user_func_array("mysqli_stmt_bind_result", $retval);
if ($stmt->fetch())
{
$assoc_array;
for ($c = 0; $c < count($names); $c++)
{
$assoc_array[$names[$c]] = $retval[$c + 1];
}
return $assoc_array;
}
else
{
return FALSE;
}
}
function handle($params)
{
header('Content-type: text/json; charset="UTF-8"');
$user = Dataface_AuthenticationTool::getInstance()->getLoggedInUser();
if (!$user)
{
return Dataface_Error::permissionDenied("U heeft geen toegang tot deze actie.");
}
$db = Dataface_Application::getInstance()->_conf['_database'];
echo ($db['host']);
//$mysqli = new mysqli($db['host'], $db['user'], "", $db['name']);
$mysqli = mysqli_connect($db['host'], $db['user'], "", $db['name']);
/* check connection */
if ($mysqli->connect_errno)
{
printf("Connect failed: %s\n", $mysqli->connect_error);
exit();
}
$sql = 'SELECT * from client';
$stmt = $mysqli->prepare($sql);
if ($stmt)
{
$result = $stmt->execute();
if (!$result)
{
echo "[" . json_encode(array('dberror' => 'db_error:' . mysql_error())) . "]";
return;
}
$rows = array();
while ($row = $this->mps_fetch_assoc($stmt))
{
$rows[] = $row;
}
print json_encode($rows);
$mysqli->close();
}
}
}
?>
答案 0 :(得分:0)
你必须使用include()。看这里: phpnet include()
答案 1 :(得分:0)
您应该使用<?php include 'name_of_file.php'; ?>
答案 2 :(得分:0)
您应该在要使用该类的任何页面中包含您的类文件。您可以通过以下方式执行此操作:
<?php include 'file_to_include.php'; ?>
之后,无论何时计划调用函数而不创建新对象,您都应该执行以下操作:
<?php actions_showclient::mps_fetch_assoc($variable); ?>
如果你要添加&#34; __构造&#34;您可以通过不同的方式调用该功能,但我建议您尝试在www.codeacademy.com上学习一些课程。他们将教你使用类的基础知识。
此外,请确保您希望自己的功能隐私,因为这会对您何时能够调用它产生一定影响(请查看此信息以获取更多信息:What is the difference between public, private, and protected?)。
祝你好运!答案 3 :(得分:0)
这样做的另一个好方法可能是类自动加载,在一个文件中保存了许多include()以使一切工作。
有关详情,请参阅此处:http://php.net/manual/en/language.oop5.autoload.php