一,在megento表中,增加一个存储上传图片路径的属性,

给magento的customer实体类型增加一个audit_file_path属性,因为要customer使用的是EAV模型,得操作几个关联的数据表,方便使用magento模型的方法,

1,为表eav_attribute添加一个条记录,即增加一个audit_file_path属性对应于attribute_code字段,其中backend_type为varchar类型,在eav里对应的属性值会被存储到customer_entity_varchar表当中,SQL语句如下:

 INSERT INTO yo_eav_attribute(entity_type_id,attribute_code,attribute_model,backend_model,backend_type,backend_table,frontend_model,frontend_input,frontend_label,frontend_class,source_model,is_required,is_user_defined,default_value,is_unique,note) VALUE(1,'audit_file_path',NULL,NULL,'varchar',NULL,NULL,'text','Audit file path',NULL,NULL,0,0,0,0,NULL)

2,属性添加成功后,会生成attribute_id:157,其它字段值可参考eav_entity_attribure表里面,entity_type_id的实体类型为customer的一些记录设置,SQL语句如下:

 INSERT INTO yo_eav_entity_attribute(entity_type_id,attribute_set_id,attribute_group_id,attribute_id,sort_order) VALUE(1,1,1,157,110)

3,接着为customer_eav_attribute表(用户实体),增加属性id为157的一条记录,SQL语句如下:

 INSERT INTO yo_customer_eav_attribute VALUE(157,1,NULL,0,NULL,1,0,NULL)

二,在megento系统中的app\design\frontend\Packagename\yourstore\template目录中的找到对应的模板.phtml,并添加文件上传的html结构,代码如下:

                     <div class="fileContainer">
<div class="audit_file_wrp">
<input type="file" name="audit_file[]" class="audit_file" />
<span class="auditRemove">remove</span>
</div>
</div>
<div><span class="addAuditFile">add file</span></div>

在对应js文件中添加文件按钮的添加与移除按钮,js代码如下:

  jQuery(document).ready(function(){
//增加上传文件按钮
jQuery('.addAuditFile').click(function(){
var addHtml='<div class="audit_file_wrp"> <input type="file" name="audit_file[]" class="audit_file" /> <span class="auditRemove">remove</span></div>';
jQuery(addHtml).appendTo('.fileContainer');
});
//删除上传文件按钮,至少保留一个
jQuery('.fileContainer').on('click', '.auditRemove', function() {
if (jQuery('.auditRemove').length > 1) {
jQuery(this).parents('.audit_file_wrp').remove();
} else {
alert('at least one image need to be selected');
}
});
});

三,在magento系统中,app\code\local\Packagename\yourmodule\controllers目录下找到自己对应的anction方法处理文件的上传,与存储并存到数据库,方便以后查阅文件,这里是以图形式上传,代码如下:

       /**
* 获取当前用户对象
*/
$customer = Mage::getSingleton ( "customer/session" )->getCustomer ();
/**
* 获取当前对象ID
*/
$customerId = $customer->getId ();
/**
* 加载当前用户对象的模型
*/
$model = Mage::getModel ( 'customer/customer' )->load ( $customerId ); /**
* 设置存储图片的默认路径
*/
$basedir = Mage::getBaseDir ( 'media' );
/**
* 遍历上传的文件,并存储到对应路径
*/
$imagePath=array();
foreach($_FILES ["audit_file"]["name"] as $key=>$image){
if (isset ( $_FILES ["audit_file"] ['name'][$key] ) && (file_exists ( $_FILES ["audit_file"] ['tmp_name'][$key] ))) {
try { $uploader = new Varien_File_Uploader ( array(
'name'=> $_FILES ["audit_file"] ['name'][$key],
'type'=> $_FILES ["audit_file"] ['type'][$key],
'tmp_name'=> $_FILES ["audit_file"] ['tmp_name'][$key],
'error'=> $_FILES ["audit_file"] ['error'][$key],
'size'=> $_FILES ["audit_file"] ['size'][$key]
) );
/**
* 定义可上传的文件格式
*/
$uploader->setAllowedExtensions ( array (
'jpg',
'jpeg',
'gif',
'png'
) );
/**
* 定义存储的文件名是否可变
*/
$uploader->setAllowRenameFiles ( false );
$uploader->setFilesDispersion ( false );
/**
* 定义具体路径
*/
$path = $basedir . DS . 'sellerimage'.DS.'audit';
/**
* 保存文件到具体路径,并按照用户id设置用户名
*/ $RenameArr=explode('.',$image);
$RenameArr[0]="audit_file_".$customerId."_".$key;
$imagePath[$key]=implode('.',$RenameArr);
$uploader->save ( $path, $imagePath[$key]); } catch ( Exception $e ) {
/**
* 显示上传出错的信息
*/
Mage::getSingleton ( 'core/session' )->addError ( $this->__ ( $e->getMessage () ) );
} }
}
/**
* 存储文件名到数据库
*/
$model->setAuditfilepath(implode(',',$imagePath));
$model->save();

总结:在整个操作过程中,难点在与magento的EVA数据模型的理解,及在内置的eav模型的使用,里面使用Varien_File_Uploader对象处理图片的存储,简单易行

												

