{"id":2506,"date":"2025-03-24T08:47:08","date_gmt":"2025-03-23T23:47:08","guid":{"rendered":"https:\/\/dexall.co.jp\/articles\/?p=2506"},"modified":"2025-03-24T08:47:38","modified_gmt":"2025-03-23T23:47:38","slug":"%e3%80%90%e4%bf%9d%e5%ad%98%e7%89%88%e3%80%91laravel%e3%81%aeauth%e6%a9%9f%e8%83%bd%e3%82%92%e5%ae%8c%e5%85%a8%e3%83%9e%e3%82%b9%e3%82%bf%e3%83%bc%ef%bc%81%e5%ae%9f%e8%a3%85%e3%81%8b%e3%82%89%e3%82%ab","status":"publish","type":"post","link":"https:\/\/dexall.co.jp\/articles\/?p=2506","title":{"rendered":"\u3010\u4fdd\u5b58\u7248\u3011Laravel\u306eAuth\u6a5f\u80fd\u3092\u5b8c\u5168\u30de\u30b9\u30bf\u30fc\uff01\u5b9f\u88c5\u304b\u3089\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u307e\u3067\u5fb9\u5e95\u89e3\u8aac"},"content":{"rendered":"\n<div class=\"toc\"><br \/>\n<b>Warning<\/b>:  Undefined array key \"is_admin\" in <b>\/home\/xs392991\/dexall.co.jp\/public_html\/articles\/wp-content\/themes\/sango-theme\/library\/gutenberg\/dist\/classes\/Toc.php<\/b> on line <b>116<\/b><br \/>\n<br \/>\n<b>Warning<\/b>:  Undefined array key \"is_category_top\" in <b>\/home\/xs392991\/dexall.co.jp\/public_html\/articles\/wp-content\/themes\/sango-theme\/library\/gutenberg\/dist\/classes\/Toc.php<\/b> on line <b>121<\/b><br \/>\n<br \/>\n<b>Warning<\/b>:  Undefined array key \"is_top\" in <b>\/home\/xs392991\/dexall.co.jp\/public_html\/articles\/wp-content\/themes\/sango-theme\/library\/gutenberg\/dist\/classes\/Toc.php<\/b> on line <b>128<\/b><br \/>\n    <div id=\"toc_container\" class=\"sgb-toc--bullets js-smooth-scroll\" data-dialog-title=\"\u76ee\u6b21\">\n      <p class=\"toc_title\">\u76ee\u6b21 <\/p>\n      <ul class=\"toc_list\">  <li class=\"first\">    <a href=\"#i-0\">Laravel\u306e\u8a8d\u8a3c\u6a5f\u80fd\u3068\u306f\uff1f\u57fa\u790e\u304b\u3089\u5b8c\u5168\u7406\u89e3<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-1\">Auth\u6a5f\u80fd\u304c\u63d0\u4f9b\u3059\u308b4\u3064\u306e\u4e3b\u8981\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-2\">\u8a8d\u8a3c\u51e6\u7406\u306e\u88cf\u5074\u3067\u52d5\u4f5c\u3059\u308b\u4ed5\u7d44\u307f<\/a>      <\/li>    <\/ul>  <\/li>  <li>    <a href=\"#i-3\">Laravel Auth\u306e\u5c0e\u5165\u624b\u9806\u3068\u57fa\u672c\u8a2d\u5b9a<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-4\">auth:make\u30b3\u30de\u30f3\u30c9\u30675\u5206\u3067\u4f5c\u308b\u8a8d\u8a3c\u57fa\u76e4<\/a>      <\/li>      <li>        <a href=\"#i-5\">\u8a2d\u5b9a\u30d5\u30a1\u30a4\u30ebauth.php\u306e\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u30dd\u30a4\u30f3\u30c8<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-6\">\u5b88\u308b\u3079\u304d3\u3064\u306e\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u8a2d\u5b9a<\/a>      <\/li>    <\/ul>  <\/li>  <li>    <a href=\"#i-7\">\u5b9f\u8df5\u7684\u306a\u8a8d\u8a3c\u6a5f\u80fd\u306e\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u65b9\u6cd5<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-8\">\u30ed\u30b0\u30a4\u30f3\u30d5\u30a9\u30fc\u30e0\u306e\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u5b9f\u88c5\u4f8b<\/a>      <\/li>      <li>        <a href=\"#i-9\">\u72ec\u81ea\u306e\u30ac\u30fc\u30c9\u8a2d\u5b9a\u306b\u3088\u308b\u591a\u91cd\u8a8d\u8a3c\u306e\u5b9f\u73fe<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-10\">\u30df\u30c9\u30eb\u30a6\u30a7\u30a2\u3092\u6d3b\u7528\u3057\u305f\u67d4\u8edf\u306a\u8a8d\u53ef\u5236\u5fa1<\/a>      <\/li>    <\/ul>  <\/li>  <li>    <a href=\"#i-11\">\u73fe\u5834\u3067\u4f7f\u3048\u308b\u8a8d\u8a3c\u6a5f\u80fd\u306e\u5fdc\u7528\u30c6\u30af\u30cb\u30c3\u30af<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-12\">\u30bd\u30fc\u30b7\u30e3\u30eb\u30ed\u30b0\u30a4\u30f3\u3092\u5c0e\u5165\u3059\u308b\u5b9f\u88c5\u624b\u9806<\/a>      <\/li>      <li>        <a href=\"#i-13\">2\u6bb5\u968e\u8a8d\u8a3c\u3067\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u3092\u5f37\u5316\u3059\u308b\u65b9\u6cd5<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-14\">API\u30c8\u30fc\u30af\u30f3\u8a8d\u8a3c\u306e\u5b9f\u88c5\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9<\/a>      <\/li>    <\/ul>  <\/li>  <li>    <a href=\"#i-15\">Auth\u6a5f\u80fd\u306e\u30c8\u30e9\u30d6\u30eb\u30b7\u30e5\u30fc\u30c6\u30a3\u30f3\u30b0<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-16\">\u30ed\u30b0\u30a4\u30f3\u51e6\u7406\u3067\u767a\u751f\u3059\u308b\u4e3b\u8981\u306a\u30a8\u30e9\u30fc\u3068\u5bfe\u51e6\u6cd5<\/a>      <\/li>      <li>        <a href=\"#i-17\">\u30bb\u30c3\u30b7\u30e7\u30f3\u95a2\u9023\u306e\u4e0d\u5177\u5408\u89e3\u6c7a\u30c6\u30af\u30cb\u30c3\u30af<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-18\">\u672c\u756a\u74b0\u5883\u3067\u306e\u8a8d\u8a3c\u30c8\u30e9\u30d6\u30eb\u5bfe\u5fdc\u4f8b<\/a>      <\/li>    <\/ul>  <\/li>  <li class=\"last\">    <a href=\"#i-19\">Laravel\u8a8d\u8a3c\u6a5f\u80fd\u306e\u904b\u7528\u3068\u30e1\u30f3\u30c6\u30ca\u30f3\u30b9<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-20\">\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u30a2\u30c3\u30d7\u30c7\u30fc\u30c8\u306e\u9069\u7528\u65b9\u91dd<\/a>      <\/li>      <li>        <a href=\"#i-21\">\u30ed\u30b0\u76e3\u8996\u3068\u4e0d\u6b63\u30a2\u30af\u30bb\u30b9\u5bfe\u7b56\u306e\u5b9f\u88c5<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-22\">\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u30c1\u30e5\u30fc\u30cb\u30f3\u30b0\u306e\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9<\/a>      <\/li>    <\/ul>  <\/li><\/ul>\n      <a href=\"#\" class=\"sgb-toc-button js-toc-button\" rel=\"nofollow\" data-open-dialog=\"true\"><i class=\"fa fa-list\"><\/i><span class=\"sgb-toc-button__text\">\u76ee\u6b21\u3078<\/span><\/a>\n    <\/div><\/div><h2 class=\"wp-block-heading\" id=\"i-0\">Laravel\u306e\u8a8d\u8a3c\u6a5f\u80fd\u3068\u306f\uff1f\u57fa\u790e\u304b\u3089\u5b8c\u5168\u7406\u89e3<\/h2>\n\n\n\n<p>Laravel\u306e\u8a8d\u8a3c\uff08Auth\uff09\u6a5f\u80fd\u306f\u3001Web\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306b\u304a\u3051\u308b\u300c\u8ab0\u3067\u3042\u308b\u304b\u300d\u3092\u78ba\u8a8d\u3057\u3001\u9069\u5207\u306a\u30ea\u30bd\u30fc\u30b9\u3078\u306e\u30a2\u30af\u30bb\u30b9\u3092\u5236\u5fa1\u3059\u308b\u6a5f\u80fd\u3067\u3059\u3002\u30d5\u30ec\u30fc\u30e0\u30ef\u30fc\u30af\u306e\u4e2d\u3067\u3082\u7279\u306b\u91cd\u8981\u306a\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306e1\u3064\u3068\u3057\u3066\u4f4d\u7f6e\u3065\u3051\u3089\u308c\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-1\">Auth\u6a5f\u80fd\u304c\u63d0\u4f9b\u3059\u308b4\u3064\u306e\u4e3b\u8981\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8<\/h3>\n\n\n\n<p>\u8a8d\u8a3c\u6a5f\u80fd\u306f\u4ee5\u4e0b\u306e4\u3064\u306e\u4e3b\u8981\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u304b\u3089\u69cb\u6210\u3055\u308c\u3066\u3044\u307e\u3059\uff1a<\/p>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u8a8d\u8a3c\uff08Authentication\uff09\u30b7\u30b9\u30c6\u30e0<\/strong><\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30e6\u30fc\u30b6\u30fc\u306e\u30ed\u30b0\u30a4\u30f3\u51e6\u7406\u3092\u62c5\u5f53<\/li>\n\n\n\n<li>\u30bb\u30c3\u30b7\u30e7\u30f3\u7ba1\u7406\u3084\u30c8\u30fc\u30af\u30f3\u7ba1\u7406\u3092\u5b9f\u65bd<\/li>\n\n\n\n<li>Remember Me\u6a5f\u80fd\u306e\u63d0\u4f9b<\/li>\n<\/ul>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">   \/\/ \u57fa\u672c\u7684\u306a\u8a8d\u8a3c\u30c1\u30a7\u30c3\u30af\u306e\u4f8b\n   if (Auth::check()) {\n       \/\/ \u30e6\u30fc\u30b6\u30fc\u306f\u8a8d\u8a3c\u6e08\u307f\n       $user = Auth::user();  \/\/ \u73fe\u5728\u306e\u30e6\u30fc\u30b6\u30fc\u60c5\u5831\u3092\u53d6\u5f97\n   }<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li><strong>\u8a8d\u53ef\uff08Authorization\uff09\u30b7\u30b9\u30c6\u30e0<\/strong><\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30a2\u30af\u30bb\u30b9\u6a29\u9650\u306e\u78ba\u8a8d<\/li>\n\n\n\n<li>\u30dd\u30ea\u30b7\u30fc\u3068\u30b2\u30fc\u30c8\u306e\u7ba1\u7406<\/li>\n\n\n\n<li>\u30ed\u30fc\u30eb\u30d9\u30fc\u30b9\u306e\u30a2\u30af\u30bb\u30b9\u5236\u5fa1<\/li>\n<\/ul>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">   \/\/ \u30dd\u30ea\u30b7\u30fc\u3092\u4f7f\u7528\u3057\u305f\u8a8d\u53ef\u306e\u4f8b\n   class PostPolicy\n   {\n       public function update(User $user, Post $post)\n       {\n           return $user-&gt;id === $post-&gt;user_id;\n       }\n   }<\/pre>\n\n\n\n<ol start=\"3\" class=\"wp-block-list\">\n<li><strong>\u30d1\u30b9\u30ef\u30fc\u30c9\u30ea\u30bb\u30c3\u30c8\u30b7\u30b9\u30c6\u30e0<\/strong><\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30d1\u30b9\u30ef\u30fc\u30c9\u30ea\u30bb\u30c3\u30c8\u30e1\u30fc\u30eb\u306e\u9001\u4fe1<\/li>\n\n\n\n<li>\u30c8\u30fc\u30af\u30f3\u306e\u751f\u6210\u3068\u691c\u8a3c<\/li>\n\n\n\n<li>\u30d1\u30b9\u30ef\u30fc\u30c9\u66f4\u65b0\u51e6\u7406<\/li>\n<\/ul>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">   \/\/ \u30d1\u30b9\u30ef\u30fc\u30c9\u30ea\u30bb\u30c3\u30c8\u30e1\u30fc\u30eb\u9001\u4fe1\u306e\u4f8b\n   Password::sendResetLink($request-&gt;only('email'));<\/pre>\n\n\n\n<ol start=\"4\" class=\"wp-block-list\">\n<li><strong>\u30e6\u30fc\u30b6\u30fc\u767b\u9332\u30b7\u30b9\u30c6\u30e0<\/strong><\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u65b0\u898f\u30e6\u30fc\u30b6\u30fc\u767b\u9332\u51e6\u7406<\/li>\n\n\n\n<li>\u30e1\u30fc\u30eb\u78ba\u8a8d\u6a5f\u80fd<\/li>\n\n\n\n<li>\u30d7\u30ed\u30d5\u30a3\u30fc\u30eb\u7ba1\u7406<\/li>\n<\/ul>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">   \/\/ \u57fa\u672c\u7684\u306a\u30e6\u30fc\u30b6\u30fc\u767b\u9332\u51e6\u7406\u306e\u4f8b\n   User::create([\n       'name' =&gt; $request-&gt;name,\n       'email' =&gt; $request-&gt;email,\n       'password' =&gt; Hash::make($request-&gt;password),\n   ]);<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-2\">\u8a8d\u8a3c\u51e6\u7406\u306e\u88cf\u5074\u3067\u52d5\u4f5c\u3059\u308b\u4ed5\u7d44\u307f<\/h3>\n\n\n\n<p>Laravel\u306e\u8a8d\u8a3c\u30b7\u30b9\u30c6\u30e0\u306f\u3001\u4ee5\u4e0b\u306e\u6d41\u308c\u3067\u52d5\u4f5c\u3057\u307e\u3059\uff1a<\/p>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u30ea\u30af\u30a8\u30b9\u30c8\u53d7\u4fe1\u6642\u306e\u51e6\u7406<\/strong><\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30bb\u30c3\u30b7\u30e7\u30f3ID\u306e\u78ba\u8a8d<\/li>\n\n\n\n<li>\u30af\u30c3\u30ad\u30fc\u306e\u691c\u8a3c<\/li>\n\n\n\n<li>\u30c8\u30fc\u30af\u30f3\u306e\u78ba\u8a8d<\/li>\n<\/ul>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u8a8d\u8a3c\u60c5\u5831\u306e\u691c\u8a3c\u30d7\u30ed\u30bb\u30b9<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">   \/\/ \u8a8d\u8a3c\u306e\u4ed5\u7d44\u307f\uff08\u7c21\u7565\u5316\u3057\u305f\u4f8b\uff09\n   protected function attemptLogin(Request $request)\n   {\n       return $this-&gt;guard()-&gt;attempt(\n           $this-&gt;credentials($request),\n           $request-&gt;filled('remember')\n       );\n   }<\/pre>\n\n\n\n<ol start=\"3\" class=\"wp-block-list\">\n<li><strong>\u30bb\u30c3\u30b7\u30e7\u30f3\u30fb\u30af\u30c3\u30ad\u30fc\u7ba1\u7406<\/strong><\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30bb\u30c3\u30b7\u30e7\u30f3\u30c7\u30fc\u30bf\u306e\u4fdd\u5b58<\/li>\n\n\n\n<li>Remember Me\u30c8\u30fc\u30af\u30f3\u306e\u751f\u6210<\/li>\n\n\n\n<li>\u30bb\u30c3\u30b7\u30e7\u30f3\u306e\u518d\u751f\u6210<\/li>\n<\/ul>\n\n\n\n<ol start=\"3\" class=\"wp-block-list\">\n<li><strong>\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u5bfe\u7b56<\/strong><br>\u5bfe\u7b56 \u8aac\u660e \u5b9f\u88c5\u65b9\u6cd5<br>\u30d6\u30eb\u30fc\u30c8\u30d5\u30a9\u30fc\u30b9\u5bfe\u7b56 \u30ed\u30b0\u30a4\u30f3\u8a66\u884c\u56de\u6570\u306e\u5236\u9650 ThrottlesLogins \u30c8\u30ec\u30a4\u30c8\u4f7f\u7528<br>\u30bb\u30c3\u30b7\u30e7\u30f3\u56fa\u5b9a\u653b\u6483\u5bfe\u7b56 \u30ed\u30b0\u30a4\u30f3\u6642\u306b\u30bb\u30c3\u30b7\u30e7\u30f3ID\u3092\u518d\u751f\u6210 \u81ea\u52d5\u5b9f\u65bd<br>\u30d1\u30b9\u30ef\u30fc\u30c9\u30cf\u30c3\u30b7\u30e5\u5316 \u30d1\u30b9\u30ef\u30fc\u30c9\u306e\u5b89\u5168\u306a\u4fdd\u5b58 Hash::make()\u3092\u4f7f\u7528 \u3053\u306e\u3088\u3046\u306b\u3001Laravel\u306e\u8a8d\u8a3c\u6a5f\u80fd\u306f\u5305\u62ec\u7684\u306a\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u5bfe\u7b56\u3092\u5099\u3048\u3066\u304a\u308a\u3001\u591a\u304f\u306e\u30e6\u30fc\u30b9\u30b1\u30fc\u30b9\u306b\u5bfe\u5fdc\u3067\u304d\u308b\u67d4\u8edf\u6027\u3092\u6301\u3063\u3066\u3044\u307e\u3059\u3002\u6b21\u306e\u30bb\u30af\u30b7\u30e7\u30f3\u3067\u306f\u3001\u3053\u308c\u3089\u306e\u6a5f\u80fd\u3092\u5b9f\u969b\u306b\u5c0e\u5165\u30fb\u8a2d\u5b9a\u3059\u308b\u65b9\u6cd5\u306b\u3064\u3044\u3066\u8a73\u3057\u304f\u89e3\u8aac\u3057\u307e\u3059\u3002<\/li>\n<\/ol>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"i-3\">Laravel Auth\u306e\u5c0e\u5165\u624b\u9806\u3068\u57fa\u672c\u8a2d\u5b9a<\/h2>\n\n\n\n<p>\u8a8d\u8a3c\u6a5f\u80fd\u306e\u5b9f\u88c5\u306f\u3001Web\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u958b\u767a\u306b\u304a\u3051\u308b\u6700\u91cd\u8981\u30bf\u30b9\u30af\u306e1\u3064\u3067\u3059\u3002Laravel\u3067\u306f\u3001\u308f\u305a\u304b\u6570\u30b9\u30c6\u30c3\u30d7\u3067\u5805\u7262\u306a\u8a8d\u8a3c\u57fa\u76e4\u3092\u69cb\u7bc9\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-4\">auth:make\u30b3\u30de\u30f3\u30c9\u30675\u5206\u3067\u4f5c\u308b\u8a8d\u8a3c\u57fa\u76e4<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u8a8d\u8a3c\u30b9\u30ab\u30d5\u30a9\u30fc\u30eb\u30c9\u306e\u751f\u6210<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\"># Laravel 8\u4ee5\u964d\u306e\u5834\u5408\ncomposer require laravel\/ui\nphp artisan ui bootstrap --auth\n\n# \u307e\u305f\u306f\u3001Jetstream\/Breeze\u3092\u4f7f\u7528\u3059\u308b\u5834\u5408\ncomposer require laravel\/breeze --dev\nphp artisan breeze:install<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li><strong>\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u306e\u6e96\u5099<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\"># \u30de\u30a4\u30b0\u30ec\u30fc\u30b7\u30e7\u30f3\u306e\u5b9f\u884c\nphp artisan migrate<\/pre>\n\n\n\n<ol start=\"3\" class=\"wp-block-list\">\n<li><strong>\u8a8d\u8a3c\u95a2\u9023\u30d5\u30a1\u30a4\u30eb\u306e\u78ba\u8a8d<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">app\/\n\u251c\u2500\u2500 Http\/\n\u2502   \u251c\u2500\u2500 Controllers\/\n\u2502   \u2502   \u251c\u2500\u2500 Auth\/\n\u2502   \u2502   \u2502   \u251c\u2500\u2500 LoginController.php\n\u2502   \u2502   \u2502   \u251c\u2500\u2500 RegisterController.php\n\u2502   \u2502   \u2502   \u251c\u2500\u2500 ForgotPasswordController.php\n\u2502   \u2502   \u2502   \u2514\u2500\u2500 ResetPasswordController.php\n\u251c\u2500\u2500 Models\/\n\u2502   \u2514\u2500\u2500 User.php\n\u2514\u2500\u2500 config\/\n    \u2514\u2500\u2500 auth.php<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-5\">\u8a2d\u5b9a\u30d5\u30a1\u30a4\u30ebauth.php\u306e\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u30dd\u30a4\u30f3\u30c8<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u8a8d\u8a3c\u30c9\u30e9\u30a4\u30d0\u30fc\u306e\u8a2d\u5b9a<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">\/\/ config\/auth.php\n'guards' =&gt; [\n    'web' =&gt; [\n        'driver' =&gt; 'session',  \/\/ \u30bb\u30c3\u30b7\u30e7\u30f3\u8a8d\u8a3c\n        'provider' =&gt; 'users',\n    ],\n    'api' =&gt; [\n        'driver' =&gt; 'sanctum',  \/\/ API\u30c8\u30fc\u30af\u30f3\u8a8d\u8a3c\n        'provider' =&gt; 'users',\n    ],\n],<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li><strong>\u30e6\u30fc\u30b6\u30fc\u30d7\u30ed\u30d0\u30a4\u30c0\u30fc\u306e\u8a2d\u5b9a<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">'providers' =&gt; [\n    'users' =&gt; [\n        'driver' =&gt; 'eloquent',\n        'model' =&gt; App\\Models\\User::class,\n        \/\/ \u30ab\u30b9\u30bf\u30e0\u30e6\u30fc\u30b6\u30fc\u30c6\u30fc\u30d6\u30eb\u3092\u4f7f\u7528\u3059\u308b\u5834\u5408\n        \/\/ 'table' =&gt; 'custom_users',\n    ],\n],<\/pre>\n\n\n\n<ol start=\"3\" class=\"wp-block-list\">\n<li><strong>\u30d1\u30b9\u30ef\u30fc\u30c9\u30ea\u30bb\u30c3\u30c8\u8a2d\u5b9a<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">'passwords' =&gt; [\n    'users' =&gt; [\n        'provider' =&gt; 'users',\n        'table' =&gt; 'password_reset_tokens',\n        'expire' =&gt; 60,          \/\/ \u30c8\u30fc\u30af\u30f3\u306e\u6709\u52b9\u671f\u9650\uff08\u5206\uff09\n        'throttle' =&gt; 60,        \/\/ \u518d\u9001\u4fe1\u307e\u3067\u306e\u5f85\u6a5f\u6642\u9593\uff08\u79d2\uff09\n    ],\n],<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-6\">\u5b88\u308b\u3079\u304d3\u3064\u306e\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u8a2d\u5b9a<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>CSRF\u4fdd\u8b77\u306e\u78ba\u5b9f\u306a\u5b9f\u88c5<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">\/\/ app\/Http\/Kernel.php\nprotected $middlewareGroups = [\n    'web' =&gt; [\n        \\App\\Http\\Middleware\\VerifyCsrfToken::class,\n    ],\n];\n\n\/\/ Blade\u30c6\u30f3\u30d7\u30ec\u30fc\u30c8\u5185\n&lt;form method=\"POST\" action=\"\/login\"&gt;\n    @csrf\n    &lt;!-- \u30d5\u30a9\u30fc\u30e0\u8981\u7d20 --&gt;\n&lt;\/form&gt;<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li><strong>\u30bb\u30c3\u30b7\u30e7\u30f3\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u306e\u5f37\u5316<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">\/\/ config\/session.php\nreturn [\n    'secure' =&gt; env('SESSION_SECURE_COOKIE', true),  \/\/ HTTPS\u306e\u307f\n    'same_site' =&gt; 'lax',                           \/\/ CSRF\u5bfe\u7b56\n    'http_only' =&gt; true,                            \/\/ XSS\u5bfe\u7b56\n];<\/pre>\n\n\n\n<ol start=\"3\" class=\"wp-block-list\">\n<li><strong>\u30d1\u30b9\u30ef\u30fc\u30c9\u30cf\u30c3\u30b7\u30e5\u5316\u306e\u9069\u5207\u306a\u8a2d\u5b9a<\/strong><br>\u8a2d\u5b9a\u9805\u76ee \u63a8\u5968\u8a2d\u5b9a \u7406\u7531<br>\u30cf\u30c3\u30b7\u30e5\u30a2\u30eb\u30b4\u30ea\u30ba\u30e0 bcrypt \u5341\u5206\u306a\u5f37\u5ea6\u3068\u51e6\u7406\u901f\u5ea6\u306e\u30d0\u30e9\u30f3\u30b9<br>\u30d1\u30b9\u30ef\u30fc\u30c9\u6700\u5c0f\u9577 8\u6587\u5b57\u4ee5\u4e0a \u30d6\u30eb\u30fc\u30c8\u30d5\u30a9\u30fc\u30b9\u653b\u6483\u5bfe\u7b56<br>\u30d1\u30b9\u30ef\u30fc\u30c9\u8907\u96d1\u6027 \u6587\u5b57\u7a2e\u6df7\u5728\u5fc5\u9808 \u8f9e\u66f8\u653b\u6483\u5bfe\u7b56 <code>\/\/ app\/Http\/Controllers\/Auth\/RegisterController.php protected function validator(array $data) { return Validator::make($data, [ 'password' =&gt; [ 'required', 'string', 'min:8', \/\/ \u6700\u5c0f8\u6587\u5b57 'regex:\/[a-z]\/', \/\/ \u5c0f\u6587\u5b57\u5fc5\u9808 'regex:\/[A-Z]\/', \/\/ \u5927\u6587\u5b57\u5fc5\u9808 'regex:\/[0-9]\/', \/\/ \u6570\u5b57\u5fc5\u9808 'regex:\/[@$!%*#?&amp;]\/', \/\/ \u7279\u6b8a\u6587\u5b57\u5fc5\u9808 'confirmed', \/\/ \u78ba\u8a8d\u7528\u3068\u4e00\u81f4 ], ]); }<\/code> \u3053\u308c\u3089\u306e\u8a2d\u5b9a\u3092\u9069\u5207\u306b\u884c\u3046\u3053\u3068\u3067\u3001\u30bb\u30ad\u30e5\u30a2\u306a\u8a8d\u8a3c\u57fa\u76e4\u3092\u69cb\u7bc9\u3067\u304d\u307e\u3059\u3002\u6b21\u306e\u30bb\u30af\u30b7\u30e7\u30f3\u3067\u306f\u3001\u3053\u306e\u57fa\u76e4\u3092\u30d9\u30fc\u30b9\u306b\u3057\u305f\u5b9f\u8df5\u7684\u306a\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u65b9\u6cd5\u306b\u3064\u3044\u3066\u89e3\u8aac\u3057\u307e\u3059\u3002<\/li>\n<\/ol>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"i-7\">\u5b9f\u8df5\u7684\u306a\u8a8d\u8a3c\u6a5f\u80fd\u306e\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u65b9\u6cd5<\/h2>\n\n\n\n<p>Laravel\u306e\u8a8d\u8a3c\u6a5f\u80fd\u306f\u3001\u9ad8\u5ea6\u306a\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u304c\u53ef\u80fd\u3067\u3059\u3002\u5b9f\u969b\u306e\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3067\u5fc5\u8981\u3068\u306a\u308b\u5177\u4f53\u7684\u306a\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u65b9\u6cd5\u3092\u89e3\u8aac\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-8\">\u30ed\u30b0\u30a4\u30f3\u30d5\u30a9\u30fc\u30e0\u306e\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u5b9f\u88c5\u4f8b<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u30ab\u30b9\u30bf\u30e0\u30ed\u30b0\u30a4\u30f3\u30d5\u30a3\u30fc\u30eb\u30c9\u306e\u8ffd\u52a0<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">\/\/ app\/Http\/Controllers\/Auth\/LoginController.php\nclass LoginController extends Controller\n{\n    \/\/ \u30e6\u30fc\u30b6\u30fc\u540d\u3067\u3082\u30ed\u30b0\u30a4\u30f3\u53ef\u80fd\u306b\u3059\u308b\n    public function username()\n    {\n        $login = request()-&gt;input('login');\n        $field = filter_var($login, FILTER_VALIDATE_EMAIL) ? 'email' : 'username';\n        request()-&gt;merge([$field =&gt; $login]);\n        return $field;\n    }\n\n    \/\/ \u30ed\u30b0\u30a4\u30f3\u8a66\u884c\u6642\u306e\u8ffd\u52a0\u30d0\u30ea\u30c7\u30fc\u30b7\u30e7\u30f3\n    protected function validateLogin(Request $request)\n    {\n        $request-&gt;validate([\n            'login' =&gt; 'required|string',\n            'password' =&gt; 'required|string',\n            'company_code' =&gt; 'required|exists:companies,code', \/\/ \u4f1a\u793e\u30b3\u30fc\u30c9\u306e\u691c\u8a3c\n        ]);\n    }\n}<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li><strong>\u30ab\u30b9\u30bf\u30e0\u30ed\u30b0\u30a4\u30f3\u30d3\u30e5\u30fc\u306e\u4f5c\u6210<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">\/\/ resources\/views\/auth\/login.blade.php\n&lt;form method=\"POST\" action=\"{{ route('login') }}\"&gt;\n    @csrf\n    &lt;div class=\"form-group\"&gt;\n        &lt;label&gt;\u30e1\u30fc\u30eb\u30a2\u30c9\u30ec\u30b9\u307e\u305f\u306f\u30e6\u30fc\u30b6\u30fc\u540d&lt;\/label&gt;\n        &lt;input type=\"text\" name=\"login\" class=\"form-control\" required&gt;\n    &lt;\/div&gt;\n    &lt;div class=\"form-group\"&gt;\n        &lt;label&gt;\u4f1a\u793e\u30b3\u30fc\u30c9&lt;\/label&gt;\n        &lt;input type=\"text\" name=\"company_code\" class=\"form-control\" required&gt;\n    &lt;\/div&gt;\n    &lt;div class=\"form-group\"&gt;\n        &lt;label&gt;\u30d1\u30b9\u30ef\u30fc\u30c9&lt;\/label&gt;\n        &lt;input type=\"password\" name=\"password\" class=\"form-control\" required&gt;\n    &lt;\/div&gt;\n    &lt;!-- reCAPTCHA\u7b49\u306e\u8ffd\u52a0\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u8981\u7d20 --&gt;\n    {!! NoCaptcha::display() !!}\n    &lt;button type=\"submit\"&gt;\u30ed\u30b0\u30a4\u30f3&lt;\/button&gt;\n&lt;\/form&gt;<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-9\">\u72ec\u81ea\u306e\u30ac\u30fc\u30c9\u8a2d\u5b9a\u306b\u3088\u308b\u591a\u91cd\u8a8d\u8a3c\u306e\u5b9f\u73fe<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u30ab\u30b9\u30bf\u30e0\u30ac\u30fc\u30c9\u306e\u5b9a\u7fa9<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">\/\/ config\/auth.php\n'guards' =&gt; [\n    'web' =&gt; [\n        'driver' =&gt; 'session',\n        'provider' =&gt; 'users',\n    ],\n    'admin' =&gt; [\n        'driver' =&gt; 'session',\n        'provider' =&gt; 'admins',\n    ],\n    'company' =&gt; [\n        'driver' =&gt; 'session',\n        'provider' =&gt; 'companies',\n    ],\n],\n\n'providers' =&gt; [\n    'users' =&gt; [\n        'driver' =&gt; 'eloquent',\n        'model' =&gt; App\\Models\\User::class,\n    ],\n    'admins' =&gt; [\n        'driver' =&gt; 'eloquent',\n        'model' =&gt; App\\Models\\Admin::class,\n    ],\n    'companies' =&gt; [\n        'driver' =&gt; 'eloquent',\n        'model' =&gt; App\\Models\\Company::class,\n    ],\n],<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li><strong>\u30de\u30eb\u30c1\u8a8d\u8a3c\u306e\u5b9f\u88c5<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">\/\/ app\/Http\/Middleware\/RedirectIfAuthenticated.php\npublic function handle($request, Closure $next, ...$guards)\n{\n    $guards = empty($guards) ? [null] : $guards;\n\n    foreach ($guards as $guard) {\n        if (Auth::guard($guard)-&gt;check()) {\n            switch ($guard) {\n                case 'admin':\n                    return redirect()-&gt;route('admin.dashboard');\n                case 'company':\n                    return redirect()-&gt;route('company.dashboard');\n                default:\n                    return redirect()-&gt;route('home');\n            }\n        }\n    }\n    return $next($request);\n}<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-10\">\u30df\u30c9\u30eb\u30a6\u30a7\u30a2\u3092\u6d3b\u7528\u3057\u305f\u67d4\u8edf\u306a\u8a8d\u53ef\u5236\u5fa1<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u30ab\u30b9\u30bf\u30e0\u8a8d\u53ef\u30df\u30c9\u30eb\u30a6\u30a7\u30a2\u306e\u4f5c\u6210<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">\/\/ app\/Http\/Middleware\/CheckRole.php\nclass CheckRole\n{\n    public function handle($request, Closure $next, ...$roles)\n    {\n        if (!Auth::check())\n            return redirect('login');\n\n        $user = Auth::user();\n\n        foreach($roles as $role) {\n            if($user-&gt;hasRole($role))\n                return $next($request);\n        }\n\n        abort(403, '\u6a29\u9650\u304c\u3042\u308a\u307e\u305b\u3093');\n    }\n}\n\n\/\/ app\/Models\/User.php\nclass User extends Authenticatable\n{\n    public function roles()\n    {\n        return $this-&gt;belongsToMany(Role::class);\n    }\n\n    public function hasRole($role)\n    {\n        return $this-&gt;roles-&gt;contains('name', $role);\n    }\n}<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li><strong>\u9ad8\u5ea6\u306a\u8a8d\u53ef\u30dd\u30ea\u30b7\u30fc\u306e\u5b9f\u88c5<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">\/\/ app\/Policies\/DocumentPolicy.php\nclass DocumentPolicy\n{\n    public function view(User $user, Document $document)\n    {\n        \/\/ \u90e8\u7f72\u30c1\u30a7\u30c3\u30af\n        if ($user-&gt;department_id !== $document-&gt;department_id) {\n            return false;\n        }\n\n        \/\/ \u6a5f\u5bc6\u30ec\u30d9\u30eb\u30c1\u30a7\u30c3\u30af\n        if ($document-&gt;confidentiality_level &gt; $user-&gt;clearance_level) {\n            return false;\n        }\n\n        \/\/ \u6709\u52b9\u671f\u9650\u30c1\u30a7\u30c3\u30af\n        if ($document-&gt;expires_at &amp;&amp; $document-&gt;expires_at &lt; now()) {\n            return false;\n        }\n\n        return true;\n    }\n}<\/pre>\n\n\n\n<ol start=\"3\" class=\"wp-block-list\">\n<li><strong>\u5b9f\u88c5\u30d1\u30bf\u30fc\u30f3\u5225\u306e\u8a8d\u53ef\u5236\u5fa1\u65b9\u6cd5<\/strong><br>\u30e6\u30fc\u30b9\u30b1\u30fc\u30b9 \u5b9f\u88c5\u65b9\u6cd5 \u4f7f\u7528\u30bf\u30a4\u30df\u30f3\u30b0<br>\u30b7\u30f3\u30d7\u30eb\u306a\u6a29\u9650\u30c1\u30a7\u30c3\u30af \u30df\u30c9\u30eb\u30a6\u30a7\u30a2 \u30eb\u30fc\u30c8\u30ec\u30d9\u30eb\u3067\u306e\u5236\u5fa1<br>\u8907\u96d1\u306a\u6761\u4ef6\u5224\u5b9a \u30dd\u30ea\u30b7\u30fc \u30e2\u30c7\u30eb\u30d9\u30fc\u30b9\u306e\u5236\u5fa1<br>\u52d5\u7684\u306a\u6a29\u9650\u5236\u5fa1 \u30b2\u30fc\u30c8 \u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u5168\u4f53\u3067\u5171\u901a\u306e\u5236\u5fa1 \u3053\u308c\u3089\u306e\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u306b\u3088\u308a\u3001\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306e\u8981\u4ef6\u306b\u5408\u308f\u305b\u305f\u67d4\u8edf\u306a\u8a8d\u8a3c\u30fb\u8a8d\u53ef\u30b7\u30b9\u30c6\u30e0\u3092\u69cb\u7bc9\u3067\u304d\u307e\u3059\u3002\u6b21\u306e\u30bb\u30af\u30b7\u30e7\u30f3\u3067\u306f\u3001\u3055\u3089\u306b\u9ad8\u5ea6\u306a\u5fdc\u7528\u30c6\u30af\u30cb\u30c3\u30af\u306b\u3064\u3044\u3066\u89e3\u8aac\u3057\u307e\u3059\u3002<\/li>\n<\/ol>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"i-11\">\u73fe\u5834\u3067\u4f7f\u3048\u308b\u8a8d\u8a3c\u6a5f\u80fd\u306e\u5fdc\u7528\u30c6\u30af\u30cb\u30c3\u30af<\/h2>\n\n\n\n<p>\u5b9f\u8df5\u7684\u306a\u73fe\u5834\u3067\u5fc5\u8981\u3068\u3055\u308c\u308b\u9ad8\u5ea6\u306a\u8a8d\u8a3c\u6a5f\u80fd\u306e\u5b9f\u88c5\u65b9\u6cd5\u306b\u3064\u3044\u3066\u89e3\u8aac\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-12\">\u30bd\u30fc\u30b7\u30e3\u30eb\u30ed\u30b0\u30a4\u30f3\u3092\u5c0e\u5165\u3059\u308b\u5b9f\u88c5\u624b\u9806<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>Socialite\u30d1\u30c3\u30b1\u30fc\u30b8\u306e\u5c0e\u5165<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">composer require laravel\/socialite<\/pre>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">\/\/ config\/services.php\nreturn [\n    'github' =&gt; [\n        'client_id' =&gt; env('GITHUB_CLIENT_ID'),\n        'client_secret' =&gt; env('GITHUB_CLIENT_SECRET'),\n        'redirect' =&gt; env('GITHUB_CALLBACK_URL'),\n    ],\n    'google' =&gt; [\n        'client_id' =&gt; env('GOOGLE_CLIENT_ID'),\n        'client_secret' =&gt; env('GOOGLE_CLIENT_SECRET'),\n        'redirect' =&gt; env('GOOGLE_CALLBACK_URL'),\n    ],\n];<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li><strong>\u30bd\u30fc\u30b7\u30e3\u30eb\u30ed\u30b0\u30a4\u30f3\u51e6\u7406\u306e\u5b9f\u88c5<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">\/\/ app\/Http\/Controllers\/Auth\/SocialiteController.php\nclass SocialiteController extends Controller\n{\n    public function redirectToProvider($provider)\n    {\n        return Socialite::driver($provider)-&gt;redirect();\n    }\n\n    public function handleProviderCallback($provider)\n    {\n        try {\n            $social_user = Socialite::driver($provider)-&gt;user();\n\n            \/\/ \u30e6\u30fc\u30b6\u30fc\u60c5\u5831\u306e\u53d6\u5f97\u307e\u305f\u306f\u65b0\u898f\u4f5c\u6210\n            $user = User::firstOrCreate(\n                ['email' =&gt; $social_user-&gt;getEmail()],\n                [\n                    'name' =&gt; $social_user-&gt;getName(),\n                    'password' =&gt; Hash::make(Str::random(24)),\n                    'provider' =&gt; $provider,\n                    'provider_id' =&gt; $social_user-&gt;getId(),\n                ]\n            );\n\n            \/\/ \u30bd\u30fc\u30b7\u30e3\u30eb\u30a2\u30ab\u30a6\u30f3\u30c8\u60c5\u5831\u306e\u4fdd\u5b58\n            $user-&gt;socialAccounts()-&gt;updateOrCreate(\n                [\n                    'provider' =&gt; $provider,\n                    'provider_id' =&gt; $social_user-&gt;getId()\n                ],\n                [\n                    'avatar' =&gt; $social_user-&gt;getAvatar(),\n                    'token' =&gt; $social_user-&gt;token,\n                ]\n            );\n\n            Auth::login($user);\n            return redirect()-&gt;intended('dashboard');\n\n        } catch (\\Exception $e) {\n            return redirect('login')-&gt;with('error', '\u30bd\u30fc\u30b7\u30e3\u30eb\u30ed\u30b0\u30a4\u30f3\u306b\u5931\u6557\u3057\u307e\u3057\u305f');\n        }\n    }\n}<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-13\">2\u6bb5\u968e\u8a8d\u8a3c\u3067\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u3092\u5f37\u5316\u3059\u308b\u65b9\u6cd5<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>2\u6bb5\u968e\u8a8d\u8a3c\u306e\u57fa\u672c\u8a2d\u5b9a<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">\/\/ config\/auth.php\n'second_factor' =&gt; [\n    'enabled' =&gt; true,\n    'lifetime' =&gt; 300, \/\/ \u78ba\u8a8d\u30b3\u30fc\u30c9\u306e\u6709\u52b9\u671f\u9650\uff08\u79d2\uff09\n    'attempts' =&gt; 3,   \/\/ \u6700\u5927\u8a66\u884c\u56de\u6570\n],<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li><strong>2FA\u306e\u5b9f\u88c5<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">\/\/ app\/Http\/Controllers\/Auth\/TwoFactorController.php\nclass TwoFactorController extends Controller\n{\n    public function store(Request $request)\n    {\n        $user = $request-&gt;user();\n\n        \/\/ Google Authenticator\u306e\u30b7\u30fc\u30af\u30ec\u30c3\u30c8\u30ad\u30fc\u751f\u6210\n        $google2fa = app('pragmarx.google2fa');\n        $secret = $google2fa-&gt;generateSecretKey();\n\n        \/\/ QR\u30b3\u30fc\u30c9\u751f\u6210\u7528\u306e\u60c5\u5831\n        $qrCode = $google2fa-&gt;getQRCodeUrl(\n            config('app.name'),\n            $user-&gt;email,\n            $secret\n        );\n\n        \/\/ \u30b7\u30fc\u30af\u30ec\u30c3\u30c8\u30ad\u30fc\u306e\u4fdd\u5b58\n        $user-&gt;two_factor_secret = $secret;\n        $user-&gt;save();\n\n        return view('auth.2fa.enable', compact('qrCode', 'secret'));\n    }\n\n    public function verify(Request $request)\n    {\n        $request-&gt;validate(['code' =&gt; 'required|numeric|digits:6']);\n\n        $google2fa = app('pragmarx.google2fa');\n        $valid = $google2fa-&gt;verifyKey(\n            $request-&gt;user()-&gt;two_factor_secret,\n            $request-&gt;code\n        );\n\n        if ($valid) {\n            $request-&gt;user()-&gt;two_factor_enabled = true;\n            $request-&gt;user()-&gt;save();\n            return redirect()-&gt;route('dashboard');\n        }\n\n        return back()-&gt;withErrors(['code' =&gt; '\u7121\u52b9\u306a\u8a8d\u8a3c\u30b3\u30fc\u30c9\u3067\u3059\u3002']);\n    }\n}<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-14\">API\u30c8\u30fc\u30af\u30f3\u8a8d\u8a3c\u306e\u5b9f\u88c5\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>Sanctum\u306e\u8a2d\u5b9a<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">\/\/ config\/sanctum.php\nreturn [\n    'stateful' =&gt; explode(',', env('SANCTUM_STATEFUL_DOMAINS', sprintf(\n        '%s%s',\n        'localhost,localhost:3000,127.0.0.1,127.0.0.1:8000,::1',\n        env('APP_URL') ? ','.parse_url(env('APP_URL'), PHP_URL_HOST) : ''\n    ))),\n    'expiration' =&gt; null,\n    'middleware' =&gt; [\n        'verify_csrf_token' =&gt; App\\Http\\Middleware\\VerifyCsrfToken::class,\n        'encrypt_cookies' =&gt; App\\Http\\Middleware\\EncryptCookies::class,\n    ],\n];<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li><strong>\u30c8\u30fc\u30af\u30f3\u7ba1\u7406\u306e\u5b9f\u88c5<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">\/\/ app\/Http\/Controllers\/Api\/TokenController.php\nclass TokenController extends Controller\n{\n    public function createToken(Request $request)\n    {\n        $request-&gt;validate([\n            'token_name' =&gt; 'required|string|max:255',\n            'abilities' =&gt; 'array',\n        ]);\n\n        \/\/ \u30c8\u30fc\u30af\u30f3\u306e\u4f5c\u6210\u3068\u6a29\u9650\u306e\u4ed8\u4e0e\n        $token = $request-&gt;user()-&gt;createToken(\n            $request-&gt;token_name,\n            $request-&gt;abilities ?? ['*']\n        );\n\n        return response()-&gt;json([\n            'token' =&gt; $token-&gt;plainTextToken,\n            'expires_at' =&gt; now()-&gt;addDays(30),\n        ]);\n    }\n\n    public function revokeToken(Request $request)\n    {\n        \/\/ \u7279\u5b9a\u306e\u30c8\u30fc\u30af\u30f3\u306e\u5931\u52b9\n        if ($request-&gt;token_id) {\n            $request-&gt;user()-&gt;tokens()\n                -&gt;where('id', $request-&gt;token_id)\n                -&gt;delete();\n        }\n\n        \/\/ \u5168\u30c8\u30fc\u30af\u30f3\u306e\u5931\u52b9\n        if ($request-&gt;all_devices) {\n            $request-&gt;user()-&gt;tokens()-&gt;delete();\n        }\n\n        return response()-&gt;json(['message' =&gt; '\u30c8\u30fc\u30af\u30f3\u3092\u5931\u52b9\u5316\u3057\u307e\u3057\u305f']);\n    }\n}<\/pre>\n\n\n\n<ol start=\"3\" class=\"wp-block-list\">\n<li><strong>API\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u306e\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9<\/strong><br>\u5bfe\u7b56 \u5b9f\u88c5\u65b9\u6cd5 \u52b9\u679c<br>\u30ec\u30fc\u30c8\u5236\u9650 ThrottleRequests\u30df\u30c9\u30eb\u30a6\u30a7\u30a2 DoS\u653b\u6483\u306e\u9632\u6b62<br>\u30b9\u30b3\u30fc\u30d7\u5236\u9650 \u30c8\u30fc\u30af\u30f3\u306eability\u8a2d\u5b9a \u6700\u5c0f\u6a29\u9650\u306e\u539f\u5247\u306e\u5b9f\u73fe<br>\u30c8\u30fc\u30af\u30f3\u6709\u52b9\u671f\u9650 \u671f\u9650\u4ed8\u304d\u30c8\u30fc\u30af\u30f3\u306e\u767a\u884c \u9577\u671f\u7684\u306a\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u30ea\u30b9\u30af\u306e\u4f4e\u6e1b <code>\/\/ routes\/api.php Route::middleware(['auth:sanctum', 'throttle:api']) -&gt;group(function () { Route::get('\/user', function (Request $request) { return $request-&gt;user(); })-&gt;middleware(['ability:user:read']); });<\/code> \u3053\u308c\u3089\u306e\u5fdc\u7528\u30c6\u30af\u30cb\u30c3\u30af\u3092\u6d3b\u7528\u3059\u308b\u3053\u3068\u3067\u3001\u30bb\u30ad\u30e5\u30a2\u3067\u67d4\u8edf\u306a\u8a8d\u8a3c\u30b7\u30b9\u30c6\u30e0\u3092\u69cb\u7bc9\u3067\u304d\u307e\u3059\u3002\u6b21\u306e\u30bb\u30af\u30b7\u30e7\u30f3\u3067\u306f\u3001\u5b9f\u904b\u7528\u3067\u767a\u751f\u3059\u308b\u53ef\u80fd\u6027\u306e\u3042\u308b\u30c8\u30e9\u30d6\u30eb\u3078\u306e\u5bfe\u51e6\u65b9\u6cd5\u306b\u3064\u3044\u3066\u89e3\u8aac\u3057\u307e\u3059\u3002<\/li>\n<\/ol>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"i-15\">Auth\u6a5f\u80fd\u306e\u30c8\u30e9\u30d6\u30eb\u30b7\u30e5\u30fc\u30c6\u30a3\u30f3\u30b0<\/h2>\n\n\n\n<p>\u8a8d\u8a3c\u6a5f\u80fd\u3067\u767a\u751f\u3059\u308b\u4e3b\u8981\u306a\u554f\u984c\u3068\u305d\u306e\u89e3\u6c7a\u65b9\u6cd5\u306b\u3064\u3044\u3066\u3001\u5b9f\u8df5\u7684\u306a\u5bfe\u51e6\u6cd5\u3092\u89e3\u8aac\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-16\">\u30ed\u30b0\u30a4\u30f3\u51e6\u7406\u3067\u767a\u751f\u3059\u308b\u4e3b\u8981\u306a\u30a8\u30e9\u30fc\u3068\u5bfe\u51e6\u6cd5<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u8a8d\u8a3c\u30a8\u30e9\u30fc\u306e\u7a2e\u985e\u3068\u5bfe\u7b56<\/strong><\/li>\n<\/ol>\n\n\n<div id=\"id-909598ca-a389-4e53-85d6-b045afe42042\">\n<figure class=\"wp-block-table\"><table class=\"has-fixed-layout\"><thead><tr><th>\u30a8\u30e9\u30fc\u5185\u5bb9<\/th><th>\u8003\u3048\u3089\u308c\u308b\u539f\u56e0<\/th><th>\u5bfe\u51e6\u6cd5<\/th><th>\u30c7\u30d0\u30c3\u30b0\u65b9\u6cd5<\/th><\/tr><\/thead><tbody><tr><td>\u30ed\u30b0\u30a4\u30f3\u3067\u304d\u306a\u3044<\/td><td>\u30d1\u30b9\u30ef\u30fc\u30c9\u30cf\u30c3\u30b7\u30e5\u306e\u4e0d\u4e00\u81f4<\/td><td>\u30cf\u30c3\u30b7\u30e5\u30a2\u30eb\u30b4\u30ea\u30ba\u30e0\u306e\u78ba\u8a8d<\/td><td><code>Auth::attempt()<\/code>\u306e\u623b\u308a\u5024\u78ba\u8a8d<\/td><\/tr><tr><td>\u30bb\u30c3\u30b7\u30e7\u30f3\u304c\u7dad\u6301\u3055\u308c\u306a\u3044<\/td><td>\u30bb\u30c3\u30b7\u30e7\u30f3\u8a2d\u5b9a\u306e\u554f\u984c<\/td><td>\u30bb\u30c3\u30b7\u30e7\u30f3\u8a2d\u5b9a\u306e\u898b\u76f4\u3057<\/td><td>\u30bb\u30c3\u30b7\u30e7\u30f3\u30c7\u30fc\u30bf\u306e\u78ba\u8a8d<\/td><\/tr><tr><td>CSRF Token Mismatch<\/td><td>\u30c8\u30fc\u30af\u30f3\u306e\u4e0d\u4e00\u81f4\u30fb\u671f\u9650\u5207\u308c<\/td><td>CSRF\u30c8\u30fc\u30af\u30f3\u306e\u518d\u751f\u6210<\/td><td>\u30df\u30c9\u30eb\u30a6\u30a7\u30a2\u306e\u78ba\u8a8d<\/td><\/tr><\/tbody><\/table><\/figure>\n<\/div>\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li><strong>\u30c7\u30d0\u30c3\u30b0\u30b3\u30fc\u30c9\u4f8b<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">\/\/ \u30ed\u30b0\u30a4\u30f3\u51e6\u7406\u306e\u30c7\u30d0\u30c3\u30b0\ntry {\n    $credentials = $request-&gt;only('email', 'password');\n\n    \/\/ \u8a8d\u8a3c\u8a66\u884c\u306e\u30ed\u30b0\n    \\Log::info('Login attempt', [\n        'email' =&gt; $credentials['email'],\n        'ip' =&gt; $request-&gt;ip(),\n        'user_agent' =&gt; $request-&gt;userAgent()\n    ]);\n\n    if (Auth::attempt($credentials)) {\n        \/\/ \u8a8d\u8a3c\u6210\u529f\u6642\u306e\u8a73\u7d30\u30ed\u30b0\n        \\Log::info('Login successful', [\n            'user_id' =&gt; Auth::id(),\n            'session_id' =&gt; session()-&gt;getId()\n        ]);\n    } else {\n        \/\/ \u8a8d\u8a3c\u5931\u6557\u6642\u306e\u539f\u56e0\u7279\u5b9a\n        $user = User::where('email', $credentials['email'])-&gt;first();\n        if (!$user) {\n            \\Log::warning('User not found');\n        } else {\n            \\Log::warning('Invalid password');\n        }\n    }\n} catch (\\Exception $e) {\n    \\Log::error('Login error', [\n        'message' =&gt; $e-&gt;getMessage(),\n        'trace' =&gt; $e-&gt;getTraceAsString()\n    ]);\n}<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-17\">\u30bb\u30c3\u30b7\u30e7\u30f3\u95a2\u9023\u306e\u4e0d\u5177\u5408\u89e3\u6c7a\u30c6\u30af\u30cb\u30c3\u30af<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u30bb\u30c3\u30b7\u30e7\u30f3\u8a2d\u5b9a\u306e\u6700\u9069\u5316<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">\/\/ config\/session.php\nreturn [\n    'driver' =&gt; env('SESSION_DRIVER', 'file'),\n    'lifetime' =&gt; env('SESSION_LIFETIME', 120),\n    'expire_on_close' =&gt; false,\n    'encrypt' =&gt; true,\n    'secure' =&gt; env('SESSION_SECURE_COOKIE', true),\n    'same_site' =&gt; 'lax',\n];<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li><strong>\u30bb\u30c3\u30b7\u30e7\u30f3\u30c7\u30d0\u30c3\u30b0\u7528\u30df\u30c9\u30eb\u30a6\u30a7\u30a2<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">\/\/ app\/Http\/Middleware\/SessionDebugger.php\nclass SessionDebugger\n{\n    public function handle($request, Closure $next)\n    {\n        \/\/ \u30ea\u30af\u30a8\u30b9\u30c8\u524d\u306e\u30bb\u30c3\u30b7\u30e7\u30f3\u72b6\u614b\n        \\Log::debug('Session before', [\n            'id' =&gt; session()-&gt;getId(),\n            'data' =&gt; session()-&gt;all()\n        ]);\n\n        $response = $next($request);\n\n        \/\/ \u30ea\u30af\u30a8\u30b9\u30c8\u5f8c\u306e\u30bb\u30c3\u30b7\u30e7\u30f3\u72b6\u614b\n        \\Log::debug('Session after', [\n            'id' =&gt; session()-&gt;getId(),\n            'data' =&gt; session()-&gt;all()\n        ]);\n\n        return $response;\n    }\n}<\/pre>\n\n\n\n<ol start=\"3\" class=\"wp-block-list\">\n<li><strong>\u4e00\u822c\u7684\u306a\u30bb\u30c3\u30b7\u30e7\u30f3\u554f\u984c\u306e\u89e3\u6c7a\u65b9\u6cd5<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">\/\/ \u30bb\u30c3\u30b7\u30e7\u30f3\u30b9\u30c8\u30ec\u30fc\u30b8\u306e\u30af\u30ea\u30fc\u30f3\u30a2\u30c3\u30d7\nphp artisan session:gc\n\n\/\/ \u30bb\u30c3\u30b7\u30e7\u30f3\u30c9\u30e9\u30a4\u30d0\u30fc\u306e\u52d5\u4f5c\u78ba\u8a8d\nif (Cache::store('file')-&gt;put('test_key', 'test_value', 5)) {\n    echo \"\u30bb\u30c3\u30b7\u30e7\u30f3\u30b9\u30c8\u30ec\u30fc\u30b8\u306f\u6b63\u5e38\u306b\u52d5\u4f5c\u3057\u3066\u3044\u307e\u3059\";\n}\n\n\/\/ \u30bb\u30c3\u30b7\u30e7\u30f3\u30cf\u30f3\u30c9\u30e9\u30fc\u306e\u78ba\u8a8d\n$handler = session()-&gt;getHandler();\nif ($handler-&gt;write(session()-&gt;getId(), serialize(['test' =&gt; 'data']))) {\n    echo \"\u30bb\u30c3\u30b7\u30e7\u30f3\u306e\u66f8\u304d\u8fbc\u307f\u304c\u6b63\u5e38\u306b\u52d5\u4f5c\u3057\u3066\u3044\u307e\u3059\";\n}<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-18\">\u672c\u756a\u74b0\u5883\u3067\u306e\u8a8d\u8a3c\u30c8\u30e9\u30d6\u30eb\u5bfe\u5fdc\u4f8b<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u672c\u756a\u74b0\u5883\u7279\u6709\u306e\u554f\u984c\u3068\u5bfe\u7b56<\/strong><\/li>\n<\/ol>\n\n\n<div id=\"id-fd19719b-3b2f-4ed6-9030-74357d77a673\">\n<figure class=\"wp-block-table\"><table class=\"has-fixed-layout\"><thead><tr><th>\u554f\u984c<\/th><th>\u539f\u56e0<\/th><th>\u89e3\u6c7a\u7b56<\/th><th>\u4e88\u9632\u7b56<\/th><\/tr><\/thead><tbody><tr><td>\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u4f4e\u4e0b<\/td><td>\u30bb\u30c3\u30b7\u30e7\u30f3\u6570\u306e\u5897\u5927<\/td><td>\u5b9a\u671f\u7684\u306a\u30af\u30ea\u30fc\u30f3\u30a2\u30c3\u30d7<\/td><td>\u30bb\u30c3\u30b7\u30e7\u30f3\u6709\u52b9\u671f\u9650\u306e\u9069\u6b63\u5316<\/td><\/tr><tr><td>\u7a81\u7136\u306e\u30ed\u30b0\u30a2\u30a6\u30c8<\/td><td>\u30b5\u30fc\u30d0\u30fc\u8a2d\u5b9a\u306e\u4e0d\u6574\u5408<\/td><td>\u30bb\u30c3\u30b7\u30e7\u30f3\u4fdd\u5b58\u5148\u306e\u898b\u76f4\u3057<\/td><td>\u5197\u9577\u5316\u69cb\u6210\u306e\u5c0e\u5165<\/td><\/tr><tr><td>\u30e1\u30e2\u30ea\u4f7f\u7528\u91cf\u5897\u52a0<\/td><td>\u30bb\u30c3\u30b7\u30e7\u30f3\u30c7\u30fc\u30bf\u306e\u80a5\u5927\u5316<\/td><td>\u30c7\u30fc\u30bf\u69cb\u9020\u306e\u6700\u9069\u5316<\/td><td>\u30e2\u30cb\u30bf\u30ea\u30f3\u30b0\u306e\u5f37\u5316<\/td><\/tr><\/tbody><\/table><\/figure>\n<\/div>\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li><strong>\u76e3\u8996\u30fb\u30c7\u30d0\u30c3\u30b0\u7528\u30b3\u30fc\u30c9<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">\/\/ app\/Providers\/AppServiceProvider.php\npublic function boot()\n{\n    \/\/ \u8a8d\u8a3c\u30a4\u30d9\u30f3\u30c8\u306e\u76e3\u8996\n    Event::listen('auth.login', function ($user, $remember) {\n        \\Log::channel('auth')-&gt;info('User logged in', [\n            'user_id' =&gt; $user-&gt;id,\n            'remember' =&gt; $remember,\n            'ip' =&gt; request()-&gt;ip(),\n            'server' =&gt; gethostname()\n        ]);\n    });\n\n    Event::listen('auth.logout', function ($user) {\n        \\Log::channel('auth')-&gt;info('User logged out', [\n            'user_id' =&gt; $user-&gt;id,\n            'session_id' =&gt; session()-&gt;getId()\n        ]);\n    });\n}<\/pre>\n\n\n\n<ol start=\"3\" class=\"wp-block-list\">\n<li><strong>\u30c8\u30e9\u30d6\u30eb\u30b7\u30e5\u30fc\u30c6\u30a3\u30f3\u30b0\u30c1\u30a7\u30c3\u30af\u30ea\u30b9\u30c8<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\"># \u30b7\u30b9\u30c6\u30e0\u30c1\u30a7\u30c3\u30af\nphp artisan cache:clear\nphp artisan config:clear\nphp artisan route:clear\nphp artisan view:clear\n\n# \u30d1\u30fc\u30df\u30c3\u30b7\u30e7\u30f3\u78ba\u8a8d\nchmod -R 755 storage\/\nchmod -R 755 bootstrap\/cache\/\n\n# \u30bb\u30c3\u30b7\u30e7\u30f3\u30b9\u30c8\u30ec\u30fc\u30b8\u78ba\u8a8d\nls -la storage\/framework\/sessions\/\n\n# \u30ed\u30b0\u30d5\u30a1\u30a4\u30eb\u78ba\u8a8d\ntail -f storage\/logs\/laravel.log<\/pre>\n\n\n\n<p>\u3053\u308c\u3089\u306e\u30c8\u30e9\u30d6\u30eb\u30b7\u30e5\u30fc\u30c6\u30a3\u30f3\u30b0\u624b\u6cd5\u3092\u7406\u89e3\u3057\u3066\u304a\u304f\u3053\u3068\u3067\u3001\u672c\u756a\u74b0\u5883\u3067\u767a\u751f\u3059\u308b\u8a8d\u8a3c\u95a2\u9023\u306e\u554f\u984c\u306b\u8fc5\u901f\u306b\u5bfe\u5fdc\u3067\u304d\u307e\u3059\u3002\u6b21\u306e\u30bb\u30af\u30b7\u30e7\u30f3\u3067\u306f\u3001\u8a8d\u8a3c\u6a5f\u80fd\u306e\u7d99\u7d9a\u7684\u306a\u904b\u7528\u3068\u30e1\u30f3\u30c6\u30ca\u30f3\u30b9\u306b\u3064\u3044\u3066\u89e3\u8aac\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"i-19\">Laravel\u8a8d\u8a3c\u6a5f\u80fd\u306e\u904b\u7528\u3068\u30e1\u30f3\u30c6\u30ca\u30f3\u30b9<\/h2>\n\n\n\n<p>\u8a8d\u8a3c\u30b7\u30b9\u30c6\u30e0\u3092\u5b89\u5168\u304b\u3064\u52b9\u7387\u7684\u306b\u904b\u7528\u3057\u7d9a\u3051\u308b\u305f\u3081\u306e\u5177\u4f53\u7684\u306a\u65b9\u91dd\u3068\u5b9f\u8df5\u7684\u306a\u624b\u6cd5\u3092\u89e3\u8aac\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-20\">\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u30a2\u30c3\u30d7\u30c7\u30fc\u30c8\u306e\u9069\u7528\u65b9\u91dd<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u30a2\u30c3\u30d7\u30c7\u30fc\u30c8\u306e\u7ba1\u7406\u30d5\u30ed\u30fc<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">\/\/ composer.json\u3067\u306e\u30d0\u30fc\u30b8\u30e7\u30f3\u7ba1\u7406\n{\n    \"require\": {\n        \"php\": \"^8.1\",\n        \"laravel\/framework\": \"^10.0\",\n        \"laravel\/sanctum\": \"^3.2\",\n        \"laravel\/socialite\": \"^5.6\"\n    },\n    \"scripts\": {\n        \"post-update-cmd\": [\n            \"php artisan config:clear\",\n            \"php artisan cache:clear\",\n            \"php artisan route:clear\",\n            \"php artisan view:clear\"\n        ],\n        \"security-check\": [\n            \"composer audit\"\n        ]\n    }\n}<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li><strong>\u5b9a\u671f\u7684\u306a\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u30c1\u30a7\u30c3\u30af\u306e\u81ea\u52d5\u5316<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">#!\/bin\/bash\n# security-check.sh\n\n# Composer\u306e\u4f9d\u5b58\u30d1\u30c3\u30b1\u30fc\u30b8\u306e\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u30c1\u30a7\u30c3\u30af\ncomposer audit\n\n# Laravel\u7cfb\u30d1\u30c3\u30b1\u30fc\u30b8\u306e\u66f4\u65b0\u78ba\u8a8d\ncomposer outdated \"laravel\/*\" --direct\n\n# \u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u30ed\u30b0\u306e\u78ba\u8a8d\ngrep -i \"security\\|warning\\|error\" storage\/logs\/laravel.log\n\n# \u5b9f\u884c\u6a29\u9650\u306e\u78ba\u8a8d\nfind storage -type d -exec chmod 755 {} \\;\nfind storage -type f -exec chmod 644 {} \\;<\/pre>\n\n\n\n<ol start=\"3\" class=\"wp-block-list\">\n<li><strong>\u30a2\u30c3\u30d7\u30c7\u30fc\u30c8\u9069\u7528\u624b\u9806<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\"># 1. \u30d0\u30c3\u30af\u30a2\u30c3\u30d7\u306e\u4f5c\u6210\nphp artisan backup:run\n\n# 2. \u30e1\u30f3\u30c6\u30ca\u30f3\u30b9\u30e2\u30fc\u30c9\u306e\u6709\u52b9\u5316\nphp artisan down --refresh=60\n\n# 3. \u4f9d\u5b58\u30d1\u30c3\u30b1\u30fc\u30b8\u306e\u66f4\u65b0\ncomposer update --with-dependencies\n\n# 4. \u30de\u30a4\u30b0\u30ec\u30fc\u30b7\u30e7\u30f3\u306e\u5b9f\u884c\nphp artisan migrate --force\n\n# 5. \u30ad\u30e3\u30c3\u30b7\u30e5\u306e\u30af\u30ea\u30a2\nphp artisan optimize:clear\n\n# 6. \u30e1\u30f3\u30c6\u30ca\u30f3\u30b9\u30e2\u30fc\u30c9\u306e\u89e3\u9664\nphp artisan up<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-21\">\u30ed\u30b0\u76e3\u8996\u3068\u4e0d\u6b63\u30a2\u30af\u30bb\u30b9\u5bfe\u7b56\u306e\u5b9f\u88c5<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u9ad8\u5ea6\u306a\u30ed\u30b0\u76e3\u8996\u30b7\u30b9\u30c6\u30e0\u306e\u5b9f\u88c5<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">\/\/ app\/Providers\/EventServiceProvider.php\nclass EventServiceProvider extends ServiceProvider\n{\n    public function boot()\n    {\n        \/\/ \u8a8d\u8a3c\u8a66\u884c\u306e\u76e3\u8996\n        Event::listen(Login::class, function ($event) {\n            $this-&gt;logAuthenticationAttempt($event);\n        });\n\n        \/\/ \u30d1\u30b9\u30ef\u30fc\u30c9\u30ea\u30bb\u30c3\u30c8\u306e\u76e3\u8996\n        Event::listen(PasswordReset::class, function ($event) {\n            $this-&gt;logPasswordReset($event);\n        });\n    }\n\n    private function logAuthenticationAttempt($event)\n    {\n        $data = [\n            'ip' =&gt; request()-&gt;ip(),\n            'user_agent' =&gt; request()-&gt;userAgent(),\n            'email' =&gt; $event-&gt;credentials['email'] ?? null,\n            'status' =&gt; $event-&gt;user ? 'success' : 'failure'\n        ];\n\n        \/\/ \u4e0d\u6b63\u30a2\u30af\u30bb\u30b9\u306e\u691c\u77e5\n        if ($this-&gt;isSupiciousActivity($data)) {\n            $this-&gt;notifySecurityTeam($data);\n        }\n\n        \\Log::channel('auth')-&gt;info('Authentication attempt', $data);\n    }\n\n    private function isSupiciousActivity($data)\n    {\n        return Cache::remember(\"failed_attempts:{$data['ip']}\", 3600, function () use ($data) {\n            return \\Log::channel('auth')\n                -&gt;where('ip', $data['ip'])\n                -&gt;where('status', 'failure')\n                -&gt;where('created_at', '&gt;', now()-&gt;subHour())\n                -&gt;count() &gt; 5;\n        });\n    }\n}<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li><strong>\u4e0d\u6b63\u30a2\u30af\u30bb\u30b9\u5bfe\u7b56\u306e\u5b9f\u88c5\u4f8b<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">\/\/ app\/Http\/Middleware\/DetectSuspiciousActivity.php\nclass DetectSuspiciousActivity\n{\n    public function handle($request, Closure $next)\n    {\n        $key = 'auth_attempts_' . $request-&gt;ip();\n        $attempts = Cache::get($key, 0);\n\n        if ($attempts &gt; 10) {\n            \/\/ IP\u30a2\u30c9\u30ec\u30b9\u3092\u30d6\u30e9\u30c3\u30af\u30ea\u30b9\u30c8\u306b\u8ffd\u52a0\n            $this-&gt;blacklistIP($request-&gt;ip());\n            abort(403, 'Too many authentication attempts.');\n        }\n\n        $response = $next($request);\n\n        \/\/ \u8a8d\u8a3c\u5931\u6557\u6642\u306e\u51e6\u7406\n        if ($response-&gt;status() === 401) {\n            Cache::put($key, $attempts + 1, now()-&gt;addHour());\n        }\n\n        return $response;\n    }\n\n    private function blacklistIP($ip)\n    {\n        Redis::sadd('blacklisted_ips', $ip);\n        \\Log::channel('security')-&gt;warning('IP blacklisted', ['ip' =&gt; $ip]);\n    }\n}<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-22\">\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u30c1\u30e5\u30fc\u30cb\u30f3\u30b0\u306e\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u30bb\u30c3\u30b7\u30e7\u30f3\u7ba1\u7406\u306e\u6700\u9069\u5316<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">\/\/ config\/session.php\nreturn [\n    'driver' =&gt; env('SESSION_DRIVER', 'redis'),\n    'connection' =&gt; 'session',\n    'lifetime' =&gt; env('SESSION_LIFETIME', 120),\n    'lottery' =&gt; [2, 100],  \/\/ 2%\u306e\u78ba\u7387\u3067\u30ac\u30d9\u30fc\u30b8\u30b3\u30ec\u30af\u30b7\u30e7\u30f3\n];\n\n\/\/ Redis\u30bb\u30c3\u30b7\u30e7\u30f3\u306eCluster\u5bfe\u5fdc\n'redis' =&gt; [\n    'session' =&gt; [\n        'cluster' =&gt; true,\n        'prefix' =&gt; 'session_',\n        'persistent' =&gt; true,\n    ],\n],<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li><strong>\u30ad\u30e3\u30c3\u30b7\u30e5\u6226\u7565\u306e\u5b9f\u88c5<\/strong><\/li>\n<\/ol>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">\/\/ app\/Models\/User.php\npublic function getCachedPermissions()\n{\n    return Cache::tags(['permissions', \"user_{$this-&gt;id}\"])\n        -&gt;remember(\"user_permissions_{$this-&gt;id}\", 3600, function () {\n            return $this-&gt;permissions()\n                -&gt;with('roles')\n                -&gt;get();\n        });\n}\n\n\/\/ \u30ad\u30e3\u30c3\u30b7\u30e5\u306e\u81ea\u52d5\u66f4\u65b0\npublic static function boot()\n{\n    parent::boot();\n\n    static::updated(function ($user) {\n        Cache::tags(['permissions', \"user_{$user-&gt;id}\"])-&gt;flush();\n    });\n}<\/pre>\n\n\n\n<ol start=\"3\" class=\"wp-block-list\">\n<li><strong>\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u76e3\u8996\u6307\u6a19<\/strong><br>\u6307\u6a19 \u76ee\u6a19\u5024 \u76e3\u8996\u65b9\u6cd5 \u6539\u5584\u7b56<br>\u30ed\u30b0\u30a4\u30f3\u5fdc\u7b54\u6642\u9593 &lt;500ms NewRelic\u30e2\u30cb\u30bf\u30ea\u30f3\u30b0 \u30af\u30a8\u30ea\u6700\u9069\u5316<br>\u30bb\u30c3\u30b7\u30e7\u30f3\u6570 &lt;10000\/\u30b5\u30fc\u30d0\u30fc Redis\u30e2\u30cb\u30bf\u30ea\u30f3\u30b0 \u5b9a\u671f\u30af\u30ea\u30fc\u30f3\u30a2\u30c3\u30d7<br>\u30e1\u30e2\u30ea\u4f7f\u7528\u91cf &lt;80% \u30b5\u30fc\u30d0\u30fc\u30e2\u30cb\u30bf\u30ea\u30f3\u30b0 \u30bb\u30c3\u30b7\u30e7\u30f3\u6709\u52b9\u671f\u9650\u8abf\u6574 <code>\/\/ \u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u30e2\u30cb\u30bf\u30ea\u30f3\u30b0\u306e\u5b9f\u88c5\u4f8b class PerformanceMonitoringMiddleware { public function handle($request, Closure $next) { $startTime = microtime(true); $startMemory = memory_get_usage(); $response = $next($request); $endTime = microtime(true); $endMemory = memory_get_usage(); if (($endTime - $startTime) &gt; 0.5) { \\Log::channel('performance')-&gt;warning('Slow authentication', [ 'duration' =&gt; $endTime - $startTime, 'memory_usage' =&gt; $endMemory - $startMemory, 'uri' =&gt; $request-&gt;getUri() ]); } return $response; } }<\/code> \u3053\u308c\u3089\u306e\u904b\u7528\u30fb\u30e1\u30f3\u30c6\u30ca\u30f3\u30b9\u65b9\u91dd\u3092\u9069\u5207\u306b\u5b9f\u65bd\u3059\u308b\u3053\u3068\u3067\u3001\u8a8d\u8a3c\u30b7\u30b9\u30c6\u30e0\u306e\u5b89\u5b9a\u6027\u3068\u5b89\u5168\u6027\u3092\u7d99\u7d9a\u7684\u306b\u78ba\u4fdd\u3067\u304d\u307e\u3059\u3002\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u3001\u76e3\u8996\u3001\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u306e3\u3064\u306e\u89b3\u70b9\u304b\u3089\u30d0\u30e9\u30f3\u30b9\u306e\u53d6\u308c\u305f\u904b\u7528\u3092\u5fc3\u304c\u3051\u307e\u3057\u3087\u3046\u3002<\/li>\n<\/ol>\n","protected":false},"excerpt":{"rendered":"<p>Warning: Undefined array key &#8220;is_admin&#8221; in \/home\/xs392991\/dexall.co.jp\/public_html\/articles\/wp-content\/themes\/ &#8230; <\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[12],"tags":[],"class_list":{"0":"post-2506","1":"post","2":"type-post","3":"status-publish","4":"format-standard","6":"category-php","7":"nothumb"},"_links":{"self":[{"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/posts\/2506","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=2506"}],"version-history":[{"count":2,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/posts\/2506\/revisions"}],"predecessor-version":[{"id":2508,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/posts\/2506\/revisions\/2508"}],"wp:attachment":[{"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=2506"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=2506"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=2506"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}