PHP为任意页面设访问密码

柔情痞子 提交于 2019-12-05 10:54:42

代码演示

代码简介

为你的页面 支持 加密访问 无论什么程序 只要是PHP程序 都是支持这代码的 来实现加密访问你的加密页面 或文章等等的页面 不保证其他程序可以正常使用 麻烦先测试!

代码如下

  1. <?php
  2. /********************************************
  3. * 使用方法:
  4. *
  5. * 1、将本段代码保存为 MkEncrypt.php
  6. *
  7. * 2、在要加密的页面前面引入这个 php 文件
  8. * require_once('MkEncrypt.php');
  9. *
  10. * 3、设置页面访问密码
  11. * MkEncrypt('页面密码');
  12. *
  13. ********************************************/
  14. // 密码 Cookie 加密盐
  15. if(!defined('MK_ENCRYPT_SALT'))
  16. define('MK_ENCRYPT_SALT', 'Kgs$JC!V');
  17. /**
  18. * 设置访问密码
  19. *
  20. * @param $password 访问密码
  21. * @param $pageid 页面唯一 ID 值,用于区分同一网站的不同加密页面
  22. */
  23. function MkEncrypt($password, $pageid = 'default') {
  24. $pageid = md5($pageid);
  25. $md5pw = md5(md5($password).MK_ENCRYPT_SALT);
  26. $postpwd = isset($_POST['pagepwd']) ? addslashes(trim($_POST['pagepwd'])) : '';
  27. $cookiepwd = isset($_COOKIE['mk_encrypt_'.$pageid]) ? addslashes(trim($_COOKIE['mk_encrypt_'.$pageid])) : '';
  28. if($cookiepwd == $md5pw) return; // Cookie密码验证正确
  29. if($postpwd == $password) { // 提交的密码正确
  30. setcookie('mk_encrypt_' . $pageid, $md5pw, time() + 3600000, '/');
  31. return;
  32. }
  33. ?>
  34. <html>
  35. <head>
  36. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
  37. <meta charset="UTF-8">
  38. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  39. <meta name="renderer" content="webkit">
  40. <meta name="author" content="mengkun">
  41. <meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no">
  42. <title>该页面已被加密</title>
  43. <style type="text/css">
  44. *{font-family:"Microsoft Yahei",微软雅黑,"Helvetica Neue",Helvetica,"Hiragino Sans GB","WenQuanYi Micro Hei",sans-serif;box-sizing:border-box;margin:0px;padding:0px;font-size:14px;-webkit-transition:.2s;-moz-transition:.2s;-ms-transition:.2s;-o-transition:.2s;transition:.2s}
  45. html,body{width:100%;height:100%}
  46. body{background-color:#F4F6F9;color:#768093}
  47. input,button{font-size:1em;border-radius:3px;-webkit-appearance:none}
  48. input{width:100%;padding:5px;box-sizing:border-box;border:1px solid #e5e9ef;resize:vertical}
  49. input:focus{background-color:#fff;outline:none}
  50. button{border:0;background:#6abd09;color:#fff;cursor:pointer;opacity:1;user-select:none}
  51. button:hover,button:focus{opacity:.9}
  52. button:active{opacity:1}
  53. .main{width:100%;max-width:500px;height:300px;padding:30px;background-color:#fff;border-radius:2px;box-shadow:0 10px 60px 0 rgba(29,29,31,0.09);transition:all .12s ease-out;position:absolute;left:0;top:0;bottom:0;right:0;margin:auto;text-align:center}
  54. .alert{width:80px}
  55. .mk-side-form{margin-bottom:28px}
  56. .mk-side-form input{float:left;padding:2px 10px;width:77%;height:37px;border:1px solid #ebebeb;border-right-color:transparent;border-radius:2px 0 0 2px;line-height:37px}
  57. .mk-side-form button{position:relative;overflow:visible;width:23%;height:37px;border-radius:0 2px 2px 0;text-transform:uppercase}
  58. .pw-tip{font-weight:normal;font-size:26px;text-align:center;margin:25px auto}
  59. #pw-error {color: red;margin-top: 15px;margin-bottom: -20px;}
  60. .return-home{text-decoration:none;color:#b1b1b1;font-size:16px}
  61. .return-home:hover{color:#1E9FFF;letter-spacing:5px}
  62. </style>
  63. </head>
  64. <body>
  65. <div class="main">
  66. <svg class="alert" viewBox="0 0 1084 1024" xmlns="http://www.w3.org/2000/svg" width="80" height="80">
  67. <defs><style/></defs>
  68. <path d="M1060.744 895.036L590.547 80.656a55.959 55.959 0 0 0-96.919 0L22.588 896.662a55.959 55.959 0 0 0 48.43 83.907h942.14a55.959 55.959 0 0 0 47.525-85.534zm-470.619-85.172a48.008 48.008 0 1 1-96.015 0v-1.567a48.008 48.008 0 1 1 96.015 0v1.567zm0-175.345a48.008 48.008 0 1 1-96.015 0V379.362a48.008 48.008 0 1 1 96.015 0v255.157z" fill="#FF9800"/>
  69. </svg>
  70. <form action="" method="post" class="mk-side-form">
  71. <h2 class="pw-tip">该页面已被加密</h2>
  72. <input type="password" name="pagepwd" placeholder="请输入访问密码查看" required><button type="submit">提交</button>
  73. <?php if($postpwd): ?>
  74. <p id="pw-error">Oops!密码不对哦~</p>
  75. <script>setTimeout(function() {document.getElementById("pw-error").style.display = "none"}, 2000);</script>
  76. <?php endif; ?>
  77. </form>
  78. <a href="/" class="return-home" title="点击回到网站首页">- 返回首页 - </a>
  79. </div>
  80. </body>
  81. </html>
  82. <?php
  83. exit();
  84. }
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!