国内流行的内容管理系统(CMS)多端全媒体解决方案 https://www.dedebiz.com
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

470 lines
17KB

  1. <?php
  2. /**
  3. * 图集编辑
  4. *
  5. * @version $Id: album_edit.php 1 8:26 2010年7月12日Z tianya $
  6. * @package DedeCMS.Administrator
  7. * @copyright Copyright (c) 2007 - 2018, DesDev, Inc.
  8. * @copyright Copyright (c) 2020, DedeBIZ.COM
  9. * @license https://www.dedebiz.com/license/v6
  10. * @link https://www.dedebiz.com
  11. */
  12. require_once(dirname(__FILE__)."/config.php");
  13. CheckPurview('a_Edit,a_AccEdit,a_MyEdit');
  14. require_once(DEDEINC."/customfields.func.php");
  15. require_once(DEDEADMIN."/inc/inc_archives_functions.php");
  16. if(empty($dopost)) $dopost = '';
  17. if($dopost!='save')
  18. {
  19. require_once(DEDEADMIN."/inc/inc_catalog_options.php");
  20. require_once(DEDEINC."/dedetag.class.php");
  21. ClearMyAddon();
  22. $aid = intval($aid);
  23. //读取归档信息
  24. $arcQuery = "SELECT ch.typename as channelname,ar.membername as rankname,arc.*
  25. FROM `#@__archives` arc
  26. LEFT JOIN `#@__channeltype` ch ON ch.id=arc.channel
  27. LEFT JOIN `#@__arcrank` ar ON ar.rank=arc.arcrank WHERE arc.id='$aid' ";
  28. $arcRow = $dsql->GetOne($arcQuery);
  29. if(!is_array($arcRow))
  30. {
  31. ShowMsg("读取档案基本信息出错!","-1");
  32. exit();
  33. }
  34. $query = "SELECT * FROM `#@__channeltype` WHERE id='".$arcRow['channel']."'";
  35. $cInfos = $dsql->GetOne($query);
  36. if(!is_array($cInfos))
  37. {
  38. ShowMsg("读取频道配置信息出错!","javascript:;");
  39. exit();
  40. }
  41. $addtable = $cInfos['addtable'];
  42. $addRow = $dsql->GetOne("SELECT * FROM `$addtable` WHERE aid='$aid'");
  43. $channelid = $arcRow['channel'];
  44. $imgurls = $addRow["imgurls"];
  45. $maxwidth = $addRow["maxwidth"];
  46. $pagestyle = $addRow["pagestyle"];
  47. $irow = $addRow["row"];
  48. $icol = $addRow["col"];
  49. $isrm = $addRow["isrm"];
  50. $body = $addRow["body"];
  51. $ddmaxwidth = $addRow["ddmaxwidth"];
  52. $pagepicnum = $addRow["pagepicnum"];
  53. $tags = GetTags($aid);
  54. $arcRow=XSSClean($arcRow);$addRow=XSSClean($addRow);
  55. include DedeInclude("templets/album_edit.htm");
  56. exit();
  57. }
  58. /*--------------------------------
  59. function __save(){ }
  60. -------------------------------*/
  61. else if($dopost=='save')
  62. {
  63. require_once(DEDEINC.'/image.func.php');
  64. require_once(DEDEINC.'/oxwindow.class.php');
  65. $flag = isset($flags) ? join(',', $flags) : '';
  66. $notpost = isset($notpost) && $notpost == 1 ? 1: 0;
  67. if(empty($typeid2)) $typeid2 = 0;
  68. if(!isset($autokey)) $autokey = 0;
  69. if(!isset($remote)) $remote = 0;
  70. if(!isset($dellink)) $dellink = 0;
  71. if(!isset($autolitpic)) $autolitpic = 0;
  72. if(!isset($formhtml)) $formhtml = 0;
  73. if(!isset($albums)) $albums = "";
  74. if(!isset($formzip)) $formzip = 0;
  75. if(!isset($ddisfirst)) $ddisfirst = 0;
  76. if(!isset($delzip)) $delzip = 0;
  77. if($typeid==0)
  78. {
  79. ShowMsg("请指定文档的栏目!","-1");
  80. exit();
  81. }
  82. if(empty($channelid))
  83. {
  84. ShowMsg("文档为非指定的类型,请检查你发布内容的表单是否合法!","-1");
  85. exit();
  86. }
  87. if(!CheckChannel($typeid,$channelid))
  88. {
  89. ShowMsg("你所选择的栏目与当前模型不相符,请选择白色的选项!","-1");
  90. exit();
  91. }
  92. if(!TestPurview('a_Edit'))
  93. {
  94. if(TestPurview('a_AccEdit'))
  95. {
  96. CheckCatalog($typeid,"对不起,你没有操作栏目 {$typeid} 的文档权限!");
  97. }
  98. else
  99. {
  100. CheckArcAdmin($id,$cuserLogin->getUserID());
  101. }
  102. }
  103. //对保存的内容进行处理
  104. $pubdate = GetMkTime($pubdate);
  105. $sortrank = AddDay($pubdate,$sortup);
  106. $ismake = $ishtml==0 ? -1 : 0;
  107. $title = cn_substrR($title,$cfg_title_maxlen);
  108. $shorttitle = cn_substrR($shorttitle,36);
  109. $color = cn_substrR($color,7);
  110. $writer = cn_substrR($writer,20);
  111. $source = cn_substrR($source,30);
  112. $description = cn_substrR($description,250);
  113. $keywords = trim(cn_substrR($keywords,60));
  114. $filename = trim(cn_substrR($filename,40));
  115. $isremote = 0;
  116. $serviterm=empty($serviterm)? "" : $serviterm;
  117. if(!TestPurview('a_Check,a_AccCheck,a_MyCheck'))
  118. {
  119. $arcrank = -1;
  120. }
  121. $adminid = $cuserLogin->getUserID();
  122. //处理上传的缩略图
  123. if(empty($ddisremote))
  124. {
  125. $ddisremote = 0;
  126. }
  127. $litpic = GetDDImage('none', $picname, $ddisremote);
  128. // 处理新的缩略图上传
  129. if ($litpic_b64 != "") {
  130. $data = explode( ',', $litpic_b64 );
  131. $ntime = time();
  132. $savepath = $ddcfg_image_dir.'/'.MyDate($cfg_addon_savetype, $ntime);
  133. CreateDir($savepath);
  134. $fullUrl = $savepath.'/'.dd2char(MyDate('mdHis', $ntime).$cuserLogin->getUserID().mt_rand(1000, 9999));
  135. $fullUrl = $fullUrl.".png";
  136. file_put_contents($cfg_basedir.$fullUrl, base64_decode( $data[ 1 ] ));
  137. // 加水印
  138. WaterImg($cfg_basedir.$fullUrl, 'up');
  139. $litpic = $fullUrl;
  140. }
  141. //分析body里的内容
  142. $body = AnalyseHtmlBody($body, $description, $litpic, $keywords, 'htmltext');
  143. //处理图片文档的自定义属性
  144. if($litpic!='' && !preg_match("#p#", $flag))
  145. {
  146. $flag = ($flag=='' ? 'p' : $flag.',p');
  147. }
  148. if($redirecturl!='' && !preg_match("#j#", $flag))
  149. {
  150. $flag = ($flag=='' ? 'j' : $flag.',j');
  151. }
  152. //跳转网址的文档强制为动态
  153. if(preg_match("#j#", $flag)) $ismake = -1;
  154. //更新数据库的SQL语句
  155. $query = "
  156. UPDATE `#@__archives` SET
  157. typeid='$typeid',
  158. typeid2='$typeid2',
  159. sortrank='$sortrank',
  160. flag='$flag',
  161. click='$click',
  162. ismake='$ismake',
  163. arcrank='$arcrank',
  164. money='$money',
  165. title='$title',
  166. color='$color',
  167. source='$source',
  168. writer='$writer',
  169. litpic='$litpic',
  170. pubdate='$pubdate',
  171. notpost='$notpost',
  172. description='$description',
  173. keywords='$keywords',
  174. shorttitle='$shorttitle',
  175. filename='$filename',
  176. dutyadmin='$adminid'
  177. WHERE id='$id'; ";
  178. if(!$dsql->ExecuteNoneQuery($query))
  179. {
  180. ShowMsg("更新数据库archives表时出错,请检查!".$dsql->GetError(),"javascript:;");
  181. exit();
  182. }
  183. $imgurls = "{dede:pagestyle maxwidth='$maxwidth' pagepicnum='$pagepicnum' ddmaxwidth='$ddmaxwidth' row='$row' col='$col' value='$pagestyle'/}\r\n";
  184. $hasone = false;
  185. //----------------------------------------
  186. //检查旧的图片是否有更新,并保存
  187. //-----------------------------------------
  188. for($i=1; $i<=120; $i++)
  189. {
  190. if( !isset(${'imgurl'.$i}) ) continue;
  191. $info = '';
  192. $iinfo = str_replace("'", "`", stripslashes(${'imgmsg'.$i}));
  193. $iurl = stripslashes(${'imgurl'.$i});
  194. $ddurl = stripslashes(${'imgddurl'.$i});
  195. if(preg_match("#swfupload#i", $ddurl)) $ddurl = '';
  196. $imgfile = $cfg_basedir.$iurl;
  197. $litimgfile = $cfg_basedir.$ddurl;
  198. //有上传文件的情况
  199. if( isset(${'imgfile'.$i}) && is_uploaded_file(${'imgfile'.$i}) )
  200. {
  201. $tmpFile = ${'imgfile'.$i};
  202. //检测上传的图片, 如果类型不对,保留原来图片
  203. $imginfos = @GetImageSize($tmpFile, $info);
  204. if(!is_array($imginfos))
  205. {
  206. $imginfos = @GetImageSize($imgfile, $info);
  207. $imgurls .= "{dede:img ddimg='$ddurl' text='$iinfo' width='".$imginfos[0]."' height='".$imginfos[1]."'} $iurl {/dede:img}\r\n";
  208. continue;
  209. }
  210. move_uploaded_file($tmpFile, $imgfile);
  211. $imginfos = @GetImageSize($imgfile, $info);
  212. if($ddurl==$iurl)
  213. {
  214. $litpicname = $pagestyle > 2 ? GetImageMapDD($iurl, $cfg_ddimg_width) : $iurl;
  215. $litimgfile = $cfg_basedir.$litpicname;
  216. }
  217. else
  218. {
  219. if($cfg_ddimg_full=='Y') ImageResizeNew($imgfile, $cfg_ddimg_width, $cfg_ddimg_height, $litimgfile);
  220. else ImageResize($imgfile, $cfg_ddimg_width, $cfg_ddimg_height, $litimgfile);
  221. $litpicname = $ddurl;
  222. }
  223. $imgurls .= "{dede:img ddimg='$litpicname' text='$iinfo' width='".$imginfos[0]."' height='".$imginfos[1]."'} $iurl {/dede:img}\r\n";
  224. }
  225. //没上传图片(只修改msg信息)
  226. else
  227. {
  228. $iinfo = str_replace("'", "`", stripslashes(${'imgmsg'.$i}));
  229. $iurl = stripslashes(${'imgurl'.$i});
  230. $ddurl = stripslashes(${'imgddurl'.$i});
  231. if(preg_match("#swfupload#i", $ddurl))
  232. {
  233. $ddurl = $pagestyle > 2 ? GetImageMapDD($iurl, $cfg_ddimg_width) : $iurl;
  234. }
  235. $imginfos = @GetImageSize($imgfile, $info);
  236. $imgurls .= "{dede:img ddimg='$ddurl' text='$iinfo' width='".$imginfos[0]."' height='".$imginfos[1]."'} $iurl {/dede:img}\r\n";
  237. }
  238. }
  239. //----------------------------
  240. //从HTML中获取新图片
  241. //----------------------------
  242. if($formhtml==1 && !empty($imagebody))
  243. {
  244. $imagebody = stripslashes($imagebody);
  245. $imgurls .= GetCurContentAlbum($imagebody,$copysource,$litpicname);
  246. if($ddisfirst==1 && $litpic=="" && !empty($litpicname))
  247. {
  248. $litpic = $litpicname;
  249. $hasone = true;
  250. }
  251. }
  252. /*---------------------
  253. function _getformzip()
  254. 从ZIP文件中获取新图片
  255. ---------------------*/
  256. if($formzip==1)
  257. {
  258. include_once(DEDEINC."/zip.class.php");
  259. include_once(DEDEADMIN."/file_class.php");
  260. $zipfile = $cfg_basedir.str_replace($cfg_mainsite,'',$zipfile);
  261. $tmpzipdir = DEDEDATA.'/ziptmp/'.cn_substr(md5(ExecTime()),16);
  262. $ntime = time();
  263. if(file_exists($zipfile))
  264. {
  265. @mkdir($tmpzipdir,$GLOBALS['cfg_dir_purview']);
  266. @chmod($tmpzipdir,$GLOBALS['cfg_dir_purview']);
  267. $z = new zip();
  268. $z->ExtractAll($zipfile,$tmpzipdir);
  269. $fm = new FileManagement();
  270. $imgs = array();
  271. $fm->GetMatchFiles($tmpzipdir,"jpg|png|gif",$imgs);
  272. $i = 0;
  273. foreach($imgs as $imgold)
  274. {
  275. $i++;
  276. $savepath = $cfg_image_dir."/".MyDate("Y-m",$ntime);
  277. CreateDir($savepath);
  278. $iurl = $savepath."/".MyDate("d",$ntime).dd2char(MyDate("His",$ntime).'-'.$adminid."-{$i}".mt_rand(1000,9999));
  279. $iurl = $iurl.substr($imgold,-4,4);
  280. $imgfile = $cfg_basedir.$iurl;
  281. copy($imgold,$imgfile);
  282. unlink($imgold);
  283. if(is_file($imgfile))
  284. {
  285. $litpicname = $pagestyle > 2 ? GetImageMapDD($iurl,$cfg_ddimg_width) : $iurl;
  286. $info = '';
  287. $imginfos = GetImageSize($imgfile,$info);
  288. $imgurls .= "{dede:img ddimg='$litpicname' text='' width='".$imginfos[0]."' height='".$imginfos[1]."'} $iurl {/dede:img}\r\n";
  289. //把图片信息保存到媒体文档管理档案中
  290. $inquery = "
  291. INSERT INTO #@__uploads(title,url,mediatype,width,height,playtime,filesize,uptime,mid)
  292. VALUES ('{$title}','{$iurl}','1','".$imginfos[0]."','".$imginfos[1]."','0','".filesize($imgfile)."','".$ntime."','$adminid');
  293. ";
  294. $dsql->ExecuteNoneQuery($inquery);
  295. if(!$hasone && $ddisfirst==1
  296. && $litpic=="" && !empty($litpicname))
  297. {
  298. if( file_exists($cfg_basedir.$litpicname) )
  299. {
  300. $litpic = $litpicname;
  301. $hasone = true;
  302. }
  303. }
  304. }
  305. }
  306. if($delzip==1)
  307. {
  308. unlink($zipfile);
  309. }
  310. $fm->RmDirFiles($tmpzipdir);
  311. }
  312. }
  313. if ($albums !== "") {
  314. $albumsArr = json_decode(stripslashes( $albums), true);
  315. // var_dump($albumsArr);exit;
  316. for ($i=0; $i <= count($albumsArr) - 1; $i++) {
  317. $album = $albumsArr[$i];
  318. $data = explode( ',', $album['img'] );
  319. $ntime = time();
  320. $savepath = $ddcfg_image_dir.'/'.MyDate($cfg_addon_savetype, $ntime);
  321. CreateDir($savepath);
  322. $fullUrl = $savepath.'/'.dd2char(MyDate('mdHis', $ntime).$cuserLogin->getUserID().mt_rand(1000, 9999));
  323. $fullUrl = $fullUrl.".png";
  324. file_put_contents($cfg_basedir.$fullUrl, base64_decode( $data[ 1 ] ));
  325. $info = '';
  326. $imginfos = GetImageSize($cfg_basedir.$fullUrl, $info);
  327. $v = $fullUrl;
  328. $imginfo = !empty($album['txt']) ? $album['txt'] : '';
  329. $imgurls .= "{dede:img ddimg='$v' text='$imginfo' width='".$imginfos[0]."' height='".$imginfos[1]."'} $v {/dede:img}\r\n";
  330. }
  331. }
  332. $imgurls = addslashes($imgurls);
  333. //分析处理附加表数据
  334. $inadd_f = '';
  335. $inadd_v = '';
  336. if(!empty($dede_addonfields))
  337. {
  338. $addonfields = explode(';', $dede_addonfields);
  339. $inadd_f = '';
  340. $inadd_v = '';
  341. if(is_array($addonfields))
  342. {
  343. foreach($addonfields as $v)
  344. {
  345. if($v=='')
  346. {
  347. continue;
  348. }
  349. $vs = explode(',',$v);
  350. if($vs[1]=='htmltext'||$vs[1]=='textdata') //HTML文本特殊处理
  351. {
  352. ${$vs[0]} = AnalyseHtmlBody(${$vs[0]},$description,$litpic,$keywords,$vs[1]);
  353. }else{
  354. if(!isset(${$vs[0]}))
  355. {
  356. ${$vs[0]} = '';
  357. }
  358. ${$vs[0]} = GetFieldValueA(${$vs[0]},$vs[1],$id);
  359. }
  360. $inadd_f .= ",`{$vs[0]}` = '".${$vs[0]}."'";
  361. }
  362. }
  363. }
  364. //更新附加表
  365. $cts = $dsql->GetOne("SELECT addtable FROM `#@__channeltype` WHERE id='$channelid' ");
  366. $addtable = trim($cts['addtable']);
  367. if($addtable!='')
  368. {
  369. $useip = GetIP();
  370. $query = "Update `$addtable`
  371. set typeid='$typeid',
  372. pagestyle='$pagestyle',
  373. body='$body',
  374. maxwidth = '$maxwidth',
  375. ddmaxwidth = '$ddmaxwidth',
  376. pagepicnum = '$pagepicnum',
  377. imgurls='$imgurls',
  378. `row`='$row',
  379. col='$col',
  380. isrm='$isrm'{$inadd_f},
  381. redirecturl='$redirecturl',
  382. userip = '$useip'
  383. WHERE aid='$id'; ";
  384. if(!$dsql->ExecuteNoneQuery($query))
  385. {
  386. ShowMsg("更新附加表 `$addtable` 时出错,请检查原因!".$dsql->GetError(),"javascript:;");
  387. exit();
  388. }
  389. }
  390. //生成HTML
  391. UpIndexKey($id,$arcrank,$typeid,$sortrank,$tags);
  392. if($cfg_remote_site=='Y' && $isremote=="1")
  393. {
  394. if($serviterm!=""){
  395. list($servurl,$servuser,$servpwd) = explode(',',$serviterm);
  396. $config=array( 'hostname' => $servurl, 'username' => $servuser, 'password' => $servpwd,'debug' => 'TRUE');
  397. }else{
  398. $config=array();
  399. }
  400. if(!$ftp->connect($config)) exit('Error:None FTP Connection!');
  401. }
  402. $arcUrl = MakeArt($id,true,true,$isremote);
  403. if($arcUrl=='')
  404. {
  405. $arcUrl = $cfg_phpurl."/view.php?aid=$id";
  406. }
  407. ClearMyAddon($id, $title);
  408. // 自动更新关联内容
  409. if (is_array($automake)) {
  410. foreach ($automake as $key => $value) {
  411. if (isset(${$key}) && !empty(${$key})) {
  412. $ids = explode(",", ${$key});
  413. foreach ($ids as $id) {
  414. MakeArt($id,true,true,$isremote);
  415. }
  416. }
  417. }
  418. }
  419. //返回成功信息
  420. $msg =
  421. "   请选择你的后续操作:
  422. <a href='album_add.php?cid=$typeid' class='btn btn-secondary btn-sm'>继续发布图片</a>
  423. &nbsp;&nbsp;
  424. <a href='archives_do.php?aid=".$id."&dopost=editArchives' class='btn btn-secondary btn-sm'>查看更改</a>
  425. &nbsp;&nbsp;
  426. <a href='$arcUrl' target='_blank' class='btn btn-secondary btn-sm'>预览文档</a>
  427. &nbsp;&nbsp;
  428. <a href='catalog_do.php?cid=$typeid&dopost=listArchives' class='btn btn-secondary btn-sm'>管理已发布图片</a>
  429. &nbsp;&nbsp;
  430. $backurl
  431. ";
  432. $wintitle = "成功更改图集!";
  433. $wecome_info = "文章管理::更改图集";
  434. $win = new OxWindow();
  435. $win->AddTitle("成功更改一个图集:");
  436. $win->AddMsgItem($msg);
  437. $winform = $win->GetWindow("hand","&nbsp;",false);
  438. $win->Display();
  439. }