我在自定义模块中为'customer_save_before'事件添加了观察者代码 . 当客户在Magento前台,账户管理区域提交详细信息时,它会触发 . 它执行一个脚本,该脚本应拦截$ _FILES [...]数组并使用Varien_File_Uploader将其保存在数据库中 .
我在... / template / customer / form / edit.phtml中添加了一个新字段
<input type="file" name="logo" id="logo" title="<?php echo $this->__('Logo') ?>" class="input-file" />
这是我在'customer_save_before'上获取的Observer.php代码:
class Walder_Logoupload_Model_Observer extends Mage_Core_Model_Abstract {
public function customer_save_before($observer) {
// Test code START
echo "<pre>"; print_r($_FILES);
$tempexists = file_exists($_FILES['logo']['tmp_name'])?'exists':'doesnt exist';
echo "logo.tmp_name file: ".$tempexists;
exit;
// Test code END
if(isset($_FILES['logo']['name'])) {
try {
$uploader = new Varien_File_Uploader('logo');
$uploader->setAllowedExtensions(array('jpg','jpeg','gif','png'));
$uploader->setAllowRenameFiles(false);
$uploader->setFilesDispersion(false);
$path = Mage::getBaseDir('media') . DS .'catalog'.DS.'customer'.DS.'logo';
$newName = time() . $_FILES['logo']['name'];
$uploader->save($path, $newName);
$customer->setLogo($newName);
}catch(Exception $e) {
echo "Exception: ".$e; exit;
}
}
}
}
文件上传后,启用测试代码后,我得到一个包含文件信息和“tmp_name”路径的数组,以及一条临时文件不存在的消息:
[logo] => Array
(
[name] => sample-logo.png
[type] => image/png
[tmp_name] => /home/www/mag59212/tmp/phpbCoax5
[error] => 0
[size] => 107564
)
logo.tmp_name file: doesnt exist
随着测试代码注释掉,我收到此异常错误消息:
exception 'Exception' with message 'File was not uploaded.'
in /home/www/mag59212/html/magento-de/lib/Varien/File/Uploader.php:153
这意味着相同的,$ _FILES ['tmp_name']文件不存在 . 因此,文件不会保存在服务器上 .
当我在后端运行这个Observer代码时,我得到了相同的消息,我的测试代码(文件不存在),但无论如何都要上传文件 .
如何修复我的前端代码以上传此文件?
2 回答
我遇到了类似的问题 . 你检查了系统日志吗?
对我来说它说:
在php.ini或phpinfo()中查找php设置 . 搜索“open_basedir”和“upload_tmp_dir” . 如果设置了open_basedir限制,并且upload_tmp_dir不在允许的目录中,则可能会触发此类错误 .
在我的结尾,问题存档:Mage / Customer / controllers / AccountController.php代码:
在$ customerData中我的文件自定义属性也在compactData函数调用时删除了文件 . 由于安装文件中属性创建中的以下行,它包括在内:
当我从自定义属性设置行中删除上面的行时,它解决了问题 . 希望对有类似问题的人有帮助,