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

330 lines
12KB

  1. <?php
  2. /**
  3. * 软件发布
  4. *
  5. * @version $Id: soft_add.php 1 16:09 2010年7月20日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. } else {
  29. if($channelid==0) $channelid = 1;
  30. }
  31. $softconfig = $dsql->GetOne("SELECT * FROM `#@__softconfig` ");
  32. //获得频道模型信息
  33. $cInfos = $dsql->GetOne(" SELECT * FROM `#@__channeltype` WHERE id='$channelid' ");
  34. $channelid = $cInfos['id'];
  35. //获取文章最大id以确定当前权重
  36. $maxWright = $dsql->GetOne("SELECT COUNT(*) AS cc FROM #@__archives");
  37. include DedeInclude("templets/soft_add.htm");
  38. exit();
  39. }
  40. /*--------------------------------
  41. function __save(){ }
  42. -------------------------------*/
  43. else if($dopost=='save')
  44. {
  45. require_once(DEDEINC.'/image.func.php');
  46. require_once(DEDEINC.'/oxwindow.class.php');
  47. $flag = isset($flags) ? join(',',$flags) : '';
  48. $notpost = isset($notpost) && $notpost == 1 ? 1: 0;
  49. if(empty($click)) $click = ($cfg_arc_click=='-1' ? mt_rand(50, 200) : $cfg_arc_click);
  50. if(!isset($typeid2)) $typeid2 = 0;
  51. if(!isset($autokey)) $autokey = 0;
  52. if(!isset($remote)) $remote = 0;
  53. if(!isset($dellink)) $dellink = 0;
  54. if(!isset($autolitpic)) $autolitpic = 0;
  55. if($typeid==0)
  56. {
  57. ShowMsg("请指定文档的栏目!","-1");
  58. exit();
  59. }
  60. if(empty($channelid))
  61. {
  62. ShowMsg("文档为非指定的类型,请检查你发布内容的表单是否合法!","-1");
  63. exit();
  64. }
  65. if(!CheckChannel($typeid,$channelid) )
  66. {
  67. ShowMsg("你所选择的栏目与当前模型不相符,请选择白色的选项!","-1");
  68. exit();
  69. }
  70. if(!TestPurview('a_New'))
  71. {
  72. CheckCatalog($typeid,"对不起,你没有操作栏目 {$typeid} 的权限!");
  73. }
  74. //对保存的内容进行处理
  75. if(empty($writer))$writer=$cuserLogin->getUserName();
  76. if(empty($source))$source='未知';
  77. $pubdate = GetMkTime($pubdate);
  78. $senddate = time();
  79. $sortrank = AddDay($pubdate,$sortup);
  80. if($ishtml==0) $ismake = -1;
  81. else $ismake = 0;
  82. if(empty($click)) $click = ($cfg_arc_click=='-1' ? mt_rand(50, 200) : $cfg_arc_click);
  83. $title = preg_replace('#"#', '"', $title);
  84. $title = cn_substrR($title, $cfg_title_maxlen);
  85. $shorttitle = cn_substrR($shorttitle, 36);
  86. $color = cn_substrR($color, 7);
  87. $writer = cn_substrR($writer, 20);
  88. $source = cn_substrR($source, 30);
  89. $description = cn_substrR($description, $cfg_auot_description);
  90. $keywords = cn_substrR($keywords, 60);
  91. $filename = trim(cn_substrR($filename, 40));
  92. $userip = GetIP();
  93. $isremote = (empty($isremote)? 0 : $isremote);
  94. $serviterm=empty($serviterm)? "" : $serviterm;
  95. if(!TestPurview('a_Check,a_AccCheck,a_MyCheck'))
  96. {
  97. $arcrank = -1;
  98. }
  99. $adminid = $cuserLogin->getUserID();
  100. //处理上传的缩略图
  101. if(empty($ddisremote)) $ddisremote = 0;
  102. $litpic = GetDDImage('none', $picname, $ddisremote);
  103. // 处理新的缩略图上传
  104. if ($litpic_b64 != "") {
  105. $data = explode( ',', $litpic_b64 );
  106. $ntime = time();
  107. $savepath = $ddcfg_image_dir.'/'.MyDate($cfg_addon_savetype, $ntime);
  108. CreateDir($savepath);
  109. $fullUrl = $savepath.'/'.dd2char(MyDate('mdHis', $ntime).$cuserLogin->getUserID().mt_rand(1000, 9999));
  110. $fullUrl = $fullUrl.".png";
  111. file_put_contents($cfg_basedir.$fullUrl, base64_decode( $data[ 1 ] ));
  112. // 加水印
  113. WaterImg($cfg_basedir.$fullUrl, 'up');
  114. $litpic = $fullUrl;
  115. }
  116. //生成文档ID
  117. $arcID = GetIndexKey($arcrank, $typeid, $sortrank, $channelid, $senddate, $adminid);
  118. if(empty($arcID))
  119. {
  120. ShowMsg("无法获得主键,因此无法进行后续操作!","-1");
  121. exit();
  122. }
  123. //处理body字段自动摘要、自动提取缩略图等
  124. $body = AnalyseHtmlBody($body, $description, $litpic, $keywords, 'htmltext');
  125. //分析处理附加表数据
  126. $inadd_f = '';
  127. $inadd_v = '';
  128. if(!empty($dede_addonfields))
  129. {
  130. $addonfields = explode(';', $dede_addonfields);
  131. $inadd_f = '';
  132. $inadd_v = '';
  133. if(is_array($addonfields))
  134. {
  135. foreach($addonfields as $v)
  136. {
  137. if($v=='')
  138. {
  139. continue;
  140. }
  141. $vs = explode(',',$v);
  142. if(!isset(${$vs[0]}))
  143. {
  144. ${$vs[0]} = '';
  145. }
  146. else if($vs[1]=='htmltext'||$vs[1]=='textdata') //HTML文本特殊处理
  147. {
  148. ${$vs[0]} = AnalyseHtmlBody(${$vs[0]},$description,$litpic,$keywords,$vs[1]);
  149. }
  150. else
  151. {
  152. if(!isset(${$vs[0]}))
  153. {
  154. ${$vs[0]} = '';
  155. }
  156. ${$vs[0]} = GetFieldValueA(${$vs[0]},$vs[1],$arcID);
  157. }
  158. $inadd_f .= ','.$vs[0];
  159. $inadd_v .= " ,'".${$vs[0]}."' ";
  160. }
  161. }
  162. }
  163. //处理图片文档的自定义属性
  164. if($litpic!='' && !preg_match('#p#', $flag))
  165. {
  166. $flag = ($flag=='' ? 'p' : $flag.',p');
  167. }
  168. if($redirecturl!='' && !preg_match('#j#', $flag))
  169. {
  170. $flag = ($flag=='' ? 'j' : $flag.',j');
  171. }
  172. //跳转网址的文档强制为动态
  173. if(preg_match('#j#', $flag)) $ismake = -1;
  174. //保存到主表
  175. $inQuery = "INSERT INTO `#@__archives`(id,typeid,typeid2,sortrank,flag,ismake,channel,arcrank,click,money,title,shorttitle,
  176. color,writer,source,litpic,pubdate,senddate,mid,notpost,description,keywords,filename,dutyadmin,weight)
  177. VALUES ('$arcID','$typeid','$typeid2','$sortrank','$flag','$ismake','$channelid','$arcrank','$click','$money','$title','$shorttitle',
  178. '$color','$writer','$source','$litpic','$pubdate','$senddate','$adminid','$notpost','$description','$keywords','$filename','$adminid','$weight');";
  179. if(!$dsql->ExecuteNoneQuery($inQuery))
  180. {
  181. $gerr = $dsql->GetError();
  182. $dsql->ExecuteNoneQuery("DELETE FROM `#@__arctiny` WHERE id='$arcID'");
  183. ShowMsg("把数据保存到数据库主表 `#@__archives` 时出错,请把相关信息提交给DedeCMS官方。".str_replace('"','',$gerr),"javascript:;");
  184. exit();
  185. }
  186. //软件链接列表
  187. $urls = '';
  188. //本地链接处理
  189. $softurl1 = stripslashes($softurl1);
  190. $nsoftsize = '';
  191. if($softurl1 != '')
  192. {
  193. $urls .= "{dede:link islocal='1' text='{$servermsg1}'} $softurl1 {/dede:link}\r\n";
  194. $autosize = empty($autosize) ? FALSE : TRUE;
  195. if($autosize && empty($softsize))
  196. {
  197. $nsoftsize = @filesize($cfg_basedir.$softurl1);
  198. if(empty($nsoftsize)) $nsoftsize = '未知';
  199. else
  200. {
  201. $nsoftsize = trim(sprintf("%0.2f", $nsoftsize / 1024 / 1024));
  202. $nsoftsize = $nsoftsize." MB";
  203. }
  204. }
  205. }
  206. //软件大小
  207. if(!empty($nsoftsize)) $softsize = $nsoftsize;
  208. else if(empty($softsize)) $softsize = '未知';
  209. else $softsize = $softsize.' '.$unit;
  210. //其它链接处理
  211. for($i=2; $i<=30; $i++)
  212. {
  213. if(!empty(${'softurl'.$i}))
  214. {
  215. $forconfig = empty(${'forconfig'.$i}) ? FALSE : TRUE;
  216. if($forconfig)
  217. {
  218. if(empty(${'need'.$i})) continue;
  219. $serverUrl = stripslashes(${'softurlfirst'.$i});
  220. $serverUrl = preg_replace("#\/$#", "", $serverUrl);
  221. $softurl = stripslashes(${'softurl'.$i});
  222. if( cn_substr($softurl, 1) != '/' ) $softurl = '/'.$softurl;
  223. $softurl = $serverUrl.$softurl;
  224. }
  225. else
  226. {
  227. $softurl = stripslashes(${'softurl'.$i});
  228. }
  229. $servermsg = str_replace("'", "", stripslashes(${'servermsg'.$i}));
  230. if($servermsg=='') $servermsg = '下载地址'.$i;
  231. if($softurl != 'http://')
  232. {
  233. $urls .= "{dede:link text='$servermsg'} $softurl {/dede:link}\r\n";
  234. }
  235. }
  236. }
  237. $urls = addslashes($urls);
  238. //保存到附加表
  239. $cts = $dsql->GetOne("SELECT addtable FROM `#@__channeltype` WHERE id='$channelid' ");
  240. $addtable = trim($cts['addtable']);
  241. if(empty($addtable))
  242. {
  243. $dsql->ExecuteNoneQuery("DELETE FROM `#@__archives` WHERE id='$arcID'");
  244. $dsql->ExecuteNoneQuery("DELETE FROM `#@__arctiny` WHERE id='$arcID'");
  245. ShowMsg("没找到当前模型[{$channelid}]的主表信息,无法完成操作!。","javascript:;");
  246. exit();
  247. }
  248. $daccess = isset($daccess) && is_numeric($daccess) ? $daccess : 0;
  249. $useip = GetIP();
  250. $inQuery = "INSERT INTO `$addtable`(aid,typeid,redirecturl,userip,filetype,language,softtype,accredit,
  251. os,softrank,officialUrl,officialDemo,softsize,softlinks,introduce,daccess,needmoney{$inadd_f})
  252. VALUES ('$arcID','$typeid','$redirecturl','$useip','$filetype','$language','$softtype','$accredit',
  253. '$os','$softrank','$officialUrl','$officialDemo','$softsize','$urls','$body','$daccess','$needmoney'{$inadd_v});";
  254. if(!$dsql->ExecuteNoneQuery($inQuery))
  255. {
  256. $gerr = $dsql->GetError();
  257. $dsql->ExecuteNoneQuery("DELETE FROM `#@__archives` WHERE id='$arcID'");
  258. $dsql->ExecuteNoneQuery("DELETE FROM `#@__arctiny` WHERE id='$arcID'");
  259. ShowMsg("把数据保存到数据库附加表 `{$addtable}` 时出错,请把相关信息提交给DedeCMS官方。".str_replace('"','',$gerr),"javascript:;");
  260. exit();
  261. }
  262. //生成HTML
  263. InsertTags($tags, $arcID);
  264. if($cfg_remote_site=='Y' && $isremote=="1")
  265. {
  266. if($serviterm!="")
  267. {
  268. list($servurl, $servuser, $servpwd) = explode(',',$serviterm);
  269. $config = array( 'hostname' => $servurl, 'username' => $servuser,
  270. 'password' => $servpwd,'debug' => 'TRUE');
  271. } else {
  272. $config = array();
  273. }
  274. if(!$ftp->connect($config)) exit('Error:None FTP Connection!');
  275. }
  276. $arcUrl = MakeArt($arcID, TRUE, TRUE, $isremote);
  277. if($arcUrl=='')
  278. {
  279. $arcUrl = $cfg_phpurl."/view.php?aid=$arcID";
  280. }
  281. ClearMyAddon($arcID, $title);
  282. //返回成功信息
  283. $msg = "
  284.   请选择你的后续操作:
  285. <a href='soft_add.php?cid=$typeid'><u>继续发布软件</u></a>
  286. &nbsp;&nbsp;
  287. <a href='$arcUrl' target='_blank'><u>查看软件</u></a>
  288. &nbsp;&nbsp;
  289. <a href='archives_do.php?aid=".$arcID."&dopost=editArchives'><u>更改软件</u></a>
  290. &nbsp;&nbsp;
  291. <a href='catalog_do.php?cid=$typeid&dopost=listArchives'><u>已发布软件管理</u></a>
  292. &nbsp;&nbsp;
  293. <a href='catalog_main.php'><u>网站栏目管理</u></a>
  294. ";
  295. $msg = "<div style=\"line-height:36px;height:36px\">{$msg}</div>".GetUpdateTest();
  296. $wintitle = "成功发布一个软件!";
  297. $wecome_info = "文章管理::发布软件";
  298. $win = new OxWindow();
  299. $win->AddTitle("成功发布软件:");
  300. $win->AddMsgItem($msg);
  301. $winform = $win->GetWindow("hand", "&nbsp;", FALSE);
  302. $win->Display();
  303. }