Actor.php 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525
  1. <?php
  2. namespace app\common\model;
  3. use think\Db;
  4. use think\Cache;
  5. use app\common\util\Pinyin;
  6. class Actor extends Base {
  7. // 设置数据表(不含前缀)
  8. protected $name = 'actor';
  9. // 定义时间戳字段名
  10. protected $createTime = '';
  11. protected $updateTime = '';
  12. // 自动完成
  13. protected $auto = [];
  14. protected $insert = [];
  15. protected $update = [];
  16. public function getActorStatusTextAttr($val,$data)
  17. {
  18. $arr = [0=>lang('disable'),1=>lang('enable')];
  19. return $arr[$data['actor_status']];
  20. }
  21. public function countData($where)
  22. {
  23. $total = $this->where($where)->count();
  24. return $total;
  25. }
  26. public function listData($where,$order,$page=1,$limit=20,$start=0,$field='*',$addition=1,$totalshow=1)
  27. {
  28. $page = $page > 0 ? (int)$page : 1;
  29. $limit = $limit ? (int)$limit : 20;
  30. $start = $start ? (int)$start : 0;
  31. if(!is_array($where)){
  32. $where = json_decode($where,true);
  33. }
  34. $where2='';
  35. if(!empty($where['_string'])){
  36. $where2 = $where['_string'];
  37. unset($where['_string']);
  38. }
  39. $limit_str = ($limit * ($page-1) + $start) .",".$limit;
  40. if($totalshow==1) {
  41. $total = $this->where($where)->count();
  42. }
  43. $list = Db::name('Actor')->field($field)->where($where)->where($where2)->orderRaw($order)->limit($limit_str)->select();
  44. //分类
  45. $type_list = model('Type')->getCache('type_list');
  46. foreach($list as $k=>$v){
  47. if($addition==1){
  48. if(!empty($v['type_id'])) {
  49. $list[$k]['type'] = $type_list[$v['type_id']];
  50. $list[$k]['type_1'] = $type_list[$list[$k]['type']['type_pid']];
  51. }
  52. }
  53. }
  54. return ['code'=>1,'msg'=>lang('data_list'),'page'=>$page,'pagecount'=>ceil($total/$limit),'limit'=>$limit,'total'=>$total,'list'=>$list];
  55. }
  56. public function listCacheData($lp)
  57. {
  58. if (!is_array($lp)) {
  59. $lp = json_decode($lp, true);
  60. }
  61. $order = $lp['order'];
  62. $by = $lp['by'];
  63. $type = $lp['type'];
  64. $ids = $lp['ids'];
  65. $paging = $lp['paging'];
  66. $pageurl = $lp['pageurl'];
  67. $level = $lp['level'];
  68. $wd = $lp['wd'];
  69. $name = $lp['name'];
  70. $area = $lp['area'];
  71. $letter = $lp['letter'];
  72. $sex = $lp['sex'];
  73. $starsign = $lp['starsign'];
  74. $blood = $lp['blood'];
  75. $start = intval(abs($lp['start']));
  76. $num = intval(abs($lp['num']));
  77. $half = intval(abs($lp['half']));
  78. $timeadd = $lp['timeadd'];
  79. $timehits = $lp['timehits'];
  80. $time = $lp['time'];
  81. $hitsmonth = $lp['hitsmonth'];
  82. $hitsweek = $lp['hitsweek'];
  83. $hitsday = $lp['hitsday'];
  84. $hits = $lp['hits'];
  85. $not = $lp['not'];
  86. $cachetime = $lp['cachetime'];
  87. $typenot = $lp['typenot'];
  88. $page = 1;
  89. $where = [];
  90. $totalshow=0;
  91. if(empty($num)){
  92. $num = 20;
  93. }
  94. if($start>1){
  95. $start--;
  96. }
  97. if(!in_array($paging, ['yes', 'no'])) {
  98. $paging = 'no';
  99. }
  100. $param = mac_param_url();
  101. if($paging=='yes') {
  102. $param = mac_search_len_check($param);
  103. $totalshow = 1;
  104. if(!empty($param['id'])) {
  105. //$type = intval($param['id']);
  106. }
  107. if(!empty($param['ids'])){
  108. $ids = $param['ids'];
  109. }
  110. if(!empty($param['level'])) {
  111. if($param['level']=='all'){
  112. $level = '1,2,3,4,5,6,7,8,9';
  113. }
  114. else{
  115. $level = $param['level'];
  116. }
  117. }
  118. if(!empty($param['letter'])) {
  119. $letter = $param['letter'];
  120. }
  121. if(!empty($param['sex'])){
  122. $sex = $param['sex'];
  123. }
  124. if(!empty($param['area'])) {
  125. $area = $param['area'];
  126. }
  127. if(!empty($param['starsign'])){
  128. $starsign = $param['starsign'];
  129. }
  130. if(!empty($param['blood'])){
  131. $blood = $param['blood'];
  132. }
  133. if(!empty($param['wd'])) {
  134. $wd = $param['wd'];
  135. }
  136. if(!empty($param['by'])){
  137. $by = $param['by'];
  138. }
  139. if(!empty($param['order'])){
  140. $order = $param['order'];
  141. }
  142. if(!empty($param['page'])){
  143. $page = intval($param['page']);
  144. }
  145. foreach($param as $k=>$v){
  146. if(empty($v)){
  147. unset($param[$k]);
  148. }
  149. }
  150. if(empty($pageurl)){
  151. $pageurl = 'actor/type';
  152. }
  153. $param['page'] = 'PAGELINK';
  154. if($pageurl=='actor/type' || $pageurl=='actor/show'){
  155. $type = intval( $GLOBALS['type_id'] );
  156. $type_list = model('Type')->getCache('type_list');
  157. $type_info = $type_list[$type];
  158. $flag='type';
  159. if($pageurl == 'actor/show'){
  160. $flag='show';
  161. }
  162. $pageurl = mac_url_type($type_info,$param,$flag);
  163. }
  164. else{
  165. $pageurl = mac_url($pageurl,$param);
  166. }
  167. }
  168. $where['actor_status'] = ['eq',1];
  169. if(!empty($level)) {
  170. if($level=='all'){
  171. $level = '1,2,3,4,5,6,7,8,9';
  172. }
  173. $where['actor_level'] = ['in',explode(',',$level)];
  174. }
  175. if(!empty($ids)) {
  176. if($ids!='all'){
  177. $where['actor_id'] = ['in',explode(',',$ids)];
  178. }
  179. }
  180. if(!empty($not)){
  181. $where['actor_id'] = ['not in',explode(',',$not)];
  182. }
  183. if(!empty($sex)){
  184. $where['actor_sex'] = ['eq',$sex];
  185. }
  186. if(!empty($letter)){
  187. if(substr($letter,0,1)=='0' && substr($letter,2,1)=='9'){
  188. $letter='0,1,2,3,4,5,6,7,8,9';
  189. }
  190. $where['actor_letter'] = ['in',explode(',',$letter)];
  191. }
  192. if(!empty($timeadd)){
  193. $s = intval(strtotime($timeadd));
  194. $where['actor_time_add'] =['gt',$s];
  195. }
  196. if(!empty($timehits)){
  197. $s = intval(strtotime($timehits));
  198. $where['actor_time_hits'] =['gt',$s];
  199. }
  200. if(!empty($time)){
  201. $s = intval(strtotime($time));
  202. $where['actor_time'] =['gt',$s];
  203. }
  204. if(!empty($type)) {
  205. if($type=='current'){
  206. $type = intval( $GLOBALS['type_id'] );
  207. }
  208. if($type!='all') {
  209. $tmp_arr = explode(',', $type);
  210. $type_list = model('Type')->getCache('type_list');
  211. $type = [];
  212. foreach ($type_list as $k2 => $v2) {
  213. if (in_array($v2['type_id'] . '', $tmp_arr) || in_array($v2['type_pid'] . '', $tmp_arr)) {
  214. $type[] = $v2['type_id'];
  215. }
  216. }
  217. $type = array_unique($type);
  218. $where['type_id'] = ['in', implode(',', $type)];
  219. }
  220. }
  221. if(!empty($typenot)){
  222. $where['type_id'] = ['not in',$typenot];
  223. }
  224. if(!empty($tid)) {
  225. $where['type_id|type_id_1'] = ['eq',$tid];
  226. }
  227. if(!empty($hitsmonth)){
  228. $tmp = explode(' ',$hitsmonth);
  229. if(count($tmp)==1){
  230. $where['actor_hits_month'] = ['gt', $tmp];
  231. }
  232. else{
  233. $where['actor_hits_month'] = [$tmp[0],$tmp[1]];
  234. }
  235. }
  236. if(!empty($hitsweek)){
  237. $tmp = explode(' ',$hitsweek);
  238. if(count($tmp)==1){
  239. $where['actor_hits_week'] = ['gt', $tmp];
  240. }
  241. else{
  242. $where['actor_hits_week'] = [$tmp[0],$tmp[1]];
  243. }
  244. }
  245. if(!empty($hitsday)){
  246. $tmp = explode(' ',$hitsday);
  247. if(count($tmp)==1){
  248. $where['actor_hits_day'] = ['gt', $tmp];
  249. }
  250. else{
  251. $where['actor_hits_day'] = [$tmp[0],$tmp[1]];
  252. }
  253. }
  254. if(!empty($hits)){
  255. $tmp = explode(' ',$hits);
  256. if(count($tmp)==1){
  257. $where['actor_hits'] = ['gt', $tmp];
  258. }
  259. else{
  260. $where['actor_hits'] = [$tmp[0],$tmp[1]];
  261. }
  262. }
  263. if(!empty($area)){
  264. $where['actor_area'] = ['in',explode(',',$area) ];
  265. }
  266. if(!empty($starsign)){
  267. $where['actor_starsign'] = ['in',explode(',',$starsign) ];
  268. }
  269. if(!empty($blood)){
  270. $where['actor_blood'] = ['in',explode(',',$blood) ];
  271. }
  272. if(!empty($name)){
  273. $where['actor_name'] = ['in',explode(',',$name) ];
  274. }
  275. if(!empty($wd)) {
  276. $where['actor_name|actor_en'] = ['like', '%' . $wd . '%'];
  277. }
  278. if($by=='rnd'){
  279. $data_count = $this->countData($where);
  280. $page_total = floor($data_count / $lp['num']) + 1;
  281. if($data_count < $lp['num']){
  282. $lp['num'] = $data_count;
  283. }
  284. $randi = @mt_rand(1, $page_total);
  285. $page = $randi;
  286. $by = 'hits_week';
  287. $order = 'desc';
  288. }
  289. if(!in_array($by, ['id', 'time','time_add','score','hits','hits_day','hits_week','hits_month','up','down','level','rnd','in'])) {
  290. $by = 'time';
  291. }
  292. if(!in_array($order, ['asc', 'desc'])) {
  293. $order = 'desc';
  294. }
  295. $where_cache = $where;
  296. if(!empty($randi)){
  297. unset($where_cache['actor_id']);
  298. $where_cache['order'] = 'rnd';
  299. }
  300. if($by=='in' && !empty($name) ){
  301. $order = ' find_in_set(actor_name, \''.$name.'\' ) ';
  302. }
  303. else{
  304. if($by=='in' && empty($name) ){
  305. $by = 'time';
  306. }
  307. $order= 'actor_'.$by .' ' . $order;
  308. }
  309. $cach_name = $GLOBALS['config']['app']['cache_flag']. '_' .md5('actor_listcache_'.http_build_query($where_cache).'_'.$order.'_'.$page.'_'.$num.'_'.$start.'_'.$pageurl);
  310. $res = Cache::get($cach_name);
  311. if(empty($cachetime)){
  312. $cachetime = $GLOBALS['config']['app']['cache_time'];
  313. }
  314. if($GLOBALS['config']['app']['cache_core']==0 || empty($res)) {
  315. $res = $this->listData($where,$order,$page,$num,$start,'*',1,$totalshow);
  316. if($GLOBALS['config']['app']['cache_core']==1){
  317. Cache::set($cach_name, $res, $cachetime);
  318. }
  319. }
  320. $res['pageurl'] = $pageurl;
  321. $res['half'] = $half;
  322. return $res;
  323. }
  324. public function infoData($where,$field='*',$cache=0)
  325. {
  326. if(empty($where) || !is_array($where)){
  327. return ['code'=>1001,'msg'=>lang('param_err')];
  328. }
  329. $data_cache = false;
  330. $key = $GLOBALS['config']['app']['cache_flag']. '_'. 'actor_detail_'.$where['actor_id'][1].'_'.$where['actor_en'][1];
  331. if($where['actor_id'][0]=='eq' || $where['actor_en'][0]=='eq'){
  332. $data_cache = true;
  333. }
  334. if($GLOBALS['config']['app']['cache_core']==1 && $data_cache) {
  335. $info = Cache::get($key);
  336. }
  337. if($GLOBALS['config']['app']['cache_core']==0 || $cache==0 || empty($info['actor_id'])) {
  338. $info = $this->field($field)->where($where)->find();
  339. if (empty($info)) {
  340. return ['code' => 1002, 'msg' => lang('obtain_err')];
  341. }
  342. $info = $info->toArray();
  343. //分类
  344. if (!empty($info['type_id'])) {
  345. $type_list = model('Type')->getCache('type_list');
  346. $info['type'] = $type_list[$info['type_id']];
  347. $info['type_1'] = $type_list[$info['type']['type_pid']];
  348. }
  349. if($GLOBALS['config']['app']['cache_core']==1 && $data_cache && $cache==1) {
  350. Cache::set($key, $info);
  351. }
  352. }
  353. return ['code'=>1,'msg'=>lang('obtain_ok'),'info'=>$info];
  354. }
  355. public function saveData($data)
  356. {
  357. $validate = \think\Loader::validate('Actor');
  358. if(!$validate->check($data)){
  359. return ['code'=>1001,'msg'=>lang('param_err').':'.$validate->getError() ];
  360. }
  361. $key = 'actor_detail_'.$data['actor_id'];
  362. Cache::rm($key);
  363. $key = 'actor_detail_'.$data['actor_en'];
  364. Cache::rm($key);
  365. $key = 'actor_detail_'.$data['actor_id'].'_'.$data['actor_en'];
  366. Cache::rm($key);
  367. $type_list = model('Type')->getCache('type_list');
  368. $type_info = $type_list[$data['type_id']];
  369. $data['type_id_1'] = $type_info['type_pid'];
  370. if(empty($data['actor_en'])){
  371. $data['actor_en'] = Pinyin::get($data['actor_name']);
  372. }
  373. if(empty($data['actor_letter'])){
  374. $data['actor_letter'] = strtoupper(substr($data['actor_en'],0,1));
  375. }
  376. if(!empty($data['actor_content'])) {
  377. $pattern_src = '/<img[\s\S]*?src\s*=\s*[\"|\'](.*?)[\"|\'][\s\S]*?>/';
  378. @preg_match_all($pattern_src, $data['actor_content'], $match_src1);
  379. if (!empty($match_src1)) {
  380. foreach ($match_src1[1] as $v1) {
  381. $v2 = str_replace($GLOBALS['config']['upload']['protocol'] . ':', 'mac:', $v1);
  382. $data['actor_content'] = str_replace($v1, $v2, $data['actor_content']);
  383. }
  384. }
  385. unset($match_src1);
  386. }
  387. if(empty($data['actor_blurb'])){
  388. $data['actor_blurb'] = mac_substring( strip_tags($data['actor_content']) ,100);
  389. }
  390. if($data['uptag']==1){
  391. $data['actor_tag'] = mac_get_tag($data['actor_name'], $data['actor_content']);
  392. }
  393. if($data['uptime']==1){
  394. $data['actor_time'] = time();
  395. }
  396. unset($data['uptime']);
  397. unset($data['uptag']);
  398. // xss过滤
  399. $filter_fields = [
  400. 'actor_name',
  401. 'actor_en',
  402. 'actor_alias',
  403. 'actor_color',
  404. 'actor_pic',
  405. 'actor_blurb',
  406. 'actor_remarks',
  407. 'actor_area',
  408. 'actor_height',
  409. 'actor_weight',
  410. 'actor_birthday',
  411. 'actor_birtharea',
  412. 'actor_blood',
  413. 'actor_starsign',
  414. 'actor_school',
  415. 'actor_works',
  416. 'actor_tag',
  417. 'actor_class',
  418. 'actor_tpl',
  419. 'actor_jumpurl',
  420. ];
  421. foreach ($filter_fields as $filter_field) {
  422. if (!isset($data[$filter_field])) {
  423. continue;
  424. }
  425. $data[$filter_field] = mac_filter_xss($data[$filter_field]);
  426. }
  427. if(!empty($data['actor_id'])){
  428. $where=[];
  429. $where['actor_id'] = ['eq',$data['actor_id']];
  430. $res = $this->allowField(true)->where($where)->update($data);
  431. }
  432. else{
  433. $data['actor_time_add'] = time();
  434. $data['actor_time'] = time();
  435. $res = $this->allowField(true)->insert($data);
  436. }
  437. if(false === $res){
  438. return ['code'=>1002,'msg'=>lang('save_err').':'.$this->getError() ];
  439. }
  440. return ['code'=>1,'msg'=>lang('save_ok')];
  441. }
  442. public function delData($where)
  443. {
  444. $list = $this->listData($where,'',1,9999);
  445. if($list['code'] !==1){
  446. return ['code'=>1001,'msg'=>lang('del_err').':'.$this->getError() ];
  447. }
  448. $path = './';
  449. foreach($list['list'] as $k=>$v){
  450. $pic = $path.$v['actor_pic'];
  451. if(file_exists($pic) && (substr($pic,0,8) == "./upload") || count( explode("./",$pic) ) ==1){
  452. unlink($pic);
  453. }
  454. if($GLOBALS['config']['view']['actor_detail'] ==2 ){
  455. $lnk = mac_url_actor_detail($v);
  456. $lnk = reset_html_filename($lnk);
  457. if(file_exists($lnk)){
  458. unlink($lnk);
  459. }
  460. }
  461. }
  462. $res = $this->where($where)->delete();
  463. if($res===false){
  464. return ['code'=>1001,'msg'=>lang('del_err').':'.$this->getError() ];
  465. }
  466. return ['code'=>1,'msg'=>lang('del_ok')];
  467. }
  468. public function fieldData($where,$update)
  469. {
  470. if(!is_array($update)){
  471. return ['code'=>1001,'msg'=>lang('param_err')];
  472. }
  473. $res = $this->allowField(true)->where($where)->update($update);
  474. if($res===false){
  475. return ['code'=>1001,'msg'=>lang('set_err').':'.$this->getError() ];
  476. }
  477. $list = $this->field('actor_id,actor_name,actor_en')->where($where)->select();
  478. foreach($list as $k=>$v){
  479. $key = 'actor_detail_'.$v['actor_id'];
  480. Cache::rm($key);
  481. $key = 'actor_detail_'.$v['actor_en'];
  482. Cache::rm($key);
  483. }
  484. return ['code'=>1,'msg'=>lang('set_ok')];
  485. }
  486. }