国内流行的内容管理系统(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.

433 lines
15KB

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