国内流行的内容管理系统(CMS)多端全媒体解决方案 https://www.dedebiz.com
No puede seleccionar más de 25 temas Los temas deben comenzar con una letra o número, pueden incluir guiones ('-') y pueden tener hasta 35 caracteres de largo.

166 líneas
6.8KB

  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. <table width="98%" border="0" cellpadding="1" cellspacing="1" align="center" class="table maintable mt-3">
  46. <form action="sys_data_replace.php" name="form1" method="post" target="stafrm" onSubmit="return CheckSubmit()">
  47. <input type='hidden' name='action' value='apply'>
  48. <tr>
  49. <td height="26" bgcolor="#EDF9D5" background="../static/web/img/tbg.gif" style="padding-left:10px">数据库内容替换</td>
  50. </tr>
  51. <tr>
  52. <td bgcolor="#ffffff">
  53. <table width="100%" border="0" cellpadding="2" cellspacing="2" class="table table-borderless">
  54. <tr bgcolor="#ffffff">
  55. <td colspan="2">
  56. <div class="alert alert-info mb-0">程序用于批量替换数据库中某字段的内容,此操作极为危险,请小心使用</div>
  57. </td>
  58. </tr>
  59. <tr id='datasel'>
  60. <td width="15%" height="66">&nbsp;选择数据表与字段:</td>
  61. <td>
  62. <table width="98%" border="0" cellspacing="0" cellpadding="0">
  63. <tr>
  64. <td id="tables">
  65. <?php
  66. $dsql->SetQuery("Show Tables");
  67. $dsql->Execute('t');
  68. if($dsql->GetError()!=''){
  69. echo "<span style='color:#dc3545'>找不到您所指定的数据库 $dbname</span><br>";
  70. echo $qbutton;
  71. }
  72. echo "<select name='exptable' id='exptable' size='10' style='width:60%;height:220px' onchange='ShowFields()'>\r\n";
  73. while($row = $dsql->GetArray('t',MYSQL_BOTH)){
  74. echo "<option value='{$row[0]}'>{$row[0]}</option>\r\n";
  75. }
  76. echo "</select>\r\n";
  77. $dsql->Close();
  78. ?> </td>
  79. </tr>
  80. <tr>
  81. <td id='fields'></td>
  82. </tr>
  83. <tr>
  84. <td height="26"> 要替换的字段:
  85. <input name="rpfield" type="text" id="rpfield" class="alltxt">
  86. </td>
  87. </tr>
  88. </table>
  89. </td>
  90. </tr>
  91. <tr bgcolor="#FBFCE2">
  92. <td>&nbsp;替换方式:</td>
  93. <td>
  94. <label><input name="rptype" type="radio" id="ot1" value="replace" checked='1' class='np' />
  95. 普通替换</label>
  96. <label><input type="radio" name="rptype" id="ot2" value="regex" class='np' />
  97. 正则表达式</label> 主键字段:
  98. <input name="keyfield" type="text" id="keyfield" size="12" class="alltxt">
  99. (正则模式必须指定)
  100. </td>
  101. </tr>
  102. <tr>
  103. <td>&nbsp;被替换内容:</td>
  104. <td><textarea name="rpstring" id="rpstring" class="alltxt" style="width:60%;height:50px"></textarea></td>
  105. </tr>
  106. <tr>
  107. <td>&nbsp;替换为:</td>
  108. <td><textarea name="tostring" id="tostring" class="alltxt" style="width:60%;height:50px"></textarea></td>
  109. </tr>
  110. <tr>
  111. <td height="26">&nbsp;替换条件:</td>
  112. <td><input name="condition" type="text" id="condition" style="width:45%" class="alltxt">
  113. (空完全替换)</td>
  114. </tr>
  115. <tr>
  116. <td height="26">&nbsp;安全确认码:</td>
  117. <td>
  118. <table width="300" border="0" cellspacing="0" cellpadding="0">
  119. <tr>
  120. <td width="90">
  121. <input type="text" name="validate" class="alltxt" style="width:80px;text-transform: uppercase">
  122. </td>
  123. <td>
  124. <img src='../apps/vdimgck.php' style="cursor:pointer" onClick="this.src='../apps/vdimgck.php?'+new Date().getTime()+Math.round(Math.random() * 10000)"/>
  125. </td>
  126. </tr>
  127. </table>
  128. </td>
  129. </tr>
  130. </table>
  131. </td>
  132. </tr>
  133. <tr>
  134. <td height="30" bgcolor="#ffffff" align="center">
  135. <button type="submit" name="Submit" class="btn btn-success">开始替换数据</button>
  136. </td>
  137. </tr>
  138. </form>
  139. <tr bgcolor="#f8f8f8">
  140. <td height="26">
  141. <table width="100%" class="table table-borderless">
  142. <tr>
  143. <td width="74%">结果:</td>
  144. <td width="26%" align="right">
  145. <script language='javascript'>
  146. function ResizeDiv(obj, ty) {
  147. if (ty == "+") document.all[obj].style.pixelHeight += 50;
  148. else if (document.all[obj].style.pixelHeight > 80) document.all[obj].style.pixelHeight = document.all[obj].style.pixelHeight - 50;
  149. }
  150. </script>
  151. [<a href='javascript:;' onClick="ResizeDiv('mdv','+');">增大</a>] [<a href='javascript:;' onClick="ResizeDiv('mdv','-');">缩小</a>]
  152. </td>
  153. </tr>
  154. </table>
  155. </td>
  156. </tr>
  157. <tr bgcolor="#ffffff">
  158. <td id="mtd">
  159. <div id='mdv' style='width:100%;height:250px;'>
  160. <iframe name="stafrm" frameborder="0" id="stafrm" width="100%" height="100%"></iframe>
  161. </div>
  162. </td>
  163. </tr>
  164. </table>
  165. </body>
  166. </html>