国内流行的内容管理系统(CMS)多端全媒体解决方案 https://www.dedebiz.com
Vous ne pouvez pas sélectionner plus de 25 sujets Les noms de sujets doivent commencer par une lettre ou un nombre, peuvent contenir des tirets ('-') et peuvent comporter jusqu'à 35 caractères.

mychannel_field_add.php 4.8KB

il y a 3 ans
il y a 2 ans
il y a 3 ans
il y a 3 ans
il y a 3 ans
il y a 3 ans
il y a 3 ans
il y a 3 ans
il y a 3 ans
il y a 3 ans
il y a 3 ans
il y a 3 ans
il y a 3 ans
il y a 3 ans
il y a 3 ans
il y a 3 ans
il y a 3 ans
il y a 3 ans
il y a 2 ans
il y a 3 ans
il y a 2 ans
il y a 3 ans
il y a 3 ans
il y a 3 ans
il y a 3 ans
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. <?php
  2. /**
  3. * 添加文档模型字段
  4. *
  5. * @version $id:mychannel_field_add.php 15:07 2010年7月20日 tianya $
  6. * @package DedeBIZ.Administrator
  7. * @copyright Copyright (c) 2022 DedeBIZ.COM
  8. * @license GNU GPL v2 (https://www.dedebiz.com/license)
  9. * @link https://www.dedebiz.com
  10. */
  11. require_once(dirname(__FILE__)."/config.php");
  12. if (DEDEBIZ_SAFE_MODE) {
  13. die(DedeAlert("系统已启用安全模式,无法使用当前功能",ALERT_DANGER));
  14. }
  15. CheckPurview('c_New');
  16. require_once(DEDEADMIN."/inc/inc_admin_channel.php");
  17. require_once(DEDEINC."/dedetag.class.php");
  18. if (empty($action)) $action = '';
  19. $mysql_version = $dsql->GetVersion();
  20. if ($action == 'save') {
  21. //修改字段配置信息
  22. $dfvalue = trim($vdefault);
  23. $isnull = ($isnull == 1 ? "true" : "false");
  24. $mxlen = $maxlength;
  25. if (preg_match("#^(select|radio|checkbox)$#i", $dtype)) {
  26. if (!preg_match("#,#", $dfvalue)) {
  27. ShowMsg("您设定了字段为{$dtype}类型,必须在默认值中指定元素列表,如:'a,b,c' ", "-1");
  28. exit();
  29. }
  30. }
  31. if ($dtype == 'stepselect') {
  32. $arr = $dsql->GetOne("SELECT * FROM `#@__stepselect` WHERE egroup='$fieldname' ");
  33. if (!is_array($arr)) {
  34. ShowMsg("您设定了字段为联动类型,但系统中没找到与您定义的字段名相同的联动组名", "-1");
  35. exit();
  36. }
  37. }
  38. //模型信息
  39. $row = $dsql->GetOne("SELECT fieldset,addtable,issystem FROM `#@__channeltype` WHERE id='$id'");
  40. $fieldset = stripslashes($row['fieldset']);
  41. $dtp = new DedeTagParse();
  42. $dtp->SetNameSpace("field", "<", ">");
  43. $dtp->LoadSource($fieldset);
  44. $trueTable = $row['addtable'];
  45. //检测被修改的字段类型
  46. $fieldinfos = GetFieldMake($dtype, $fieldname, $dfvalue, $mxlen);
  47. $ntabsql = $fieldinfos[0];
  48. $buideType = $fieldinfos[1];
  49. $rs = $dsql->ExecuteNoneQuery("ALTER TABLE `$trueTable` ADD $ntabsql ");
  50. if (!$rs) {
  51. $gerr = $dsql->GetError();
  52. ShowMsg("添加字段失败,错误提示为:".$gerr, "javascript:;");
  53. exit();
  54. }
  55. //检测旧配置信息,并替换为新配置
  56. $ok = FALSE;
  57. $fieldname = strtolower($fieldname);
  58. if (is_array($dtp->CTags)) {
  59. foreach ($dtp->CTags as $tagid => $ctag) {
  60. if ($fieldname == strtolower($ctag->GetName())) {
  61. $dtp->Assign($tagid, stripslashes($fieldstring), FALSE);
  62. $ok = true;
  63. break;
  64. }
  65. }
  66. $oksetting = $ok ? $dtp->GetResultNP() : $fieldset."\n".stripslashes($fieldstring);
  67. } else {
  68. $oksetting = $fieldset."\r\n".stripslashes($fieldstring);
  69. }
  70. $addlist = GetAddFieldList($dtp, $oksetting);
  71. $oksetting = addslashes($oksetting);
  72. $rs = $dsql->ExecuteNoneQuery("UPDATE `#@__channeltype` SET fieldset='$oksetting',listfields='$addlist' WHERE id='$id' ");
  73. if (!$rs) {
  74. $grr = $dsql->GetError();
  75. ShowMsg("保存节点配置出错".$grr, "javascript:;");
  76. exit();
  77. }
  78. ShowMsg("成功添加一个字段", "mychannel_edit.php?id={$id}&dopost=edit&openfield=1");
  79. exit();
  80. }
  81. //检测模型相关信息,并初始化相关数据
  82. $row = $dsql->GetOne("SELECT '#@__archives' AS maintable,addtable FROM `#@__channeltype` WHERE id='$id'");
  83. $trueTable = $row['addtable'];
  84. $tabsql = "CREATE TABLE IF NOT EXISTS `$trueTable`( `aid` int(11) NOT NULL default '0',\r\n `typeid` int(11) NOT NULL default '0',\r\n ";
  85. if ($mysql_version < 4.1) {
  86. $tabsql .= " PRIMARY KEY (`aid`), KEY `".$trueTable."_index` (`typeid`)\r\n) TYPE=MyISAM; ";
  87. } else {
  88. $tabsql .= " PRIMARY KEY (`aid`), KEY `".$trueTable."_index` (`typeid`)\r\n) ENGINE=MyISAM DEFAULT CHARSET=".$cfg_db_language."; ";
  89. }
  90. $dsql->ExecuteNoneQuery($tabsql);
  91. //检测附加表里含有的字段
  92. $fields = array();
  93. if (empty($row['maintable'])) $row['maintable'] = '#@__archives';
  94. $rs = $dsql->SetQuery("SHOW fields FROM `{$row['maintable']}`");
  95. $dsql->Execute('a');
  96. while ($nrow = $dsql->GetArray('a', MYSQL_ASSOC)) {
  97. if ($cfg_dbtype == 'sqlite') {
  98. $nrow['Field'] = $nrow['name'];
  99. }
  100. $fields[strtolower($nrow['Field'])] = 1;
  101. }
  102. $dsql->Execute("a", "SHOW fields FROM `{$row['addtable']}`");
  103. while ($nrow = $dsql->GetArray('a', MYSQL_ASSOC)) {
  104. if ($cfg_dbtype == 'sqlite') {
  105. $nrow['Field'] = $nrow['name'];
  106. }
  107. if (!isset($fields[strtolower($nrow['Field'])])) {
  108. $fields[strtolower($nrow['Field'])] = 1;
  109. }
  110. }
  111. $f = '';
  112. foreach ($fields as $k => $v) {
  113. $f .= ($f == '' ? $k : ' '.$k);
  114. }
  115. //获取栏目模型
  116. $dsql->SetQuery("SELECT id,typename,nid FROM `#@__channeltype` WHERE id<>-1 AND isshow=1 ORDER BY id");
  117. $dsql->Execute();
  118. while ($row = $dsql->GetObject()) {
  119. $channelArray[$row->id]['typename'] = $row->typename;
  120. $channelArray[$row->id]['nid'] = $row->nid;
  121. }
  122. require_once(DEDEADMIN."/templets/mychannel_field_add.htm");
  123. ?>