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

413 lines
16KB

  1. <?php
  2. /**
  3. * 图集发布
  4. *
  5. * @version $Id: album_add.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_New,a_AccNew');
  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(DEDEINC."/dedetag.class.php");
  19. require_once(DEDEADMIN."/inc/inc_catalog_options.php");
  20. ClearMyAddon();
  21. $channelid = empty($channelid) ? 0 : intval($channelid);
  22. $cid = empty($cid) ? 0 : intval($cid);
  23. //获得频道模型ID
  24. if($cid>0 && $channelid==0)
  25. {
  26. $row = $dsql->GetOne("SELECT channeltype FROM `#@__arctype` WHERE id='$cid'; ");
  27. $channelid = $row['channeltype'];
  28. }
  29. else
  30. {
  31. if($channelid==0) $channelid = 2;
  32. }
  33. //获得频道模型信息
  34. $cInfos = $dsql->GetOne(" SELECT * FROM `#@__channeltype` WHERE id='$channelid' ");
  35. $channelid = $cInfos['id'];
  36. //获取文章最大id以确定当前权重
  37. $maxWright = $dsql->GetOne("SELECT COUNT(*) AS cc FROM #@__archives");
  38. include DedeInclude("templets/album_add.htm");
  39. exit();
  40. }
  41. /*--------------------------------
  42. function __save(){ }
  43. -------------------------------*/
  44. else if($dopost=='save')
  45. {
  46. require_once(DEDEINC.'/image.func.php');
  47. require_once(DEDEINC.'/oxwindow.class.php');
  48. $flag = isset($flags) ? join(',',$flags) : '';
  49. $notpost = isset($notpost) && $notpost == 1 ? 1: 0;
  50. if(empty($click)) $click = ($cfg_arc_click=='-1' ? mt_rand(50, 200) : $cfg_arc_click);
  51. if(!isset($typeid2)) $typeid2 = 0;
  52. if(!isset($autokey)) $autokey = 0;
  53. if(!isset($remote)) $remote = 0;
  54. if(!isset($dellink)) $dellink = 0;
  55. if(!isset($autolitpic)) $autolitpic = 0;
  56. if(!isset($formhtml)) $formhtml = 0;
  57. if(!isset($formzip)) $formzip = 0;
  58. if(!isset($ddisfirst)) $ddisfirst = 0;
  59. if(!isset($albums)) $albums = "";
  60. if(!isset($delzip)) $delzip = 0;
  61. if(empty($click)) $click = ($cfg_arc_click=='-1' ? mt_rand(50, 200) : $cfg_arc_click);
  62. if($typeid==0)
  63. {
  64. ShowMsg("请指定文档的栏目!", "-1");
  65. exit();
  66. }
  67. if(empty($channelid))
  68. {
  69. ShowMsg("文档为非指定的类型,请检查你发布内容的表单是否合法!","-1");
  70. exit();
  71. }
  72. if(!CheckChannel($typeid,$channelid) )
  73. {
  74. ShowMsg("你所选择的栏目与当前模型不相符,请选择白色的选项!","-1");
  75. exit();
  76. }
  77. if(!TestPurview('a_New'))
  78. {
  79. CheckCatalog($typeid,"对不起,你没有操作栏目 {$typeid} 的权限!");
  80. }
  81. //对保存的内容进行处理
  82. if(empty($writer))$writer=$cuserLogin->getUserName();
  83. if(empty($source))$source='未知';
  84. $pubdate = GetMkTime($pubdate);
  85. $senddate = time();
  86. $sortrank = AddDay($pubdate,$sortup);
  87. $ismake = $ishtml==0 ? -1 : 0;
  88. $title = preg_replace("#\"#", '"', $title);
  89. $title = cn_substrR($title,$cfg_title_maxlen);
  90. $shorttitle = cn_substrR($shorttitle,36);
  91. $color = cn_substrR($color,7);
  92. $writer = cn_substrR($writer,20);
  93. $source = cn_substrR($source,30);
  94. $description = cn_substrR($description,$cfg_auot_description);
  95. $keywords = cn_substrR($keywords,60);
  96. $filename = trim(cn_substrR($filename,40));
  97. $userip = GetIP();
  98. $isremote = (empty($isremote)? 0 : $isremote);
  99. $serviterm=empty($serviterm)? "" : $serviterm;
  100. if(!TestPurview('a_Check,a_AccCheck,a_MyCheck'))
  101. {
  102. $arcrank = -1;
  103. }
  104. $adminid = $cuserLogin->getUserID();
  105. //处理上传的缩略图
  106. if(empty($ddisremote))
  107. {
  108. $ddisremote = 0;
  109. }
  110. $litpic = GetDDImage('none',$picname,$ddisremote);
  111. // 处理新的缩略图上传
  112. if ($litpic_b64 != "") {
  113. $data = explode( ',', $litpic_b64 );
  114. $ntime = time();
  115. $savepath = $ddcfg_image_dir.'/'.MyDate($cfg_addon_savetype, $ntime);
  116. CreateDir($savepath);
  117. $fullUrl = $savepath.'/'.dd2char(MyDate('mdHis', $ntime).$cuserLogin->getUserID().mt_rand(1000, 9999));
  118. $fullUrl = $fullUrl.".png";
  119. file_put_contents($cfg_basedir.$fullUrl, base64_decode( $data[ 1 ] ));
  120. // 加水印
  121. WaterImg($cfg_basedir.$fullUrl, 'up');
  122. $litpic = $fullUrl;
  123. }
  124. //使用第一张图作为缩略图
  125. if($ddisfirst==1 && $litpic=='')
  126. {
  127. if(isset($imgurl1))
  128. {
  129. $litpic = GetDDImage('ddfirst', $imgurl1, $isrm);
  130. }
  131. }
  132. // 处理新的缩略图上传
  133. if ($litpic_b64 != "") {
  134. $data = explode( ',', $litpic_b64 );
  135. $ntime = time();
  136. $savepath = $ddcfg_image_dir.'/'.MyDate($cfg_addon_savetype, $ntime);
  137. CreateDir($savepath);
  138. $fullUrl = $savepath.'/'.dd2char(MyDate('mdHis', $ntime).$cuserLogin->getUserID().mt_rand(1000, 9999));
  139. $fullUrl = $fullUrl.".png";
  140. file_put_contents($cfg_basedir.$fullUrl, base64_decode( $data[ 1 ] ));
  141. // 加水印
  142. WaterImg($cfg_basedir.$fullUrl, 'up');
  143. $litpic = $fullUrl;
  144. }
  145. //生成文档ID
  146. $arcID = GetIndexKey($arcrank,$typeid,$sortrank,$channelid,$senddate,$adminid);
  147. if(empty($arcID))
  148. {
  149. ShowMsg("无法获得主键,因此无法进行后续操作!","-1");
  150. exit();
  151. }
  152. $imgurls = "{dede:pagestyle maxwidth='$maxwidth' pagepicnum='$pagepicnum' ddmaxwidth='$ddmaxwidth' row='$row' col='$col' value='$pagestyle'/}\r\n";
  153. $hasone = FALSE;
  154. //处理并保存从网上复制的图片
  155. /*---------------------
  156. function _getformhtml()
  157. ------------------*/
  158. if($formhtml==1)
  159. {
  160. $imagebody = stripslashes($imagebody);
  161. $imgurls .= GetCurContentAlbum($imagebody,$copysource,$litpicname);
  162. if($ddisfirst==1 && $litpic=='' && !empty($litpicname))
  163. {
  164. $litpic = $litpicname;
  165. $hasone = TRUE;
  166. }
  167. }
  168. /*---------------------
  169. function _getformzip()
  170. 处理从ZIP中解压的图片
  171. ---------------------*/
  172. if($formzip==1)
  173. {
  174. include_once(DEDEINC."/zip.class.php");
  175. include_once(DEDEADMIN."/file_class.php");
  176. $zipfile = $cfg_basedir.str_replace($cfg_mainsite,'',$zipfile);
  177. $tmpzipdir = DEDEDATA.'/ziptmp/'.cn_substr(md5(ExecTime()),16);
  178. $ntime = time();
  179. if(file_exists($zipfile))
  180. {
  181. @mkdir($tmpzipdir,$GLOBALS['cfg_dir_purview']);
  182. @chmod($tmpzipdir,$GLOBALS['cfg_dir_purview']);
  183. $z = new zip();
  184. $z->ExtractAll($zipfile,$tmpzipdir);
  185. $fm = new FileManagement();
  186. $imgs = array();
  187. $fm->GetMatchFiles($tmpzipdir,"jpg|png|gif",$imgs);
  188. $i = 0;
  189. foreach($imgs as $imgold)
  190. {
  191. $i++;
  192. $savepath = $cfg_image_dir."/".MyDate("Y-m",$ntime);
  193. CreateDir($savepath);
  194. $iurl = $savepath."/".MyDate("d",$ntime).dd2char(MyDate("His",$ntime).'-'.$adminid."-{$i}".mt_rand(1000,9999));
  195. $iurl = $iurl.substr($imgold,-4,4);
  196. $imgfile = $cfg_basedir.$iurl;
  197. copy($imgold,$imgfile);
  198. unlink($imgold);
  199. if(is_file($imgfile))
  200. {
  201. $litpicname = $pagestyle > 2 ? GetImageMapDD($iurl,$cfg_ddimg_width) : $iurl;
  202. //指定了提取第一张为缩略图的情况强制使用第一张缩略图
  203. if($i=='1')
  204. {
  205. if(!$hasone && $ddisfirst==1 && $litpic=='' && empty($litpicname))
  206. {
  207. $litpicname = GetImageMapDD($iurl,$cfg_ddimg_width);
  208. }
  209. }
  210. $info = '';
  211. $imginfos = GetImageSize($imgfile,$info);
  212. $imgurls .= "{dede:img ddimg='$litpicname' text='' width='".$imginfos[0]."' height='".$imginfos[1]."'} $iurl {/dede:img}\r\n";
  213. //把图片信息保存到媒体文档管理档案中
  214. $inquery = "
  215. INSERT INTO #@__uploads(title,url,mediatype,width,height,playtime,filesize,uptime,mid)
  216. VALUES ('{$title}','{$iurl}','1','".$imginfos[0]."','".$imginfos[1]."','0','".filesize($imgfile)."','".$ntime."','$adminid');
  217. ";
  218. $dsql->ExecuteNoneQuery($inquery);
  219. $fid = $dsql->GetLastID();
  220. AddMyAddon($fid, $iurl);
  221. WaterImg($imgfile, 'up');
  222. if(!$hasone && $ddisfirst==1 && $litpic=='')
  223. {
  224. if(empty($litpicname))
  225. {
  226. $litpicname = $iurl;
  227. $litpicname = GetImageMapDD($iurl, $cfg_ddimg_width);
  228. }
  229. $litpic = $litpicname;
  230. $hasone = TRUE;
  231. }
  232. }
  233. }
  234. if($delzip==1) unlink($zipfile);
  235. $fm->RmDirFiles($tmpzipdir);
  236. }
  237. }
  238. if ($albums !== "") {
  239. $albumsArr = json_decode(stripslashes( $albums), true);
  240. for ($i=0; $i <= count($albumsArr) - 1; $i++) {
  241. $album = $albumsArr[$i];
  242. $data = explode( ',', $album['img'] );
  243. $ntime = time();
  244. $savepath = $ddcfg_image_dir.'/'.MyDate($cfg_addon_savetype, $ntime);
  245. CreateDir($savepath);
  246. $fullUrl = $savepath.'/'.dd2char(MyDate('mdHis', $ntime).$cuserLogin->getUserID().mt_rand(1000, 9999));
  247. $fullUrl = $fullUrl.".png";
  248. file_put_contents($cfg_basedir.$fullUrl, base64_decode( $data[ 1 ] ));
  249. $info = '';
  250. $imginfos = GetImageSize($cfg_basedir.$fullUrl, $info);
  251. $v = $fullUrl;
  252. $imginfo = !empty($album['txt']) ? $album['txt'] : '';
  253. $imgurls .= "{dede:img ddimg='$v' text='$imginfo' width='".$imginfos[0]."' height='".$imginfos[1]."'} $v {/dede:img}\r\n";
  254. }
  255. }
  256. $imgurls = addslashes($imgurls);
  257. //处理body字段自动摘要、自动提取缩略图等
  258. $body = AnalyseHtmlBody($body,$description,$litpic,$keywords,'htmltext');
  259. //分析处理附加表数据
  260. $inadd_f = '';
  261. $inadd_v = '';
  262. if(!empty($dede_addonfields))
  263. {
  264. $addonfields = explode(';',$dede_addonfields);
  265. $inadd_f = '';
  266. $inadd_v = '';
  267. if(is_array($addonfields))
  268. {
  269. foreach($addonfields as $v)
  270. {
  271. if($v=='')
  272. {
  273. continue;
  274. }
  275. $vs = explode(',',$v);
  276. if(!isset(${$vs[0]}))
  277. {
  278. ${$vs[0]} = '';
  279. }
  280. else if($vs[1]=='htmltext'||$vs[1]=='textdata') //HTML文本特殊处理
  281. {
  282. ${$vs[0]} = AnalyseHtmlBody(${$vs[0]},$description,$litpic,$keywords,$vs[1]);
  283. }
  284. else
  285. {
  286. if(!isset(${$vs[0]}))
  287. {
  288. ${$vs[0]} = '';
  289. }
  290. ${$vs[0]} = GetFieldValueA(${$vs[0]},$vs[1],$arcID);
  291. }
  292. $inadd_f .= ','.$vs[0];
  293. $inadd_v .= " ,'".${$vs[0]}."' ";
  294. }
  295. }
  296. }
  297. //处理图片文档的自定义属性
  298. if($litpic!='' && !preg_match("#p#", $flag))
  299. {
  300. $flag = ($flag=='' ? 'p' : $flag.',p');
  301. }
  302. if($redirecturl!='' && !preg_match("#j#", $flag))
  303. {
  304. $flag = ($flag=='' ? 'j' : $flag.',j');
  305. }
  306. //跳转网址的文档强制为动态
  307. if(preg_match("#j#", $flag)) $ismake = -1;
  308. //加入主档案表
  309. $query = "INSERT INTO `#@__archives`(id,typeid,typeid2,sortrank,flag,ismake,channel,arcrank,click,money,title,shorttitle,
  310. color,writer,source,litpic,pubdate,senddate,mid,notpost,description,keywords,filename,dutyadmin,weight)
  311. VALUES ('$arcID','$typeid','$typeid2','$sortrank','$flag','$ismake','$channelid','$arcrank','$click','$money','$title','$shorttitle',
  312. '$color','$writer','$source','$litpic','$pubdate','$senddate','$adminid','$notpost','$description','$keywords','$filename','$adminid','$weight'); ";
  313. if(!$dsql->ExecuteNoneQuery($query))
  314. {
  315. $gerr = $dsql->GetError();
  316. $dsql->ExecuteNoneQuery(" DELETE FROM `#@__arctiny` WHERE id='$arcID' ");
  317. ShowMsg("把数据保存到数据库主表 `#@__archives` 时出错,请把相关信息提交给DedeCMS官方。".str_replace('"','',$gerr),"javascript:;");
  318. exit();
  319. }
  320. //加入附加表
  321. $cts = $dsql->GetOne("SELECT addtable FROM `#@__channeltype` WHERE id='$channelid' ");
  322. $addtable = trim($cts['addtable']);
  323. if(empty($addtable))
  324. {
  325. $dsql->ExecuteNoneQuery("DELETE FROM `#@__archives` WHERE id='$arcID'");
  326. $dsql->ExecuteNoneQuery("DELETE FROM `#@__arctiny` WHERE id='$arcID'");
  327. ShowMsg("没找到当前模型[{$channelid}]的主表信息,无法完成操作!。","javascript:;");
  328. exit();
  329. }
  330. $useip = GetIP();
  331. $query = "INSERT INTO `$addtable`(aid,typeid,redirecturl,userip,pagestyle,maxwidth,imgurls,`row`,col,isrm,ddmaxwidth,pagepicnum,body{$inadd_f})
  332. Values('$arcID','$typeid','$redirecturl','$useip','$pagestyle','$maxwidth','$imgurls','$row','$col','$isrm','$ddmaxwidth','$pagepicnum','$body'{$inadd_v}); ";
  333. if(!$dsql->ExecuteNoneQuery($query))
  334. {
  335. $gerr = $dsql->GetError();
  336. $dsql->ExecuteNoneQuery("DELETE FROM `#@__archives` WHERE id='$arcID'");
  337. $dsql->ExecuteNoneQuery("DELETE FROM `#@__arctiny` WHERE id='$arcID'");
  338. ShowMsg("把数据保存到数据库附加表 `{$addtable}` 时出错,请把相关信息提交给DedeCMS官方。".str_replace('"','',$gerr),"javascript:;");
  339. exit();
  340. }
  341. //生成HTML
  342. InsertTags($tags,$arcID);
  343. if($cfg_remote_site=='Y' && $isremote=="1")
  344. {
  345. if($serviterm!=""){
  346. list($servurl,$servuser,$servpwd) = explode(',',$serviterm);
  347. $config=array( 'hostname' => $servurl, 'username' => $servuser, 'password' => $servpwd,'debug' => 'TRUE');
  348. }else{
  349. $config=array();
  350. }
  351. if(!$ftp->connect($config)) exit('Error:None FTP Connection!');
  352. }
  353. $artUrl = MakeArt($arcID, TRUE, TRUE, $isremote);
  354. if($artUrl=='')
  355. {
  356. $artUrl = $cfg_phpurl."/view.php?aid=$arcID";
  357. }
  358. ClearMyAddon($arcID, $title);
  359. //返回成功信息
  360. $msg = "
  361.   请选择你的后续操作:
  362. <a href='album_add.php?cid=$typeid'><u>继续发布图片</u></a>
  363. &nbsp;&nbsp;
  364. <a href='archives_do.php?aid=".$arcID."&dopost=editArchives'><u>更改图集</u></a>
  365. &nbsp;&nbsp;
  366. <a href='$artUrl' target='_blank'><u>预览文档</u></a>
  367. &nbsp;&nbsp;
  368. <a href='catalog_do.php?cid=$typeid&dopost=listArchives'><u>已发布图片管理</u></a>
  369. &nbsp;&nbsp;
  370. $backurl
  371. ";
  372. $msg = "<div style=\"line-height:36px;height:36px\">{$msg}</div>".GetUpdateTest();
  373. $wintitle = "成功发布一个图集!";
  374. $wecome_info = "文章管理::发布图集";
  375. $win = new OxWindow();
  376. $win->AddTitle("成功发布一个图集:");
  377. $win->AddMsgItem($msg);
  378. $winform = $win->GetWindow("hand","&nbsp;",FALSE);
  379. $win->Display();
  380. }