上一次讲了给AW_Blog插件后台文章列表添加分类栏,今天继续来加强AW_Blog,给每个文章新增一个独立的图片字段。为什么要新加一个字段呢,文章内容里不是也可以添加图片吗?这是因为某些情况下,独立的图片字段是必需的,如果要把AW_Blog当做一个简单的CMS来用的话,如下图:
这里跟文章相关的图片,如果没有独立的图片字段,那就只能想办法从文章内容中抓取图片出来,不仅难度很高(专业CMS都有这个功能),而且无法保证图片比例的一致性,这时候有一个单独的图片字段的话就可以针对性的上传要显示的图片。
打开AW_Blog_Block_Manage_Blog_Edit_Form文件,给表单添加一个属性,表示该表单接受文件上传
protected function _prepareForm() { $form = new Varien_Data_Form(array( 'id' => 'edit_form', 'action' => $this->getUrl('*/*/save', array('id' => $this->getRequest()->getParam('id'))), 'method' => 'post', 'enctype' => 'multipart/form-data' ) ); $form->setUseContainer(true); $this->setForm($form); return parent::_prepareForm(); }
打开AW_Blog_Block_Manage_Blog_Edit_Tab_Form文件,新增需要添加的表单项
。。。。。。。。。。。 $fieldset->addField('blog_image', 'image', array( 'name' => 'blog_image', 'label' => $this->__('图片'), 'title' => $this->__('图片'), 'note' => $this->__('上传新闻列表或其他地方会用到的图片'), )); 。。。。。。。。。。。。。。
打开AW_Blog_Manage_BlogController文件,在saveAction里添加处理文件上传的代码
if ($data = $this->getRequest()->getPost()) { //上传图片 if(isset($_FILES['blog_image']['name']) and (file_exists($_FILES['blog_image']['tmp_name']))) { try { $uploader = new Varien_File_Uploader('blog_image'); $uploader->setAllowedExtensions(array('jpg','jpeg','gif','png')); // or pdf or anything $uploader->setAllowRenameFiles(true); $uploader->setFilesDispersion(false); $path = Mage::getBaseDir('media') . DS ; $uploader->save($path, $_FILES['blog_image']['name']); $data['blog_image'] = $uploader->getUploadedFileName(); }catch(Exception $e) { } }else{ if(isset($data['blog_image']['delete']) && $data['blog_image']['delete'] == 1) $data['blog_image'] = ''; else unset($data['blog_image']); } 。。。。。。。。。。。。当然还有一个最重要的,就是在数据库的aw_blog表中新增一个字段来保存图片的路径
后台显示效果如下:
前台在模板文件中调用该图片的方式,在适当的位置加入类似下面的代码:
<img src="<?php echo $this->getUrl('media').$post->getBlogImage();?>">
补丁下载链接:http://www.kuaipan.cn/file/id_5552585259880364.html
PS:补丁里只包含几个php文件,数据库字段的话要自己添加,容许我偷懒下吧