include [[snippet]];

时间:2011-03-25 07:42:13

标签: modx

我在ModX中有两个片段: first(DBData):

    <?php
// login.php
$db_hostname = 'localhost';
$db_database = 'my_db';
$db_username = 'myusername';
$db_password = 'mypass';

第二

    <?php
require_once '[[DBData]]';
$db_server = mysql_connect($db_hostname, $db_username, $db_password);
if (!$db_server) die("Unable to connect to MySQL: " . mysql_error());
mysql_select_db($db_database)
    or die("Unable to select database: " . mysql_error());

当我尝试将它们插入我的页面时,如下所示: [[DBData]] [[DBCONNECT]] 什么都没发生,我如何“插入”DBData到DBConnect? 感谢

2 个答案:

答案 0 :(得分:0)

您可以使用modx API runSnippet在另一个代码段中运行代码段。

进一步查看您的问题,您似乎想要使用第二个第一个代码段中设置的登录详细信息。您可以通过在第一个代码段中设置占位符然后在第二个代码段中将它们用在第二个代码段中来执行此操作

$modx->setPlaceholder('host-name', 'localhost')

然后检索第二个代码段中的值

$modx->getPlaceholder('host-name')

答案 1 :(得分:0)

我建议使用MODx已经拥有的数据库,你可以使用类似这样的语法我不想进入xPDO商务:

<?php
$rows = array();
$result = $modx->query("SELECT * FROM `xyz`");
if ($result) {
    while ($row = $result->fetch(PDO_FETCH_ASSOC)) {
        array_push($rows, $row);
    }
}

如果您真的想要使用自己的连接,那么最好在MODx配置中使用数据库凭据(可能是密码)存储您自己的系统设置,而不是通过以下方式将它们放入代码段中:

$mySetting = $modx->getOption('your_setting_key');

要创建自己的系统sesttings enries,请参阅http://rtfm.modx.com/revolution/2.x/administering-your-site/settings/system-settings/