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

173 lines
7.0KB

  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2. <html xmlns="http://www.w3.org/1999/xhtml">
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/html; charset=<?php echo $cfg_soft_lang; ?>">
  5. <title>数据批量替换</title>
  6. <script language="javascript" src="../static/web/js/jquery.min.js"></script>
  7. <script language="javascript" src="../static/web/js/bootstrap.bundle.min.js"></script>
  8. <script language="javascript" src="js/main.js"></script>
  9. <script language='javascript' src='../static/web/js/webajax.js'></script>
  10. <script language='javascript'>
  11. function ShowFields() {
  12. var exptable = $DE('exptable').options[$DE('exptable').selectedIndex].value;
  13. var queryUrl = "sys_data_replace.php?exptable=" + exptable + "&action=getfields";
  14. fetch(queryUrl).then(resp=>{
  15. if (resp.ok) {
  16. return resp.text()
  17. }
  18. throw new Error('x');
  19. }).then((d)=>{
  20. $DE('fields').innerHTML = d;
  21. }).catch((error) => {
  22. $DE('fields').innerHTML = errMsg;
  23. });
  24. }
  25. function CheckSubmit() {
  26. if ($DE('rpfield').value == "") {
  27. ShowMsg("您选择的操作为手工指定字段,但您并没指定");
  28. return false;
  29. }
  30. if ($DE('rpstring').value == "") {
  31. ShowMsg("您没指定要替换的字符串");
  32. return false;
  33. }
  34. return true;
  35. }
  36. function pf(v) {
  37. $DE('rpfield').value = v;
  38. }
  39. </script>
  40. <link rel="stylesheet" href="../static/web/css/bootstrap.min.css">
  41. <link rel="stylesheet" href="../static/web/font/css/font-awesome.min.css">
  42. <link rel="stylesheet" href="../static/web/css/admin.css">
  43. </head>
  44. <body>
  45. <div class="bodytitle mt-3 mb-3">
  46. <div class="bodytitleleft"></div>
  47. <div class="bodytitletxt">批量管理</div>
  48. </div>
  49. <table width="98%" border="0" cellpadding="1" cellspacing="1" align="center" class="table maintable table-bordered">
  50. <form action="sys_data_replace.php" name="form1" method="post" target="stafrm" onSubmit="return CheckSubmit()">
  51. <input type='hidden' name='action' value='apply'>
  52. <tr>
  53. <td height="26" bgcolor="#EDF9D5" background="../static/web/img/tbg.gif" style="padding-left:10px">数据库内容替换:</td>
  54. </tr>
  55. <tr>
  56. <td bgcolor="#FFFFFF">
  57. <table width="100%" border="0" cellpadding="2" cellspacing="2" class="table table-borderless">
  58. <tr bgcolor="#FFFFFF">
  59. <td colspan="2" style="line-height:180%">
  60. <div class="alert alert-info" role="alert">
  61. <i class="fa fa-info-circle" aria-hidden="true"></i> 程序用于批量替换数据库中某字段的内容,此操作极为危险,请小心使用
  62. </div>
  63. </td>
  64. </tr>
  65. <tr id='datasel'>
  66. <td width="15%" height="66">&nbsp;选择数据表与字段:</td>
  67. <td>
  68. <table width="98%" border="0" cellspacing="0" cellpadding="0">
  69. <tr>
  70. <td id="tables">
  71. <?php
  72. $dsql->SetQuery("Show Tables");
  73. $dsql->Execute('t');
  74. if($dsql->GetError()!=''){
  75. echo "<span style='color:#dc3545'>找不到您所指定的数据库 $dbname</span><br>";
  76. echo $qbutton;
  77. }
  78. echo "<select name='exptable' id='exptable' size='10' style='width:60%;height: 220px;' onchange='ShowFields()'>\r\n";
  79. while($row = $dsql->GetArray('t',MYSQL_BOTH)){
  80. echo "<option value='{$row[0]}'>{$row[0]}</option>\r\n";
  81. }
  82. echo "</select>\r\n";
  83. $dsql->Close();
  84. ?> </td>
  85. </tr>
  86. <tr>
  87. <td id='fields'></td>
  88. </tr>
  89. <tr>
  90. <td height="26"> 要替换的字段:
  91. <input name="rpfield" type="text" id="rpfield" class="alltxt">
  92. </td>
  93. </tr>
  94. </table>
  95. </td>
  96. </tr>
  97. <tr bgcolor="#FBFCE2">
  98. <td>&nbsp;替换方式:</td>
  99. <td>
  100. <label><input name="rptype" type="radio" id="ot1" value="replace" checked='1' class='np' />
  101. 普通替换</label>
  102. <label><input type="radio" name="rptype" id="ot2" value="regex" class='np' />
  103. 正则表达式</label> 主键字段:
  104. <input name="keyfield" type="text" id="keyfield" size="12" class="alltxt">
  105. (正则模式必须指定)
  106. </td>
  107. </tr>
  108. <tr>
  109. <td>&nbsp;被替换内容:</td>
  110. <td><textarea name="rpstring" id="rpstring" class="alltxt" style="width:60%;height:50px"></textarea></td>
  111. </tr>
  112. <tr>
  113. <td>&nbsp;替换为:</td>
  114. <td><textarea name="tostring" id="tostring" class="alltxt" style="width:60%;height:50px"></textarea></td>
  115. </tr>
  116. <tr>
  117. <td height="26">&nbsp;替换条件:</td>
  118. <td><input name="condition" type="text" id="condition" style="width:45%" class="alltxt">
  119. (空完全替换)</td>
  120. </tr>
  121. <tr>
  122. <td height="26">&nbsp;安全确认码:</td>
  123. <td>
  124. <table width="300" border="0" cellspacing="0" cellpadding="0">
  125. <tr>
  126. <td width="90">
  127. <input type="text" name="validate" class="alltxt" style="width:80px;text-transform: uppercase">
  128. </td>
  129. <td>
  130. <img src='../apps/vdimgck.php' style="cursor:pointer;" onClick="this.src='../apps/vdimgck.php?'+new Date().getTime()+Math.round(Math.random() * 10000)"/>
  131. </td>
  132. </tr>
  133. </table>
  134. </td>
  135. </tr>
  136. </table>
  137. </td>
  138. </tr>
  139. <tr>
  140. <td height="30" bgcolor="#ffffff" align="center">
  141. <button type="submit" name="Submit" class="btn btn-success">开始替换数据</button>
  142. </td>
  143. </tr>
  144. </form>
  145. <tr bgcolor="#f8f8f8">
  146. <td height="26">
  147. <table width="100%" class="table table-borderless">
  148. <tr>
  149. <td width="74%">结果:</td>
  150. <td width="26%" align="right">
  151. <script language='javascript'>
  152. function ResizeDiv(obj, ty) {
  153. if (ty == "+") document.all[obj].style.pixelHeight += 50;
  154. else if (document.all[obj].style.pixelHeight > 80) document.all[obj].style.pixelHeight = document.all[obj].style.pixelHeight - 50;
  155. }
  156. </script>
  157. [<a href='javascript:;' onClick="ResizeDiv('mdv','+');">增大</a>] [<a href='javascript:;' onClick="ResizeDiv('mdv','-');">缩小</a>]
  158. </td>
  159. </tr>
  160. </table>
  161. </td>
  162. </tr>
  163. <tr bgcolor="#FFFFFF">
  164. <td id="mtd">
  165. <div id='mdv' style='width:100%;height:250px;'>
  166. <iframe name="stafrm" frameborder="0" id="stafrm" width="100%" height="100%"></iframe>
  167. </div>
  168. </td>
  169. </tr>
  170. </table>
  171. </body>
  172. </html>