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

155 lines
5.5KB

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