1

我创建了一个自定义捐赠模块,在其中我将一些表单数据从 default.php 发布到另一个名为 checkout.php 的 php 脚本。现在我添加了一些代码来将数据插入到 checkout.php 中的数据库中

//setup db  
$db =& JFactory::getDBO();

//create database table if needed
$createTable = "CREATE TABLE IF NOT EXISTS `#__idealdonaties` ( " . 
    "`id` int(10) NOT NULL, " . 
    "`donateur_id` varchar(40) NOT NULL, " . 
    "`naam` varchar(100) NOT NULL, " . 
    "`email` varchar(250), " . 
    "`bedrag` varchar(100) NOT NULL, " . 
    "`status` int(1) DEFAULT 0, . 
    PRIMARY KEY (`id`), KEY `donateur_id` (`donateur_id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8;";
$db->setQuery($createTable);
$db->query();

//insert data into table
$insertData = "INSERT INTO `#__idealdonaties` ( `donateur_id`, `naam`, `email`, `bedrag`, `status` ) " .
    "VALUES (`" . $brq_invoicenumber . "`, `" . $cust_name . "`, `" . $cust_email . "`, `" . $brq_amount . "`, 0)";
$db->setQuery($insertData);
$db->query();   

但出现错误:

致命错误:在第 87 行的 /home/sitesosimple/public_html/modules/mod_idealdonatie/checkout.php 中找不到类“JFactory”

现在我通过添加代码修复了该错误(经过一些搜索):

define( '_JEXEC', 1 );
define( 'JPATH_BASE', realpath(dirname(__FILE__).'/../../' ));  
require_once ( JPATH_BASE .'/includes/defines.php' );
require_once ( JPATH_BASE .'/includes/framework.php' );

$mainframe = JFactory::getApplication('site');

但现在我得到一个全新的错误:

致命错误:在第 73 行的 /home/sitesosimple/public_html/modules/mod_roknavmenu/lib/RokNavMenu.php 中找不到类“JFile”

由于某种原因,roknavmenu 模块无法找到 JFile 类,尽管我在该 php 文件中没有进行任何更改,也没有对包含 JFile 类的 file.php 脚本做任何事情。

我已经将新版本的 file.php 复制到 /public_html/libraries/joomla/filesystem 文件夹中。但无济于事。

4

1 回答 1

0

不确定这是否是正确的解决方案,但它似乎奏效了。我删除了这一行:$mainframe = JFactory::getApplication('site');.

于 2015-09-25T11:36:41.183 回答