国内流行的内容管理系统(CMS)多端全媒体解决方案 https://www.dedebiz.com
Ви не можете вибрати більше 25 тем Теми мають розпочинатися з літери або цифри, можуть містити дефіси (-) і не повинні перевищувати 35 символів.

4 роки тому
3 роки тому
7 місяці тому
3 роки тому
3 роки тому
3 роки тому
7 місяці тому
6 роки тому
2 роки тому
3 роки тому
2 роки тому
2 роки тому
3 роки тому
3 роки тому
3 роки тому
3 роки тому
3 роки тому
4 роки тому
3 роки тому
3 роки тому
3 роки тому
3 роки тому
3 роки тому
3 роки тому
3 роки тому
3 роки тому
3 роки тому
7 місяці тому
3 роки тому
3 роки тому
3 роки тому
4 роки тому
3 роки тому
3 роки тому
4 роки тому
3 роки тому
7 місяці тому
2 роки тому
2 роки тому
7 місяці тому
2 роки тому
2 роки тому
2 роки тому
2 роки тому
2 роки тому
4 роки тому
7 місяці тому
6 місяці тому
7 місяці тому
7 місяці тому
7 місяці тому
7 місяці тому
2 роки тому
6 місяці тому
2 роки тому
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642
  1. #!/usr/bin/env php
  2. <?php
  3. /**
  4. * 命令行工具
  5. *
  6. * @version 2020年12月11日 tianya $
  7. * @package DedeBIZ.Command
  8. * @copyright Copyright (c) 2022, DedeBIZ.COM
  9. * @license https://www.dedebiz.com/license
  10. * @link https://www.dedebiz.com
  11. */
  12. define("DEDE_CLITOOLS", TRUE);
  13. define('DEDE_ENVIRONMENT', 'production');
  14. define('DEBUG_LEVEL', FALSE); //如果设置为TRUE则会打印执行SQL的时间和标签加载时间方便调试
  15. //切换工作目录到/src
  16. $workDir = dirname(__FILE__) . "/src";
  17. if (!file_exists($workDir . "/system/common.inc.php")) {
  18. DedeCli::error("检查目录是否正确");
  19. exit;
  20. }
  21. if (!file_exists($workDir."/data/config.cache.inc.php")) {
  22. require_once($workDir."/install/config.cache.inc.php");
  23. }
  24. require_once($workDir . "/system/common.inc.php");
  25. require_once(DEDEINC . "/libraries/cli.class.php");
  26. chdir($workDir);
  27. if (substr(php_sapi_name(), 0, 3) === 'cgi') {
  28. DedeCli::error("DedeBIZ:需要使用php-cli运行");
  29. exit;
  30. }
  31. $helpStr = "
  32. NAME:
  33. DedeBIZ命令行工具
  34. USAGE:
  35. php ./dedebiz command [arguments...]
  36. COMMANDS:
  37. serv,s 运行DedeBIZ开发服务
  38. make,m 更新网页
  39. update,u 更新到最新系统
  40. help,h Shows 帮助
  41. quick,q 快速开始一个开发环境
  42. tdata 生成测试数据
  43. pwd 更改管理员密码
  44. WEBSITE:
  45. https://www.dedebiz.com/help/
  46. ";
  47. //将选项转化为SQL IN参数
  48. function Option2SQLin($str = "")
  49. {
  50. $str = preg_replace("#[^0-9-,]#", "", $str);
  51. $strs = explode(",", $str);
  52. foreach ($strs as $key => $si) {
  53. if (preg_match("#-#", $si)) {
  54. $tstart = 0;
  55. $tend = 0;
  56. $tss = explode("-", $si);
  57. if (intval($tss[0]) > intval($tss[1])) {
  58. $tstart = intval($tss[1]);
  59. $tend = intval($tss[0]);
  60. } else {
  61. $tstart = intval($tss[0]);
  62. $tend = intval($tss[1]);
  63. }
  64. $tmpArr = array();
  65. for ($i = $tstart; $i <= $tend; $i++) {
  66. $tmpArr[] = $i;
  67. }
  68. $strs[$key] = implode(",", $tmpArr);
  69. }
  70. }
  71. return implode(",", $strs);
  72. }
  73. function RandEncode($length=26)
  74. {
  75. $chars='abcdefghigklmnopqrstuvwxwyABCDEFGHIGKLMNOPQRSTUVWXWY0123456789';
  76. $rnd_cookieEncode='';
  77. $length = rand(28,32);
  78. $max = strlen($chars) - 1;
  79. for ($i = 0; $i < $length; $i++) {
  80. $rnd_cookieEncode .= $chars[mt_rand(0, $max)];
  81. }
  82. return $rnd_cookieEncode;
  83. }
  84. if (count($argv) > 1 && ($argv[1] == "serv" || $argv[1] == "s")) {
  85. //PHP5.4以下不支持内建服务器,用于开发调试
  86. if (phpversion() < "5.4") {
  87. DedeCli::error("DedeBIZ:命令行Web Server不支持");
  88. exit;
  89. }
  90. echo "启动DedeBIZ开发环境\n\r";
  91. echo "浏览器打开 http://localhost:8088\n\r";
  92. passthru(PHP_BINARY . ' -S localhost:8088 -t' . escapeshellarg('./'));
  93. } else if (count($argv) > 1 && ($argv[1] == "make" || $argv[1] == "m")) {
  94. //一个命令行的生成工具
  95. if (count($argv) > 2 && ($argv[2] == "arc" || $argv[2] == "a")) {
  96. //生成文档
  97. //make arc typeid=1
  98. $t1 = ExecTime();
  99. $addsql = "1=1";
  100. $typeid = Option2SQLin(DedeCli::getOption("typeid"));
  101. if (!empty($typeid)) {
  102. $addsql .= " AND typeid IN(" . $typeid . ")";
  103. }
  104. $aid = Option2SQLin(DedeCli::getOption("aid"));
  105. if (!empty($aid)) {
  106. $addsql .= " AND id IN(" . $typeid . ")";
  107. }
  108. $tt = $dsql->GetOne("SELECT COUNT(id) as dd FROM `#@__arctiny` WHERE " . $addsql);
  109. $total = intval($tt['dd']);
  110. $dsql->Execute('out', "SELECT id FROM `#@__arctiny` WHERE " . $addsql . " ORDER BY typeid ASC");
  111. $i = 0;
  112. while ($row = $dsql->GetObject('out')) {
  113. $id = $row->id;
  114. $ac = new Archives($id);
  115. $rurl = $ac->MakeHtml(0);
  116. DedeCli::showProgress(ceil(($i / $total) * 100), 100, $i, $total);
  117. $i++;
  118. }
  119. DedeCli::write("成功更新文档页");
  120. $queryTime = ExecTime() - $t1;
  121. DedeCli::write($queryTime);
  122. exit;
  123. } else if (count($argv) > 2 && ($argv[2] == "list" || $argv[2] == "l")) {
  124. //生成栏目
  125. $addsql = "1=1";
  126. $typeid = Option2SQLin(DedeCli::getOption("typeid"));
  127. if (!empty($typeid)) {
  128. $addsql .= " AND id IN(" . $typeid . ")";
  129. }
  130. $dsql->Execute('out', "SELECT id,channeltype FROM `#@__arctype` WHERE " . $addsql);
  131. $i = 0;
  132. while ($row = $dsql->GetObject('out')) {
  133. if ($row->channeltype > 0) {
  134. $lv = new ListView($row->id);
  135. } else {
  136. $lv = new SgListView($row->id);
  137. }
  138. $lv->CountRecord();
  139. DedeCli::write("开始更新列表页[id:{$row->id}]");
  140. $lv->MakeHtml('', '', 0);
  141. }
  142. exit;
  143. } else if (count($argv) > 2 && ($argv[2] == "index" || $argv[2] == "i")) {
  144. //生成首页
  145. $position = DedeCli::getOption("position");
  146. if (empty($position)) {
  147. $position = "../index.html";
  148. }
  149. if (!preg_match("#\.html$#", $position)) {
  150. DedeCli::error("位置必须以.html结尾");
  151. exit;
  152. }
  153. $homeFile = DEDEINC . "/" . $position;
  154. $homeFile = str_replace("\\", "/", $homeFile);
  155. $homeFile = str_replace("//", "/", $homeFile);
  156. $row = $dsql->GetOne("SELECT * FROM `#@__homepageset`");
  157. $templet = $row['templet'];
  158. $templet = str_replace("{style}", $cfg_df_style, $templet);
  159. $pv = new PartView();
  160. $GLOBALS['_arclistEnv'] = 'index';
  161. $pv->SetTemplet($cfg_basedir . $cfg_templets_dir . "/" . $templet);
  162. $pv->SaveToHtml($homeFile);
  163. DedeCli::write("成功更新首页");
  164. } else if (count($argv) > 2 && ($argv[2] == "auto" || $argv[2] == "o")) {
  165. //自动生成
  166. function OptimizeData($dsql)
  167. {
  168. global $cfg_dbprefix;
  169. $tptables = array("{$cfg_dbprefix}archives", "{$cfg_dbprefix}arctiny");
  170. $dsql->SetQuery("SELECT maintable,addtable FROM `#@__channeltype` ");
  171. $dsql->Execute();
  172. while ($row = $dsql->GetObject()) {
  173. $addtable = str_replace('#@__', $cfg_dbprefix, $row->addtable);
  174. if ($addtable != '' && !in_array($addtable, $tptables)) $tptables[] = $addtable;
  175. }
  176. $tptable = '';
  177. foreach ($tptables as $t) $tptable .= ($tptable == '' ? "`{$t}`" : ",`{$t}`");
  178. $dsql->ExecuteNoneQuery(" OPTIMIZE TABLE $tptable; ");
  179. }
  180. $start = empty(DedeCli::getOption("start"))? "-1 day" : DedeCli::getOption("start");
  181. $start = strtotime($start);
  182. if (!$start) {
  183. DedeCli::error("start参数为空");
  184. exit;
  185. }
  186. //1.生成首页
  187. $pv = new PartView();
  188. $row = $pv->dsql->GetOne("SELECT * FROM `#@__homepageset` ");
  189. $templet = str_replace("{style}", $cfg_df_style, $row['templet']);
  190. $homeFile = DEDEINC . '/' . $row['position'];
  191. $homeFile = str_replace("\\", '/', $homeFile);
  192. $homeFile = preg_replace("#\/{1,}#", '/', $homeFile);
  193. if ($row['showmod'] == 1) {
  194. $pv->SetTemplet($cfg_basedir . $cfg_templets_dir . '/' . $templet);
  195. $pv->SaveToHtml($homeFile);
  196. $pv->Close();
  197. } else {
  198. if (file_exists($homeFile)) @unlink($homeFile);
  199. }
  200. DedeCli::write("成功更新首页");
  201. //2.生成栏目
  202. $query = "SELECT DISTINCT typeid From `#@__arctiny` WHERE senddate >=" . $start . " AND arcrank>-1";
  203. $dsql->SetQuery($query);
  204. $dsql->Execute();
  205. $typeids = array();
  206. while ($row = $dsql->GetArray()) {
  207. $typeids[$row['typeid']] = 1;
  208. }
  209. if (count($typeids) > 0) {
  210. foreach ($typeids as $k => $v) {
  211. $vs = array();
  212. $vs = GetParentIds($k);
  213. if (!isset($typeidsok[$k])) {
  214. $typeidsok[$k] = 1;
  215. }
  216. foreach ($vs as $k => $v) {
  217. if (!isset($typeidsok[$v])) {
  218. $typeidsok[$v] = 1;
  219. }
  220. }
  221. }
  222. foreach ($typeidsok as $tt=> $k) {
  223. $row = $dsql->GetOne("SELECT id,channeltype FROM `#@__arctype` WHERE id=".$tt);
  224. if ($row['channeltype'] > 0) {
  225. $lv = new ListView($tt);
  226. } else {
  227. $lv = new SgListView($tt);
  228. }
  229. $lv->CountRecord();
  230. DedeCli::write("开始更新列表页[id:{$tt}]");
  231. $lv->MakeHtml('', '', 0);
  232. }
  233. DedeCli::write("成功更新列表页");
  234. }
  235. //生成文档
  236. $tt = $dsql->GetOne("SELECT COUNT(id) as dd FROM `#@__arctiny` WHERE senddate >=" . $start . " AND arcrank>-1");
  237. $total = intval($tt['dd']);
  238. $dsql->Execute('out', "SELECT id FROM `#@__arctiny` WHERE senddate >=" . $start . " AND arcrank>-1 ORDER BY typeid ASC");
  239. $i = 0;
  240. while ($row = $dsql->GetObject('out')) {
  241. $id = $row->id;
  242. $ac = new Archives($id);
  243. $rurl = $ac->MakeHtml(0);
  244. DedeCli::showProgress(ceil(($i / $total) * 100), 100);
  245. $i++;
  246. }
  247. DedeCli::write("成功更新网页");
  248. //优化数据
  249. OptimizeData($dsql);
  250. DedeCli::write("成功优化数据");
  251. } else {
  252. $helpStr = "
  253. USAGE:
  254. php ./dedebiz make action [arguments...]
  255. ACTIONS:
  256. index,i 更新首页
  257. --position 首页位置,默认: ../index.html(相对system目录)
  258. arc,a 更新文档页
  259. --typeid 栏目id
  260. --aid 文档id
  261. list,l 更新列表页
  262. --typeid 栏目id
  263. auto,o 自动更新
  264. --start 开始时间(format:2012-03-12)
  265. tdata 更新测试数据
  266. pwd 更改管理员密码
  267. WEBSITE:
  268. https://www.dedebiz.com/help/";
  269. DedeCli::write($helpStr);
  270. exit;
  271. }
  272. } else if (count($argv) > 1 && ($argv[1] == "update" || $argv[1] == "u")) {
  273. define("DEDEINC", $workDir."/system");
  274. require_once(DEDEINC."/dedehttpdown.class.php");
  275. require_once(DEDEINC . "/libraries/cli.class.php");
  276. //更新系统
  277. $latestURL = "https://cdn.dedebiz.com/release/latest.txt";
  278. $del = new DedeHttpDown();
  279. $del->OpenUrl($latestURL);
  280. $remoteVerStr = $del->GetHtml();
  281. $commStr = file_get_contents(DEDEINC."/common.inc.php");
  282. preg_match("#_version_detail = '([\d\.]+)'#", $commStr, $matchs);
  283. $cfg_version_detail = $localVerStr = $matchs[1];
  284. if (version_compare($localVerStr, $remoteVerStr, '>=')) {
  285. DedeCli::error("已经是最新版本,无需继续升级");
  286. exit;
  287. }
  288. $fileHashURL = "https://cdn.dedebiz.com/release/{$cfg_version_detail}.json";
  289. $del = new DedeHttpDown();
  290. $del->OpenUrl($fileHashURL);
  291. $filelist = $del->GetJSON();
  292. $offFiles = array();
  293. //TODO 命令行自动更新
  294. } else if (count($argv) > 1 && ($argv[1] == "quick" || $argv[1] == "q")){
  295. if (!defined('DEDEINC')) {
  296. define("DEDEINC", $workDir."/system");
  297. }
  298. require_once(DEDEINC . "/libraries/cli.class.php");
  299. //快速开始一个用于开发的DedeBIZ环境,基于SQLite无其他依赖
  300. if (file_exists($workDir."/data/DedeBIZ.db")) {
  301. DedeCli::write("开发环境已经初始化");
  302. echo "启动DedeBIZ开发环境\n\r";
  303. echo "浏览器打开 http://localhost:8088\n\r";
  304. passthru(PHP_BINARY . ' -S localhost:8088 -t' . escapeshellarg('./'));
  305. exit;
  306. }
  307. //初始化安装一个开发环境
  308. $db = new SQLite3($workDir.'/data/DedeBIZ.db');
  309. $fp = fopen($workDir."/install/common.inc.php","r");
  310. $configStr1 = fread($fp,filesize($workDir."/install/common.inc.php"));
  311. fclose($fp);
  312. @chmod($workDir."/data",0777);
  313. $dbtype = "sqlite";
  314. $dbhost = "";
  315. $dbname = "DedeBIZ";
  316. $dbuser = "";
  317. $dbpwd = "";
  318. $dbprefix = "dede_";
  319. $dblang = "utf8";
  320. if (!is_dir($workDir.'/data/tplcache')) {
  321. mkdir($workDir.'/data/tplcache', 0777);
  322. }
  323. //common.inc.php
  324. $configStr1 = str_replace("~dbtype~",$dbtype,$configStr1);
  325. $configStr1 = str_replace("~dbhost~",$dbhost,$configStr1);
  326. $configStr1 = str_replace("~dbname~",$dbname,$configStr1);
  327. $configStr1 = str_replace("~dbuser~",$dbuser,$configStr1);
  328. $configStr1 = str_replace("~dbpwd~",$dbpwd,$configStr1);
  329. $configStr1 = str_replace("~dbprefix~",$dbprefix,$configStr1);
  330. $configStr1 = str_replace("~dblang~",$dblang,$configStr1);
  331. $fp = fopen($workDir."/data/common.inc.php","w") or die("error,check /data writeable");
  332. fwrite($fp,$configStr1);
  333. fclose($fp);
  334. $cookieencode = RandEncode(26);
  335. $baseurl = "http://127.0.0.1:8088";
  336. $indexUrl = "/";
  337. $cmspath = "";
  338. $webname = "穆云智能";
  339. $adminmail = "admin@dedebiz.com";
  340. $fp = fopen($workDir."/install/config.cache.inc.php","r");
  341. $configStr2 = fread($fp,filesize($workDir."/install/config.cache.inc.php"));
  342. fclose($fp);
  343. $configStr2 = str_replace("~baseurl~",$baseurl,$configStr2);
  344. $configStr2 = str_replace("~basepath~",$cmspath,$configStr2);
  345. $configStr2 = str_replace("~indexurl~",$indexUrl,$configStr2);
  346. $configStr2 = str_replace("~cookieEncode~",$cookieencode,$configStr2);
  347. $configStr2 = str_replace("~webname~",$webname,$configStr2);
  348. $configStr2 = str_replace("~adminmail~",$adminmail,$configStr2);
  349. $fp = fopen($workDir.'/data/config.cache.inc.php','w');
  350. fwrite($fp,$configStr2);
  351. fclose($fp);
  352. $fp = fopen($workDir.'/data/config.cache.bak.php','w');
  353. fwrite($fp,$configStr2);
  354. fclose($fp);
  355. $query = '';
  356. $fp = fopen($workDir.'/install/sql-dftables.txt','r');
  357. while (!feof($fp))
  358. {
  359. $line = rtrim(fgets($fp,1024));
  360. if (preg_match("#;$#", $line))
  361. {
  362. $query .= $line."\n";
  363. $query = str_replace('#@__',$dbprefix,$query);
  364. $query = ConvertMysqlToSqlite($query);
  365. @$db->exec($query);
  366. $query='';
  367. } else if (!preg_match("#^(\/\/|--)#", $line)) {
  368. $query .= $line;
  369. }
  370. }
  371. fclose($fp);
  372. //导入默认数据
  373. $query = '';
  374. $fp = fopen($workDir.'/install/sql-dfdata.txt','r');
  375. while (!feof($fp))
  376. {
  377. $line = rtrim(fgets($fp, 1024));
  378. if (preg_match("#;$#", $line)) {
  379. $query .= $line;
  380. $query = str_replace('#@__',$dbprefix,$query);
  381. $query = str_replace("\'","\"",$query);
  382. $query = str_replace('\t\n\n',"",$query);
  383. $query = str_replace('\t\n',"",$query);
  384. @$db->exec($query);
  385. $query='';
  386. } else if (!preg_match("#^(\/\/|--)#", $line)) {
  387. $query .= $line;
  388. }
  389. }
  390. fclose($fp);
  391. //更新配置
  392. $cquery = "UPDATE `{$dbprefix}sysconfig` SET value='{$baseurl}' WHERE varname='cfg_basehost';";
  393. $db->exec($cquery);
  394. $cquery = "UPDATE `{$dbprefix}sysconfig` SET value='{$cmspath}' WHERE varname='cfg_cmspath';";
  395. $db->exec($cquery);
  396. $cquery = "UPDATE `{$dbprefix}sysconfig` SET value='{$indexUrl}' WHERE varname='cfg_indexurl';";
  397. $db->exec($cquery);
  398. $cquery = "UPDATE `{$dbprefix}sysconfig` SET value='{$cookieencode}' WHERE varname='cfg_cookie_encode';";
  399. $db->exec($cquery);
  400. $cquery = "UPDATE `{$dbprefix}sysconfig` SET value='{$webname}' WHERE varname='cfg_webname';";
  401. $db->exec($cquery);
  402. $cquery = "UPDATE `{$dbprefix}sysconfig` SET value='{$adminmail}' WHERE varname='cfg_adminemail';";
  403. $db->exec($cquery);
  404. $adminuser = "admin";
  405. $adminpwd = "admin";
  406. //增加管理员帐号
  407. $pfd = "pwd";
  408. $apwd = substr(md5($adminpwd),5,20);
  409. $upwd = md5($adminpwd);
  410. if (function_exists('password_hash')) {
  411. $pfd = "pwd_new";
  412. $apwd = password_hash($adminpwd, PASSWORD_BCRYPT);
  413. $upwd = password_hash($adminpwd, PASSWORD_BCRYPT);
  414. }
  415. //增加管理员帐号
  416. $adminquery = "INSERT INTO `{$dbprefix}admin` (`id`,`usertype`,`userid`,`$pfd`,`uname`,`tname`,`email`,`typeid`,`logintime`,`loginip`) VALUES (1,10,'$adminuser','".$apwd."','admin','','',0,'".time()."','127.0.0.1');";
  417. $db->exec($adminquery);
  418. //关连前台会员帐号
  419. $adminquery = "INSERT INTO `{$dbprefix}member` (`mid`,`mtype`,`userid`,`{$pfd}`,`uname`,`sex`,`rank`,`money`,`email`,`scores`,`matt`,`face`,`safequestion`,`safeanswer`,`jointime`,`joinip`,`logintime`,`loginip`) VALUES ('1','个人','$adminuser','".$upwd."','$adminuser','男','100','0','','10000','10','','0','','".time()."','','0',''); ";
  420. $db->exec($adminquery);
  421. $adminquery = "INSERT INTO `{$dbprefix}member_person` (`mid`,`onlynet`,`sex`,`uname`,`qq`,`msn`,`tel`,`mobile`,`place`,`oldplace`,`birthday`,`star`,`income`,`education`,`height`,`bodytype`,`blood`,`vocation`,`smoke`,`marital`,`house`,`drink`,`datingtype`,`language`,`nature`,`lovemsg`,`address`,`uptime`) VALUES ('1','1','男','{$adminuser}','','','','','0','0','1980-01-01','1','0','0','160','0','0','0','0','0','0','0','0','','','','','0'); ";
  422. $db->exec($adminquery);
  423. $adminquery = "INSERT INTO `{$dbprefix}member_tj` (`mid`,`article`,`album`,`archives`,`homecount`,`pagecount`,`feedback`,`friend`,`stow`) VALUES ('1','0','0','0','0','0','0','0','0'); ";
  424. $db->exec($adminquery);
  425. $adminquery = "INSERT INTO `{$dbprefix}member_space` (`mid`,`pagesize`,`matt`,`spacename`,`spacelogo`,`spacestyle`,`sign`,`spacenews`) VALUES ('1','10','0','{$adminuser}的空间','','person','',''); ";
  426. $db->exec($adminquery);
  427. DedeCli::write("用户名:admin");
  428. DedeCli::write("密码:admin");
  429. if (phpversion() < "5.4") {
  430. die("DedeBIZ:命令行Web Server不支持\n\n");
  431. }
  432. //写入程序安装锁
  433. file_put_contents($workDir.'/install/install_lock.txt', 'ok');
  434. echo "Start Dev Server For DedeBIZ\n\r";
  435. echo "Open http://localhost:8088\n\r";
  436. passthru(PHP_BINARY . ' -S localhost:8088 -t' . escapeshellarg('./'));
  437. exit;
  438. } else if(count($argv) > 1 && ($argv[1] =="tdata")){
  439. if (!file_exists($workDir . "/system/common.inc.php")) {
  440. DedeCli::error("检查根目录是否存在错误");
  441. exit;
  442. }
  443. require_once($workDir . "/system/common.inc.php");
  444. require_once(DEDEINC . "/libraries/cli.class.php");
  445. for ($t=1; $t <= 10; $t++) {
  446. $in_query = "INSERT INTO `#@__arctype` (reid,topid,sortrank,typename,cnoverview,enname,enoverview,bigpic,litimg,typedir,isdefault,defaultname,issend,channeltype,tempindex,templist,temparticle,modname,namerule,namerule2,ispart,corank,description,keywords,seotitle,moresite,siteurl,sitepath,ishidden,`cross`,`crossid`,`content`,`smalltypes`) VALUES ('0','0','999','测试栏目{$t}','','','','','','{cmspath}/a/ceshilanmu{$t}','1','index.html','1','1','{style}/index_article.htm','{style}/list_article.htm','{style}/article_article.htm','default','{typedir}/{aid}.html','{typedir}/{tid}-{page}.html','0','0','测试','测试','','0','','','0','0','','','')";
  447. if (!$dsql->ExecuteNoneQuery($in_query)) {
  448. DedeCli::error("保存目录数据时失败,请检查您的输入资料是否存在问题");
  449. }
  450. $typeid = $dsql->GetLastID();
  451. DedeCli::write("开始生成[测试栏目{$t}]测试数据...");
  452. for ($i=0; $i < 1000; $i++) {
  453. DedeCli::showProgress(ceil(($i / 1000) * 100), 100);
  454. $now = time();
  455. $arcID = GetIndexKey(0, $typeid, $now, 1, $now, 1);
  456. if (empty($arcID)) {
  457. DedeCli::error("无法获得主键,因此无法进行后续操作");
  458. }
  459. $query = "INSERT INTO `#@__archives` (id,typeid,typeid2,sortrank,flag,ismake,channel,arcrank,click,money,title,shorttitle,color,writer,source,litpic,pubdate,senddate,mid,notpost,description,keywords,filename,dutyadmin,weight) VALUES ('$arcID','$typeid','0','$now','','1','1','0','100','0','这是一篇测试文章$arcID','测试文章$arcID','','天涯','DedeBIZ','','$now','$now','1','0','测试描述','测试关键词','','1','');";
  460. if (!$dsql->ExecuteNoneQuery($query)) {
  461. $gerr = $dsql->GetError();
  462. $dsql->ExecuteNoneQuery("DELETE FROM `#@__arctiny` WHERE id='$arcID'");
  463. DedeCli::error("数据保存到数据库主表`#@__archives`时出错,请检查数据库字段".str_replace('"', '', $gerr));
  464. }
  465. $body = str_repeat("<p>DedeBIZ系统基于PHP7版本开发,具有很强的可扩展性,并且采用GPLv2协议完全开放源代码。DedeBIZ支持采用现流行的Go语言设计开发,拥有简单易用、灵活扩展特性之外更安全、高效。模板设计制作简单,一直是系统一大特点,延续之前标签,同时采用响应式模板引擎Bootstrap作为系统模板渲染引擎,让搭建跨终端和移动端全媒体站点更简单。</p>",5);
  466. $query = "INSERT INTO `#@__addonarticle` (aid,typeid,redirecturl,templet,userip,body) VALUES ('$arcID','$typeid','','','127.0.0.1','$body')";
  467. if (!$dsql->ExecuteNoneQuery($query)) {
  468. $gerr = $dsql->GetError();
  469. $dsql->ExecuteNoneQuery("DELETE FROM `#@__archives` WHERE id='$arcID'");
  470. $dsql->ExecuteNoneQuery("DELETE FROM `#@__arctiny` WHERE id='$arcID'");
  471. DedeCli::error("数据保存到数据库附加表时出错,请检查数据库字段".str_replace('"', '', $gerr));
  472. }
  473. InsertTags("天涯{$arcID},穆云智能", $arcID);
  474. }
  475. }
  476. $dsql->SetQuery("SELECT id,reid,channeltype,issend,typename FROM `#@__arctype`");
  477. $dsql->Execute();
  478. $cacheFile = DEDEDATA.'/cache/inc_catalog_base.inc';
  479. $fp = fopen($cacheFile, 'w');
  480. $phph = '?';
  481. $fpHeader = "<{$phph}php\r\nglobal \$cfg_Cs;\r\n\$cfg_Cs=array();\r\n";
  482. fwrite($fp, $fpHeader);
  483. while ($row = $dsql->GetObject()) {
  484. //typename缓存起来
  485. $row->typename = base64_encode($row->typename);
  486. fwrite($fp, "\$cfg_Cs[{$row->id}]=array({$row->reid},{$row->channeltype},{$row->issend},'{$row->typename}');\r\n");
  487. }
  488. fwrite($fp, "{$phph}>");
  489. fclose($fp);
  490. DedeCli::write("成功生成所有测试数据");
  491. } else if(count($argv) > 1 && ($argv[1] =="pwd")){
  492. DedeCli::write("请选择需要更改密码的用户名:");
  493. $dsql->Execute('out', "SELECT id,userid FROM `#@__admin`");
  494. $ids = array();
  495. while ($row = $dsql->GetObject('out')) {
  496. DedeCli::write("[id:{$row->id}]{$row->userid}");
  497. $ids[] = $row->id;
  498. }
  499. $id = intval(DedeCli::prompt('输入id?', $ids));
  500. $pwd = DedeCli::prompt('请输入新的密码');
  501. if (function_exists('password_hash')) {
  502. $pwdm = "pwd='',pwd_new='".password_hash($pwd, PASSWORD_BCRYPT)."'";
  503. $pwd = "pwd='',pwd_new='".password_hash($pwd, PASSWORD_BCRYPT)."'";
  504. } else {
  505. $pwdm = "pwd='".md5($pwd)."'";
  506. $pwd = "pwd='".substr(md5($pwd), 5, 20)."'";
  507. }
  508. $query = "UPDATE `#@__admin` SET $pwd WHERE id='$id'";
  509. $dsql->ExecuteNoneQuery($query);
  510. $query = "UPDATE `#@__member` SET $pwdm WHERE mid='$id'";
  511. $dsql->ExecuteNoneQuery($query);
  512. DedeCli::write("成功修改密码");
  513. } else if(count($argv) > 1 && ($argv[1] =="clean")){
  514. // 当前功能仅开发方便清空构建站点测试用,常规情况下慎用
  515. function deleteDirectory($dir) {
  516. if (!is_dir($dir)) {
  517. return false;
  518. }
  519. $files = array_diff(scandir($dir), array('.', '..'));
  520. foreach ($files as $file) {
  521. $path = $dir . '/' . $file;
  522. if (is_dir($path)) {
  523. deleteDirectory($path);
  524. } else {
  525. unlink($path);
  526. }
  527. }
  528. return rmdir($dir);
  529. }
  530. $isClean = DedeCli::prompt('确认清空站点资源,将会删除所有配置内容请谨慎使用(y:是,n:否)?');
  531. if (strtolower($isClean) == 'y') {
  532. $directory = $workDir.'/data';
  533. // 删除data下的文件
  534. if ($handle = opendir($directory)) {
  535. // 遍历目录中的所有文件和文件夹
  536. while (false !== ($entry = readdir($handle))) {
  537. if ($entry != "." && $entry != "..") {
  538. $fullPath = $directory . '/' . $entry;
  539. // 匹配文件夹规则
  540. if (is_dir($fullPath) && preg_match('/^sessions_|^updatefile_/', $entry)) {
  541. // 删除文件夹及其内容
  542. deleteDirectory($fullPath);
  543. } elseif (is_file($fullPath) && preg_match('/.*_safe\.txt$|.*\.db$|.*\.php|.*\.inc/', $entry)) {
  544. unlink($fullPath);
  545. }
  546. }
  547. }
  548. // 关闭目录
  549. closedir($handle);
  550. }
  551. if ($handle = opendir($directory."/backupdata")) {
  552. // 遍历目录中的所有文件和文件夹
  553. while (false !== ($entry = readdir($handle))) {
  554. if ($entry != "." && $entry != "..") {
  555. $fullPath = $directory . '/backupdata/' . $entry;
  556. if (is_file($fullPath) && preg_match('/.*\.txt$/', $entry)) {
  557. unlink($fullPath);
  558. }
  559. }
  560. }
  561. // 关闭目录
  562. closedir($handle);
  563. }
  564. if ($handle = opendir($directory."/tplcache")) {
  565. // 遍历目录中的所有文件和文件夹
  566. while (false !== ($entry = readdir($handle))) {
  567. if ($entry != "." && $entry != "..") {
  568. $fullPath = $directory . '/tplcache/' . $entry;
  569. if (is_file($fullPath) && preg_match('/.*\.inc$|.*\.txt$/', $entry)) {
  570. unlink($fullPath);
  571. }
  572. }
  573. }
  574. // 关闭目录
  575. closedir($handle);
  576. }
  577. if ($handle = opendir($directory.'/cache')) {
  578. // 遍历目录中的所有文件和文件夹
  579. while (false !== ($entry = readdir($handle))) {
  580. if ($entry != "." && $entry != "..") {
  581. $fullPath = $directory . '/cache/' . $entry;
  582. // 匹配文件夹规则
  583. if (is_dir($fullPath) && preg_match('/^mask_|CSS|diggCache|HTML|memberlogin|tagjsonq|update|URI/', $entry)) {
  584. // 删除文件夹及其内容
  585. deleteDirectory($fullPath);
  586. } elseif (is_file($fullPath) && preg_match('/.*\.inc|.*\.dat/', $entry)) {
  587. unlink($fullPath);
  588. }
  589. }
  590. }
  591. // 关闭目录
  592. closedir($handle);
  593. }
  594. unlink($workDir.'/install/install_lock.txt');
  595. DedeCli::write("站点清除成功");
  596. }
  597. } else if(count($argv) > 1 && ($argv[1] =="make_filehash")){
  598. $gitFiles = shell_exec('git ls-files');
  599. // 将输出的字符串按行拆分成数组
  600. $fileList = explode("\n", trim($gitFiles));
  601. // 输出文件列表
  602. $hashs = array();
  603. foreach ($fileList as $file) {
  604. if (!file_exists($file)) {
  605. continue;
  606. }
  607. $name = $file;
  608. $size = filesize($file);
  609. $hash = md5_file($file);
  610. $f = array(
  611. "filename" => $name,
  612. );
  613. $hashs[] = $f;
  614. }
  615. file_put_contents(DEDEDATA.'/admin/files.txt',json_encode($hashs));
  616. DedeCli::write("成功生成文件哈希");
  617. } else if(count($argv) > 1 && ($argv[1] =="find_stringvals")){
  618. // 用于找出php8.2字符串变量的
  619. function searchPhpFiles($directory) {
  620. $iterator = new RecursiveIteratorIterator(new RecursiveDirectoryIterator($directory));
  621. $variablePattern = '/["\'].*?\$\{\$\w+\}.*?["\']/';
  622. foreach ($iterator as $file) {
  623. if ($file->isFile() && pathinfo($file, PATHINFO_EXTENSION) === 'php') {
  624. $filePath = $file->getPathname();
  625. $lines = file($filePath, FILE_IGNORE_NEW_LINES);
  626. foreach ($lines as $lineNumber => $line) {
  627. if (preg_match($variablePattern, $line)) {
  628. DedeCli::write( "文件: $filePath, 行号: ". ($lineNumber + 1). ", 内容: ". trim($line));
  629. }
  630. }
  631. }
  632. }
  633. }
  634. searchPhpFiles($workDir);
  635. } else {
  636. DedeCli::write($helpStr);
  637. }
  638. ?>