File: /www/wwwroot//mw.umchkw.com/application/admin/model/Images.php
<?php
/**
* 易优CMS
* ============================================================================
* 版权所有 2016-2028 海南赞赞网络科技有限公司,并保留所有权利。
* 网站地址: http://www.eyoucms.com
* ----------------------------------------------------------------------------
* 如果商业用途务必到官方购买正版授权, 以免引起不必要的法律纠纷.
* ============================================================================
* Author: 小虎哥 <1105415366@qq.com>
* Date: 2018-4-3
*/
namespace app\admin\model;
use think\Db;
use think\Model;
/**
* 图集
*/
class Images extends Model
{
// 模型标识
public $nid = 'images';
// 模型ID
public $channeltype = '';
//初始化
protected function initialize()
{
// 需要调用`Model`的`initialize`方法
parent::initialize();
$channeltype_list = config('global.channeltype_list');
$this->channeltype = $channeltype_list[$this->nid];
}
/**
* 后置操作方法
* 自定义的一个函数 用于数据保存后做的相应处理操作, 使用时手动调用
* @param int $aid 产品id
* @param array $post post数据
* @param string $opt 操作
*/
public function afterSave($aid, $post, $opt)
{
$post['aid'] = $aid;
$addonFieldExt = !empty($post['addonFieldExt']) ? $post['addonFieldExt'] : array();
model('Field')->dealChannelPostData($post['channel'], $post, $addonFieldExt);
// ---------多图
model('ImagesUpload')->saveimg($aid, $post);
// ---------end
// --处理TAG标签
model('Taglist')->savetags($aid, $post['typeid'], $post['tags'], $post['arcrank'], $opt);
// 处理mysql缓存表数据
if (isset($post['arcrank']) && -1 == $post['arcrank'] && -1 == $post['old_arcrank'] && !empty($post['users_id'])) {
// 待审核
model('SqlCacheTable')->UpdateDraftSqlCacheTable($post, $opt);
} else if (isset($post['arcrank'])) {
// 已审核
$post['old_typeid'] = intval($post['attr']['typeid']);
model('SqlCacheTable')->UpdateSqlCacheTable($post, $opt, 'images');
}
}
/**
* 获取单条记录
* @author wengxianhu by 2017-7-26
*/
public function getInfo($aid, $field = '', $isshowbody = true)
{
$result = array();
$field = !empty($field) ? $field : '*';
$result = Db::name('archives')->field($field)
->where([
'aid' => $aid,
'lang' => get_admin_lang(),
])
->find();
if ($isshowbody) {
$tableName = Db::name('channeltype')->where('id','eq',$result['channel'])->getField('table');
$result['addonFieldExt'] = Db::name($tableName.'_content')->where('aid',$aid)->find();
}
// 图集TAG标签
if (!empty($result)) {
$typeid = isset($result['typeid']) ? $result['typeid'] : 0;
$tags = model('Taglist')->getListByAid($aid, $typeid);
$result['tags'] = $tags['tag_arr'];
$result['tag_id'] = $tags['tid_arr'];
}
return $result;
}
/**
* 获取多条记录
* @author lindaoyun by 2017-9-18
*/
public function getListByLimit($map = array(), $limit = 15, $field = '*', $order = 'a.aid desc')
{
$data = array();
$field_arr = explode(',', $field);
foreach ($field_arr as $key => $val) {
array_push($data, 'a.'.trim($val));
}
$field = implode(',', $data);
$field = 'b.*, '.$field;
if (!empty($map) && is_array($map)) {
foreach ($map as $key => $val) {
if (preg_match("/^(a\.)/i", $val) == 0) {
$map['a.'.$key] = $val;
unset($map[$key]);
}
}
}
$map['a.channel'] = $this->channeltype;
$result = Db::name('archives')
->field($field)
->alias('a')
->join('__ARCTYPE__ b', 'b.id = a.typeid', 'LEFT')
->where($map)
->order($order)
->limit($limit)
->select();
return $result;
}
/**
* 获取多条记录
* @author wengxianhu by 2017-7-26
*/
public function getListByClick($limit = 10, $map = array(), $field = '*')
{
$map['channel'] = $this->channeltype;
$map['status'] = 1;
$result = Db::name('archives')
->field($field)
->where($map)
// ->cache(true,EYOUCMS_CACHE_TIME)
->order('click desc')
->limit($limit)
->select();
return $result;
}
/**
* 获取当前图集的所有上下级分类
*/
public function getAllCateByTypeid($typeid)
{
$result = Db::name('arctype')->field('id,parent_id,typename')
->where(array('id|parent_id'=>$typeid, 'status'=>1))
->order('parent_id asc, sort_order asc')
->getAllWithIndex('id');
return $result;
}
/**
* 删除的后置操作方法
* 自定义的一个函数 用于数据删除后做的相应处理操作, 使用时手动调用
* @param int $aid
*/
public function afterDel($aidArr = array())
{
if (is_string($aidArr)) {
$aidArr = explode(',', $aidArr);
}
// 同时删除内容
Db::name('images_content')->where(
array(
'aid'=>array('IN', $aidArr)
)
)
->delete();
// 同时删除图片
$result = Db::name('images_upload')->field('image_url')
->where(
array(
'aid'=>array('IN', $aidArr)
)
)
->select();
if (!empty($result)) {
//20210603大黄注释 删掉文档不删掉服务器的图片,否则复制的文档图片无法显示
// foreach ($result as $key => $val) {
// $image_url = preg_replace('#^(/[/\w]+)?(/public/upload/|/uploads/)#i', '$2', $val['image_url']);
// if (!is_http_url($image_url) && file_exists('.'.$image_url) && preg_match('#^(/uploads/|/public/upload/)(.*)/([^/]+)\.([a-z]+)$#i', $image_url)) {
// @unlink(realpath('.'.$image_url));
// }
// }
Db::name('images_upload')->where(
array(
'aid'=>array('IN', $aidArr)
)
)
->delete();
}
// 同时删除TAG标签
model('Taglist')->delByAids($aidArr);
}
}