{"id":24446,"date":"2024-11-21T14:43:10","date_gmt":"2024-11-21T06:43:10","guid":{"rendered":"https:\/\/fwq.ai\/blog\/24446\/"},"modified":"2024-11-21T14:43:10","modified_gmt":"2024-11-21T06:43:10","slug":"%e5%a6%82%e4%bd%95%e4%bd%bf%e7%94%a8webman%e8%bf%9b%e8%a1%8c%e7%bd%91%e7%ab%99%e7%9a%84%e7%94%a8%e6%88%b7%e8%ae%a4%e8%af%81%e5%92%8c%e6%9d%83%e9%99%90%e7%ae%a1%e7%90%86","status":"publish","type":"post","link":"https:\/\/fwq.ai\/blog\/24446\/","title":{"rendered":"\u5982\u4f55\u4f7f\u7528Webman\u8fdb\u884c\u7f51\u7ad9\u7684\u7528\u6237\u8ba4\u8bc1\u548c\u6743\u9650\u7ba1\u7406"},"content":{"rendered":"<p><img decoding=\"async\" src=\"https:\/\/img.php.cn\/upload\/article\/000\/887\/227\/169294374564535.jpg\" class=\"aligncenter\" title=\"\u5982\u4f55\u4f7f\u7528Webman\u8fdb\u884c\u7f51\u7ad9\u7684\u7528\u6237\u8ba4\u8bc1\u548c\u6743\u9650\u7ba1\u7406\u63d2\u56fe\" alt=\"\u5982\u4f55\u4f7f\u7528Webman\u8fdb\u884c\u7f51\u7ad9\u7684\u7528\u6237\u8ba4\u8bc1\u548c\u6743\u9650\u7ba1\u7406\u63d2\u56fe\" \/><\/p>\n<p>\u5982\u4f55\u4f7f\u7528Webman\u8fdb\u884c\u7f51\u7ad9\u7684\u7528\u6237\u8ba4\u8bc1\u548c\u6743\u9650\u7ba1\u7406<\/p>\n<p>\u5728\u73b0\u4ee3\u7684Web\u5e94\u7528\u4e2d\uff0c\u7528\u6237\u8ba4\u8bc1\u548c\u6743\u9650\u7ba1\u7406\u662f\u975e\u5e38\u91cd\u8981\u7684\u4e00\u90e8\u5206\u3002Webman\u662f\u4e00\u4e2a\u6d41\u884c\u7684PHP\u6846\u67b6\uff0c\u5b83\u63d0\u4f9b\u4e86\u4e00\u5957\u7b80\u5355\u800c\u5f3a\u5927\u7684\u5de5\u5177\uff0c\u53ef\u4ee5\u5e2e\u52a9\u6211\u4eec\u5b9e\u73b0\u7f51\u7ad9\u7684\u7528\u6237\u8ba4\u8bc1\u548c\u6743\u9650\u7ba1\u7406\u529f\u80fd\u3002\u672c\u6587\u5c06\u4ecb\u7ecd\u5982\u4f55\u4f7f\u7528Webman\u6765\u5b9e\u73b0\u8fd9\u4e9b\u529f\u80fd\uff0c\u5e76\u63d0\u4f9b\u76f8\u5173\u7684\u4ee3\u7801\u793a\u4f8b\u3002<\/p>\n<ol>\n<li>\u7528\u6237\u8ba4\u8bc1\u529f\u80fd\u7684\u5b9e\u73b0\uff1a<\/li>\n<\/ol>\n<p>\u7528\u6237\u8ba4\u8bc1\u662f\u6307\u9a8c\u8bc1\u7528\u6237\u7684\u8eab\u4efd\u662f\u5426\u5408\u6cd5\uff0c\u53ef\u4ee5\u4f7f\u7528\u7528\u6237\u540d\u548c\u5bc6\u7801\u6765\u8fdb\u884c\u9a8c\u8bc1\u3002\u5728Webman\u4e2d\uff0c\u6211\u4eec\u53ef\u4ee5\u4f7f\u7528Session\u6765\u8bb0\u5f55\u7528\u6237\u7684\u767b\u5f55\u72b6\u6001\u3002<\/p>\n<p>\u9996\u5148\uff0c\u6211\u4eec\u9700\u8981\u521b\u5efa\u4e00\u4e2a\u767b\u5f55\u9875\u9762\uff0c\u8ba9\u7528\u6237\u8f93\u5165\u7528\u6237\u540d\u548c\u5bc6\u7801\u3002\u63a5\u4e0b\u6765\uff0c\u6211\u4eec\u9700\u8981\u7f16\u5199\u4e00\u4e2a\u5904\u7406\u767b\u5f55\u8bf7\u6c42\u7684\u63a7\u5236\u5668\u65b9\u6cd5\u3002\u5728\u8fd9\u4e2a\u65b9\u6cd5\u4e2d\uff0c\u6211\u4eec\u53ef\u4ee5\u901a\u8fc7\u6bd4\u5bf9\u6570\u636e\u5e93\u4e2d\u5b58\u50a8\u7684\u7528\u6237\u540d\u548c\u5bc6\u7801\uff0c\u6765\u5224\u65ad\u7528\u6237\u662f\u5426\u767b\u5f55\u6210\u529f\u3002<\/p>\n<p>\u793a\u4f8b\u4ee3\u7801\u5982\u4e0b\uff1a<\/p>\n<pre>\/\/ \u767b\u5f55\u9875\u9762\npublic function login()\n{\n    return view('login');\n}\n\n\/\/ \u5904\u7406\u767b\u5f55\u8bf7\u6c42\npublic function doLogin()\n{\n    $username = $_POST['username'];\n    $password = $_POST['password'];\n\n    \/\/ \u6bd4\u5bf9\u7528\u6237\u540d\u548c\u5bc6\u7801\n    if ($username == 'admin' &amp;amp;&amp;amp; $password == '123456') {\n        \/\/ \u767b\u5f55\u6210\u529f\uff0c\u5c06\u7528\u6237\u4fe1\u606f\u5b58\u5165Session\n        $_SESSION['user'] = ['username' =&amp;gt; $username];\n        \/\/ \u8df3\u8f6c\u5230\u9996\u9875\n        redirect('\/');\n    } else {\n        \/\/ \u767b\u5f55\u5931\u8d25\uff0c\u8fd4\u56de\u9519\u8bef\u4fe1\u606f\n        return view('login', ['error' =&amp;gt; '\u7528\u6237\u540d\u6216\u5bc6\u7801\u9519\u8bef']);\n    }\n}<\/pre>\n<p>  \u767b\u5f55\u540e\u590d\u5236   <\/p>\n<p>\u5728\u5176\u4ed6\u9700\u8981\u8ba4\u8bc1\u7684\u9875\u9762\u4e2d\uff0c\u6211\u4eec\u53ef\u4ee5\u901a\u8fc7\u68c0\u67e5Session\u4e2d\u662f\u5426\u5b58\u5728\u7528\u6237\u4fe1\u606f\u6765\u5224\u65ad\u7528\u6237\u662f\u5426\u5df2\u767b\u5f55\uff1a<\/p>\n<pre>\/\/ \u9700\u8981\u8ba4\u8bc1\u7684\u9875\u9762\npublic function userPage()\n{\n    \/\/ \u68c0\u67e5Session\u4e2d\u662f\u5426\u5b58\u5728\u7528\u6237\u4fe1\u606f\n    if (isset($_SESSION['user'])) {\n        return view('user_page');\n    } else {\n        \/\/ \u7528\u6237\u672a\u767b\u5f55\uff0c\u8df3\u8f6c\u5230\u767b\u5f55\u9875\u9762\n        redirect('\/login');\n    }\n}<\/pre>\n<p>  \u767b\u5f55\u540e\u590d\u5236   <\/p>\n<ol>\n<li>\u6743\u9650\u7ba1\u7406\u529f\u80fd\u7684\u5b9e\u73b0\uff1a<\/li>\n<\/ol>\n<p>\u9664\u4e86\u7528\u6237\u8ba4\u8bc1\uff0c\u6743\u9650\u7ba1\u7406\u4e5f\u662f\u4e00\u4e2a\u91cd\u8981\u7684\u529f\u80fd\u3002Webman\u63d0\u4f9b\u4e86\u4e00\u5957\u7b80\u5355\u800c\u7075\u6d3b\u7684\u6743\u9650\u7ba1\u7406\u5de5\u5177\uff0c\u53ef\u4ee5\u5e2e\u52a9\u6211\u4eec\u5b9e\u73b0\u5404\u79cd\u6743\u9650\u63a7\u5236\u7b56\u7565\u3002<\/p>\n<p>\u9996\u5148\uff0c\u6211\u4eec\u9700\u8981\u5728\u6570\u636e\u5e93\u4e2d\u521b\u5efa\u4e00\u4e2a\u8868\u6765\u5b58\u50a8\u7528\u6237\u548c\u6743\u9650\u7684\u5173\u7cfb\u3002\u4f8b\u5982\uff0c\u6211\u4eec\u53ef\u4ee5\u521b\u5efa\u4e00\u4e2a\u540d\u4e3a&#8221;users_roles&#8221;\u7684\u8868\uff0c\u7528\u6765\u5b58\u50a8\u7528\u6237\u548c\u89d2\u8272\u7684\u5bf9\u5e94\u5173\u7cfb\u3002<\/p>\n<p>\u63a5\u4e0b\u6765\uff0c\u6211\u4eec\u9700\u8981\u7f16\u5199\u4e00\u4e2a\u63a7\u5236\u5668\u65b9\u6cd5\u6765\u68c0\u67e5\u7528\u6237\u662f\u5426\u5177\u6709\u67d0\u4e2a\u7279\u5b9a\u7684\u6743\u9650\u3002\u5728\u8fd9\u4e2a\u65b9\u6cd5\u4e2d\uff0c\u6211\u4eec\u53ef\u4ee5\u67e5\u8be2\u6570\u636e\u5e93\uff0c\u5224\u65ad\u7528\u6237\u662f\u5426\u5177\u6709\u76f8\u5e94\u7684\u6743\u9650\u3002<\/p>\n<p>\u793a\u4f8b\u4ee3\u7801\u5982\u4e0b\uff1a<\/p>\n<pre>\/\/ \u68c0\u67e5\u7528\u6237\u6743\u9650\npublic function checkPermission($permission)\n{\n    if (isset($_SESSION['user'])) {\n        $username = $_SESSION['user']['username'];\n\n        \/\/ \u67e5\u8be2\u7528\u6237\u89d2\u8272\u7684\u6743\u9650\n        $permissions = DB::table('users_roles')\n            -&amp;gt;join('roles_permissions', 'users_roles.role_id', '=', 'roles_permissions.role_id')\n            -&amp;gt;join('permissions', 'roles_permissions.permission_id', '=', 'permissions.id')\n            -&amp;gt;where('users_roles.username', $username)\n            -&amp;gt;pluck('permissions.name')\n            -&amp;gt;toArray();\n\n        \/\/ \u68c0\u67e5\u7528\u6237\u662f\u5426\u5177\u6709\u6743\u9650\n        if (in_array($permission, $permissions)) {\n            return true;\n        }\n    }\n\n    return false;\n}<\/pre>\n<p>  \u767b\u5f55\u540e\u590d\u5236   <\/p>\n<p>\u5728\u5176\u4ed6\u9700\u8981\u6743\u9650\u63a7\u5236\u7684\u5730\u65b9\uff0c\u6211\u4eec\u53ef\u4ee5\u8c03\u7528\u8fd9\u4e2a\u65b9\u6cd5\u6765\u5224\u65ad\u7528\u6237\u662f\u5426\u5177\u6709\u76f8\u5e94\u7684\u6743\u9650\uff1a<\/p>\n<pre>\/\/ \u9700\u8981\u6743\u9650\u63a7\u5236\u7684\u9875\u9762\npublic function adminPage()\n{\n    \/\/ \u68c0\u67e5\u7528\u6237\u662f\u5426\u5177\u6709\"admin\"\u6743\u9650\n    if ($this-&amp;gt;checkPermission('admin')) {\n        return view('admin_page');\n    } else {\n        \/\/ \u6ca1\u6709\u6743\u9650\uff0c\u8df3\u8f6c\u5230\u9996\u9875\n        redirect('\/');\n    }\n}<\/pre>\n<p>  \u767b\u5f55\u540e\u590d\u5236   <\/p>\n<p>\u901a\u8fc7\u4e0a\u8ff0\u65b9\u5f0f\uff0c\u6211\u4eec\u53ef\u4ee5\u4f7f\u7528Webman\u6765\u5b9e\u73b0\u7f51\u7ad9\u7684\u7528\u6237\u8ba4\u8bc1\u548c\u6743\u9650\u7ba1\u7406\u529f\u80fd\u3002Webman\u63d0\u4f9b\u4e86\u7b80\u5355\u800c\u5f3a\u5927\u7684\u5de5\u5177\uff0c\u5e2e\u52a9\u6211\u4eec\u8f7b\u677e\u5b8c\u6210\u8fd9\u4e9b\u4efb\u52a1\u3002\u5e0c\u671b\u672c\u6587\u80fd\u5bf9\u60a8\u6709\u6240\u5e2e\u52a9\uff01<\/p>\n<p>\u4ee5\u4e0a\u5c31\u662f\u5982\u4f55\u4f7f\u7528Webman\u8fdb\u884c\u7f51\u7ad9\u7684\u7528\u6237\u8ba4\u8bc1\u548c\u6743\u9650\u7ba1\u7406\u7684\u8be6\u7ec6\u5185\u5bb9\uff0c\u66f4\u591a\u8bf7\u5173\u6ce8\u7c73\u4e91\u5176\u5b83\u76f8\u5173\u6587\u7ae0\uff01<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u5982\u4f55\u4f7f\u7528Webman\u8fdb\u884c\u7f51\u7ad9\u7684\u7528\u6237\u8ba4\u8bc1\u548c\u6743\u9650\u7ba1\u7406 \u5728\u73b0\u4ee3\u7684Web\u5e94\u7528\u4e2d\uff0c\u7528\u6237\u8ba4\u8bc1\u548c\u6743\u9650\u7ba1\u7406\u662f\u975e\u5e38\u91cd\u8981\u7684\u4e00\u90e8\u5206\u3002Webman\u662f\u4e00\u4e2a\u6d41\u884c\u7684PHP\u6846\u67b6\uff0c\u5b83\u63d0\u4f9b\u4e86\u4e00\u5957\u7b80\u5355\u800c\u5f3a\u5927\u7684\u5de5\u5177\uff0c\u53ef\u4ee5\u5e2e\u52a9\u6211\u4eec\u5b9e\u73b0\u7f51\u7ad9\u7684\u7528\u6237\u8ba4\u8bc1\u548c\u6743\u9650\u7ba1\u7406\u529f\u80fd\u3002\u672c\u6587\u5c06\u4ecb\u7ecd\u5982\u4f55\u4f7f\u7528Webman\u6765\u5b9e\u73b0\u8fd9\u4e9b\u529f\u80fd\uff0c\u5e76\u63d0\u4f9b\u76f8\u5173\u7684\u4ee3\u7801\u793a\u4f8b\u3002 \u7528\u6237\u8ba4\u8bc1\u529f\u80fd\u7684\u5b9e\u73b0\uff1a \u7528\u6237\u8ba4\u8bc1\u662f\u6307\u9a8c\u8bc1\u7528\u6237\u7684\u8eab\u4efd\u662f\u5426\u5408\u6cd5\uff0c\u53ef\u4ee5\u4f7f\u7528\u7528\u6237\u540d\u548c\u5bc6\u7801\u6765\u8fdb\u884c\u9a8c\u8bc1\u3002\u5728Webman\u4e2d\uff0c\u6211\u4eec\u53ef\u4ee5\u4f7f\u7528Session\u6765\u8bb0\u5f55\u7528\u6237\u7684\u767b\u5f55\u72b6\u6001\u3002 \u9996\u5148\uff0c\u6211\u4eec\u9700\u8981\u521b\u5efa\u4e00\u4e2a\u767b\u5f55\u9875\u9762\uff0c\u8ba9\u7528\u6237\u8f93\u5165\u7528\u6237\u540d\u548c\u5bc6\u7801\u3002\u63a5\u4e0b\u6765\uff0c\u6211\u4eec\u9700\u8981\u7f16\u5199\u4e00\u4e2a\u5904\u7406\u767b\u5f55\u8bf7\u6c42\u7684\u63a7\u5236\u5668\u65b9\u6cd5\u3002\u5728\u8fd9\u4e2a\u65b9\u6cd5\u4e2d\uff0c\u6211\u4eec\u53ef\u4ee5\u901a\u8fc7\u6bd4\u5bf9\u6570\u636e\u5e93\u4e2d\u5b58\u50a8\u7684\u7528\u6237\u540d\u548c\u5bc6\u7801\uff0c\u6765\u5224\u65ad\u7528\u6237\u662f\u5426\u767b\u5f55\u6210\u529f\u3002 \u793a\u4f8b\u4ee3\u7801\u5982\u4e0b\uff1a \/\/ \u767b\u5f55\u9875\u9762 public function login() { return view(&#8216;login&#8217;); } \/\/ \u5904\u7406\u767b\u5f55\u8bf7\u6c42 public function doLogin() { $username = $_POST[&#8216;username&#8217;]; $password = $_POST[&#8216;password&#8217;]; \/\/ \u6bd4\u5bf9\u7528\u6237\u540d\u548c\u5bc6\u7801 if ($username == &#8216;admin&#8217; &amp;amp;&amp;amp; $password == &#8216;123456&#8217;) { \/\/ \u767b\u5f55\u6210\u529f\uff0c\u5c06\u7528\u6237\u4fe1\u606f\u5b58\u5165Session $_SESSION[&#8216;user&#8217;] = [&#8216;username&#8217; =&amp;gt; $username]; \/\/ \u8df3\u8f6c\u5230\u9996\u9875 redirect(&#8216;\/&#8217;); } else { \/\/ \u767b\u5f55\u5931\u8d25\uff0c\u8fd4\u56de\u9519\u8bef\u4fe1\u606f return view(&#8216;login&#8217;, [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[16],"tags":[],"class_list":["post-24446","post","type-post","status-publish","format-standard","hentry","category-16"],"_links":{"self":[{"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/posts\/24446","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/comments?post=24446"}],"version-history":[{"count":0,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/posts\/24446\/revisions"}],"wp:attachment":[{"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/media?parent=24446"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/categories?post=24446"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/tags?post=24446"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}