使用magento eav数据模型为用户提供图片上传功能的实践的更多相关文章

  1. java模拟表单上传文件,java通过模拟post方式提交表单实现图片上传功能实例

    java模拟表单上传文件,java通过模拟post方式提交表单实现图片上传功能实例HttpClient 测试类,提供get post方法实例 package com.zdz.httpclient; i ...

  2. megapix-image插件 使用Canvas压缩图片上传 解决手机端图片上传功能的问题

    最近在弄微信端的公众号.订阅号的相关功能,发现原本网页上用的uploadify图片上传功能到手机端有的手机类型上就不能用了,比如iphone,至于为啥我想应该不用多说了吧(uploadify使用fla ...

  3. Ueditor图片上传功能的配置

    之前的项目中碰到过图片上传功能的配置问题,但是没有记录下来,今天有个朋友突然又问到了我这个问题,当时没想起来之前怎么解决的,后来看了Ueditor的官方文档才回想起来. 官网文档巨多,一般大家遇到问题 ...

  4. drupal中安装CKEditor文本编辑器,并配置图片上传功能 之 方法二

    drupal中安装CKEditor文本编辑器,并配置图片上传功能 之 方法一 中介绍了ckeditor的安装和配置方法,其实还有另一种新方法,不用IMCE模块. 不过需要ckfinder的JS库,可以 ...

  5. FLASH图片上传功能—从百度编辑器UEditor里面提取出来

    为了记录工作中碰到的各种问题,以及学习资料整理,今天开始,将以往的文章进行了一个整理,以后也开始认真的记录学习过程中的各种问题 在HTML里面的文件上传功能一直是个问题,为了实现上传文件大小限制,怎样 ...

  6. Android开发之使用GridView+仿微信图片上传功能(附源代码)

    前言:如果转载文章请声明转载自:https://i.cnblogs.com/EditPosts.aspx?postid=7419021  .另外针对有些网站转载本人的文章结果源码链接不对的问题,本人在 ...

  7. QQ空间发表日志的图片上传功能实现

    w间接促使了用户注意图片的顺序,进一步优化的方向的是手指触动或鼠标点击来同时进行图片的增删和调序,避免精确的数字输入. 有效code <form action="wcon/wact&q ...

  8. Android 使用GridView+仿微信图片上传功能(附源代码)

    由于工作要求最近在使用GridView完成图片的批量上传功能,我的例子当中包含仿微信图片上传.拍照.本地选择.相片裁剪等功能,如果有需要的朋友可以看一下,希望我的实际经验能对您有所帮助. 直接上图,下 ...

  9. Dede后台广告管理模块增加图片上传功能插件

    用户问题:网站广告后台管理非常方便,但是织梦后台的广告管理模块,发布广告时图片没有上传选项,只能用URL地址,很不方便,那么织梦帮就教大家一个方法实现广告图片后台直接上传,非常方便.先给大家看下修改后 ...

随机推荐

  1. C++字符串与指针 所有的内容也就这么多了。

    1.定义一个字符串数组并初始化,然后输出其中的字符串. #include <iostream> using namespace std;int main(){ char str[]=&qu ...

  2. Hdu-6242 2017CCPC-哈尔滨站 M.Geometry Problem 计算几何 随机

    题面 题意:给你n个点,让你找到一个圆,输出圆心,和半径,使得有超过一半的点刚好在圆上.n<=1e5,题目保证了有解 题解:刚开始看着很不可做的样子,但是多想想,三点确定一个圆,三点啊! 现在有 ...

  3. RabbitMQ消息队列服务

    MQ 全称为 Message Queue, 消息队列( MQ ) 是一种应用程序对应用程序的通信方法.应用程序通过读写出入队列的消息(针对应用程序的数据)来通信,而无需专用连接来链接它们. 一个软件它 ...

  4. BZOJ 1041 数学

    思路: $x^2+y^2=r^2$$y=\sqrt{(r+x)(r-x)}$令$ d=gcd(r+x,r-x)$设A=$(r-x)/d$ $B=(r+x)/d$则$gcd(A,B)=1$$y^2=d^ ...

  5. C - Queue at the School

    Problem description During the break the schoolchildren, boys and girls, formed a queue of n people ...

  6. C#中图片转换为Base64编码,Base64编码转换为图片

    #region 图片转为base64编码的字符串 public string ImgToBase64String(string Imagefilename) { try { Bitmap bmp = ...

  7. Entity Framework 的懒加载、预先加载、显示加载

    1.新建两个实体,一个班级有多个学生 public class Student { public int StudentId { get; set; } public string StudentNa ...

  8. 实现model中的文件上传FTP(二)

    上一篇博客记录了如何将model中的图片存入FTP,通过一个第三方的storages简单的实现了,但是后续我发现如果想在浏览器通过url直接获取图片,就不太容易了(大神轻喷,小弟自学django和py ...

  9. html行级元素和块级元素以及css转换

    之前有说过html的标签是有语义的,当然也就有一些默认的样式,比如标题有h1···h6,他们的字体由大至小一次递减,字体比一般字体要加粗. 这样也就有了行级元素和块级元素,下面来看看什么是行级元素什么 ...

  10. hdu2112 HDU Today 基础最短路

    这题的关键是把车站的名字转化为点的编号.我用的是map.声明一个map<string,int> st,然后按照字符串出现的次序给st赋值.例如:st[s1]=2;代表这字符串s1出现的次序 ...