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

129 lines
4.4KB

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="utf-8">
  5. <meta http-equiv="X-UA-Compatible" content="IE=Edge,chrome=1">
  6. <title>数据批量替换</title>
  7. <link rel="stylesheet" href="../static/web/font/css/font-awesome.min.css">
  8. <link rel="stylesheet" href="../static/web/css/bootstrap.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="../static/web/js/webajax.js"></script>
  13. <script src="js/main.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 cellpadding="1" cellspacing="1" align="center" class="table maintable my-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="#f5f5f5" colspan="2">数据库文档替换</td>
  51. </tr>
  52. <tr>
  53. <td colspan="2">
  54. <div class="alert alert-info mb-0">程序用于批量替换数据库中某字段的文档,此操作极为危险,请小心使用</div>
  55. </td>
  56. </tr>
  57. <tr>
  58. <td width="260">选择数据表与字段:</td>
  59. <td class="table-borderless p-0">
  60. <table width="98%" cellspacing="0" cellpadding="0">
  61. <tr>
  62. <td id="tables">
  63. <?php
  64. $dsql->SetQuery("Show Tables");
  65. $dsql->Execute('t');
  66. if ($dsql->GetError()!=''){
  67. echo "<span class='text-primary'>找不到您所指定的数据库 $dbname</span><br>";
  68. echo $qbutton;
  69. }
  70. echo "<select name='exptable' id='exptable' onchange='ShowFields()' class='admin-input-md'>";
  71. while($row = $dsql->GetArray('t',MYSQL_BOTH)){
  72. echo "<option value='{$row[0]}'>{$row[0]}</option>";
  73. }
  74. echo "</select>";
  75. $dsql->Close();
  76. ?>
  77. </td>
  78. </tr>
  79. <tr>
  80. <td id="fields"></td>
  81. </tr>
  82. <tr>
  83. <td><input type="text" name="rpfield" id="rpfield" class="admin-input-md">(选择替换字段)</td>
  84. </tr>
  85. </table>
  86. </td>
  87. </tr>
  88. <tr>
  89. <td>替换方式:</td>
  90. <td>
  91. <label><input type="radio" name="rptype" id="ot1" value="replace" checked="1"> 普通替换</label>
  92. <label><input type="radio" name="rptype" id="ot2" value="regex"> 正则表达式</label>
  93. 主键字段:<input type="text" name="keyfield" id="keyfield" size="12">(正则模式必须指定)
  94. </td>
  95. </tr>
  96. <tr>
  97. <td>被替换文档:</td>
  98. <td><textarea name="rpstring" id="rpstring" class="admin-textarea-xl"></textarea></td>
  99. </tr>
  100. <tr>
  101. <td>替换为:</td>
  102. <td><textarea name="tostring" id="tostring" class="admin-textarea-xl"></textarea></td>
  103. </tr>
  104. <tr>
  105. <td>替换条件:</td>
  106. <td><input type="text" name="condition" id="condition" class="admin-input-sm">(空完全替换)</td>
  107. </tr>
  108. <tr>
  109. <td>安全确认码:</td>
  110. <td>
  111. <input type="text" name="validate" class="admin-input-sm text-uppercase">
  112. <img src="../apps/vdimgck.php" onClick="this.src='../apps/vdimgck.php?'+new Date().getTime()+Math.round(Math.random() * 10000)" title="验证码">
  113. </td>
  114. </tr>
  115. <tr>
  116. <td bgcolor="#e9ecef" colspan="2" align="center"><button type="submit" name="Submit" class="btn btn-success btn-sm">开始替换数据</button></td>
  117. </tr>
  118. </form>
  119. <tr>
  120. <td colspan="2">结果:</td>
  121. </tr>
  122. <tr>
  123. <td colspan="2" id="mtd">
  124. <div id="mdv" class="admin-win-iframe"><iframe name="stafrm" frameborder="0" id="stafrm" width="100%" height="100%"></iframe></div>
  125. </td>
  126. </tr>
  127. </table>
  128. </body>
  129. </html>