{"id":3226,"date":"2025-03-24T08:46:38","date_gmt":"2025-03-23T23:46:38","guid":{"rendered":"https:\/\/dexall.co.jp\/articles\/?p=3226"},"modified":"2025-03-24T08:47:08","modified_gmt":"2025-03-23T23:47:08","slug":"laravel-ui%e3%81%ae%e5%ae%8c%e5%85%a8%e3%82%ac%e3%82%a4%e3%83%89%ef%bc%9a5%e5%88%86%e3%81%a7%e4%bd%bf%e3%81%84%e9%81%94%e6%88%90%e3%82%a4%e3%83%b3%e3%82%b9%e3%83%88%e3%83%bc%e3%83%ab%e3%81%8b%e3%82%89","status":"publish","type":"post","link":"https:\/\/dexall.co.jp\/articles\/?p=3226","title":{"rendered":"Laravel UI\u306e\u5b8c\u5168\u30ac\u30a4\u30c9\uff1a5\u5206\u3067\u4f7f\u3044\u9054\u6210\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u304b\u3089\u8a8d\u8a3c\u5b9f\u88c5\u307e\u3067"},"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 UI\u3068\u306f\uff1f\u305d\u306e\u7279\u5fb4\u3068\u4e3b\u8981\u6a5f\u80fd\u3092\u89e3\u8aac<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-1\">Laravel UI\u30d1\u30c3\u30b1\u30fc\u30b8\u306e\u5f79\u5272\u3068\u91cd\u8981\u6027<\/a>      <\/li>      <li>        <a href=\"#i-2\">Bootstrap\u7d71\u5408\u306b\u3088\u308b\u8fc5\u901f\u306a\u958b\u767a\u74b0\u5883\u306e\u69cb\u7bc9<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-3\">\u8a8d\u8a3c\u6a5f\u80fd\u5b9f\u88c5\u306b\u304a\u3051\u308bLaravel UI\u306e\u5229\u70b9<\/a>      <\/li>    <\/ul>  <\/li>  <li>    <a href=\"#i-4\">Laravel UI\u306e\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3068\u521d\u671f\u8a2d\u5b9a\u3092\u5fb9\u5e95\u89e3\u8aac<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-5\">composer\u3092\u4f7f\u7528\u3057\u305f\u78ba\u5b9f\u306a\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u624b\u9806<\/a>      <\/li>      <li>        <a href=\"#i-6\">\u8a8d\u8a3c\u30b9\u30ab\u30d5\u30a9\u30fc\u30eb\u30c9\u306e\u751f\u6210\u3068\u57fa\u672c\u8a2d\u5b9a<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-7\">npm\u4f9d\u5b58\u95a2\u4fc2\u306e\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3068\u30a2\u30bb\u30c3\u30c8\u306e\u30b3\u30f3\u30d1\u30a4\u30eb<\/a>      <\/li>    <\/ul>  <\/li>  <li>    <a href=\"#i-8\">Laravel UI\u8a8d\u8a3c\u30b7\u30b9\u30c6\u30e0\u306e\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u65b9\u6cd5<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-9\">\u30ed\u30b0\u30a4\u30f3\u30fb\u767b\u9332\u30d5\u30a9\u30fc\u30e0\u306e\u30c7\u30b6\u30a4\u30f3\u30ab\u30b9\u30bf\u30de\u30a4\u30ba<\/a>      <\/li>      <li>        <a href=\"#i-10\">\u8a8d\u8a3c\u30d7\u30ed\u30bb\u30b9\u306e\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u3068\u30df\u30c9\u30eb\u30a6\u30a7\u30a2\u306e\u6d3b\u7528<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-11\">\u591a\u8a00\u8a9e\u5bfe\u5fdc\u306e\u653b\u7565\u30c6\u30af\u30cb\u30c3\u30af<\/a>      <\/li>    <\/ul>  <\/li>  <li>    <a href=\"#i-12\">Laravel UI\u3067\u3088\u304f\u3042\u308b\u30c8\u30e9\u30d6\u30eb\u3068\u89e3\u6c7a\u7b56<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-13\">npm run dev\u3067\u306e\u30b3\u30f3\u30d1\u30a4\u30eb\u30a8\u30e9\u30fc\u306e\u5bfe\u51e6\u6cd5<\/a>      <\/li>      <li>        <a href=\"#i-14\">\u8a8d\u8a3c\u95a2\u9023\u306e\u4e00\u822c\u7684\u306a\u30a8\u30e9\u30fc\u3068\u89e3\u6c7a\u65b9\u6cd5<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-15\">\u30a2\u30c3\u30d7\u30b0\u30ec\u30fc\u30c9\u6642\u306e\u4e92\u63db\u6027\u554f\u984c\u3078\u306e\u5bfe\u5fdc<\/a>      <\/li>    <\/ul>  <\/li>  <li class=\"last\">    <a href=\"#i-16\">Laravel UI\u3092\u4f7f\u7528\u3057\u305f\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u958b\u767a\u306e\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-17\">\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u3092\u8003\u616e\u3057\u305f\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u306e\u65b9\u6cd5<\/a>      <\/li>      <li>        <a href=\"#i-18\">\u4fdd\u5b88\u6027\u3092\u9ad8\u3081\u308b\u30b3\u30fc\u30c9\u8a2d\u8a08\u306e\u30dd\u30a4\u30f3\u30c8<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-19\">\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u6700\u9069\u5316\u306e\u305f\u3081\u306e\u30d2\u30f3\u30c8<\/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 UI\u3068\u306f\uff1f\u305d\u306e\u7279\u5fb4\u3068\u4e3b\u8981\u6a5f\u80fd\u3092\u89e3\u8aac<\/h2>\n\n\n\n<p>Laravel UI\u306f\u3001Laravel\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u958b\u767a\u3092\u8fc5\u901f\u5316\u3059\u308b\u305f\u3081\u306e\u516c\u5f0f\u30d1\u30c3\u30b1\u30fc\u30b8\u3067\u3059\u3002\u7279\u306b\u30e6\u30fc\u30b6\u30fc\u8a8d\u8a3c\u6a5f\u80fd\u306e\u5b9f\u88c5\u3068Bootstrap\u30d9\u30fc\u30b9\u306eUI\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306e\u7d71\u5408\u306b\u7279\u5316\u3057\u3066\u304a\u308a\u3001\u958b\u767a\u52b9\u7387\u3092\u5927\u5e45\u306b\u5411\u4e0a\u3055\u305b\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-1\">Laravel UI\u30d1\u30c3\u30b1\u30fc\u30b8\u306e\u5f79\u5272\u3068\u91cd\u8981\u6027<\/h3>\n\n\n\n<p>Laravel UI\u30d1\u30c3\u30b1\u30fc\u30b8\u306f\u3001\u4ee5\u4e0b\u306e3\u3064\u306e\u4e3b\u8981\u306a\u5f79\u5272\u3092\u62c5\u3063\u3066\u3044\u307e\u3059\uff1a<\/p>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u8a8d\u8a3c\u6a5f\u80fd\u306e\u30b9\u30ab\u30d5\u30a9\u30fc\u30eb\u30c9\u751f\u6210<\/strong><\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30ed\u30b0\u30a4\u30f3\/\u767b\u9332\u30d5\u30a9\u30fc\u30e0\u306e\u81ea\u52d5\u751f\u6210<\/li>\n\n\n\n<li>\u30d1\u30b9\u30ef\u30fc\u30c9\u30ea\u30bb\u30c3\u30c8\u6a5f\u80fd\u306e\u63d0\u4f9b<\/li>\n\n\n\n<li>\u30e6\u30fc\u30b6\u30fc\u8a8d\u8a3c\u306b\u5fc5\u8981\u306a\u30eb\u30fc\u30c8\u3068\u30b3\u30f3\u30c8\u30ed\u30fc\u30e9\u306e\u8a2d\u5b9a<\/li>\n\n\n\n<li>\u30bb\u30c3\u30b7\u30e7\u30f3\u7ba1\u7406\u306e\u57fa\u672c\u8a2d\u5b9a<\/li>\n<\/ul>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u30a2\u30bb\u30c3\u30c8\u306e\u7ba1\u7406<\/strong><\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>npm\u4f9d\u5b58\u95a2\u4fc2\u306e\u81ea\u52d5\u8a2d\u5b9a<\/li>\n\n\n\n<li>webpack.mix.js\u306e\u521d\u671f\u8a2d\u5b9a<\/li>\n\n\n\n<li>CSS\/JavaScript\u30a2\u30bb\u30c3\u30c8\u306e\u30b3\u30f3\u30d1\u30a4\u30eb\u74b0\u5883\u6574\u5099<\/li>\n<\/ul>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u958b\u767a\u74b0\u5883\u306e\u6a19\u6e96\u5316<\/strong><\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306e\u69cb\u9020\u5316<\/li>\n\n\n\n<li>\u30b3\u30fc\u30c7\u30a3\u30f3\u30b0\u898f\u7d04\u306e\u7d71\u4e00<\/li>\n\n\n\n<li>\u30c1\u30fc\u30e0\u958b\u767a\u306b\u304a\u3051\u308b\u5171\u901a\u57fa\u76e4\u306e\u63d0\u4f9b<\/li>\n<\/ul>\n\n\n\n<p>\u3053\u308c\u3089\u306e\u6a5f\u80fd\u306b\u3088\u308a\u3001\u958b\u767a\u8005\u306f\u4ee5\u4e0b\u306e\u3088\u3046\u306a\u30e1\u30ea\u30c3\u30c8\u3092\u5f97\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\uff1a<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u958b\u767a\u6642\u9593\u306e\u5927\u5e45\u306a\u77ed\u7e2e<\/li>\n\n\n\n<li>\u30b3\u30fc\u30c9\u306e\u54c1\u8cea\u3068\u4e00\u8cab\u6027\u306e\u78ba\u4fdd<\/li>\n\n\n\n<li>\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u30ea\u30b9\u30af\u306e\u4f4e\u6e1b<\/li>\n\n\n\n<li>\u30e1\u30f3\u30c6\u30ca\u30f3\u30b9\u6027\u306e\u5411\u4e0a<\/li>\n<\/ul>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-2\">Bootstrap\u7d71\u5408\u306b\u3088\u308b\u8fc5\u901f\u306a\u958b\u767a\u74b0\u5883\u306e\u69cb\u7bc9<\/h3>\n\n\n\n<p>Laravel UI\u306f\u3001Bootstrap\u30d5\u30ec\u30fc\u30e0\u30ef\u30fc\u30af\u3068\u306e\u7dca\u5bc6\u306a\u7d71\u5408\u3092\u63d0\u4f9b\u3057\u307e\u3059\uff1a<\/p>\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=\"\"># Bootstrap\u30b9\u30ab\u30d5\u30a9\u30fc\u30eb\u30c9\u306e\u751f\u6210\nphp artisan ui bootstrap\n\n# \u8a8d\u8a3c\u6a5f\u80fd\u4ed8\u304d\u306eBootstrap\u30b9\u30ab\u30d5\u30a9\u30fc\u30eb\u30c9\u751f\u6210\nphp artisan ui bootstrap --auth<\/pre>\n\n\n\n<p>\u3053\u306e\u7d71\u5408\u306b\u3088\u308a\u4ee5\u4e0b\u306e\u5229\u70b9\u304c\u5f97\u3089\u308c\u307e\u3059\uff1a<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>\u30ec\u30b9\u30dd\u30f3\u30b7\u30d6\u30c7\u30b6\u30a4\u30f3\u306e\u5373\u6642\u5b9f\u73fe<\/strong><\/li>\n\n\n\n<li>\u30e2\u30d0\u30a4\u30eb\u30d5\u30a1\u30fc\u30b9\u30c8\u306e\u30ec\u30a4\u30a2\u30a6\u30c8<\/li>\n\n\n\n<li>\u30b0\u30ea\u30c3\u30c9\u30b7\u30b9\u30c6\u30e0\u306e\u6d3b\u7528<\/li>\n\n\n\n<li>\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306e\u518d\u5229\u7528\u6027<\/li>\n\n\n\n<li><strong>\u30c7\u30b6\u30a4\u30f3\u306e\u4e00\u8cab\u6027\u78ba\u4fdd<\/strong><\/li>\n\n\n\n<li>\u30d7\u30ea\u30bb\u30c3\u30c8\u3055\u308c\u305f\u30c6\u30fc\u30de<\/li>\n\n\n\n<li>\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u53ef\u80fd\u306aSASS\u30d5\u30a1\u30a4\u30eb<\/li>\n\n\n\n<li>\u8c4a\u5bcc\u306aUI\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8<\/li>\n\n\n\n<li><strong>\u958b\u767a\u751f\u7523\u6027\u306e\u5411\u4e0a<\/strong><\/li>\n\n\n\n<li>CSS\u30e6\u30fc\u30c6\u30a3\u30ea\u30c6\u30a3\u30af\u30e9\u30b9\u306e\u6d3b\u7528<\/li>\n\n\n\n<li>JavaScript\u30d7\u30e9\u30b0\u30a4\u30f3\u306e\u5373\u6642\u5229\u7528<\/li>\n\n\n\n<li>\u30af\u30ed\u30b9\u30d6\u30e9\u30a6\u30b6\u5bfe\u5fdc<\/li>\n<\/ul>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-3\">\u8a8d\u8a3c\u6a5f\u80fd\u5b9f\u88c5\u306b\u304a\u3051\u308bLaravel UI\u306e\u5229\u70b9<\/h3>\n\n\n\n<p>Laravel UI\u306e\u8a8d\u8a3c\u6a5f\u80fd\u306f\u3001\u30bb\u30ad\u30e5\u30a2\u3067\u62e1\u5f35\u6027\u306e\u9ad8\u3044\u5b9f\u88c5\u3092\u63d0\u4f9b\u3057\u307e\u3059\uff1a<\/p>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u5805\u7262\u306a\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u6a5f\u80fd<\/strong><\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>CSRF\u4fdd\u8b77<\/li>\n\n\n\n<li>\u30d1\u30b9\u30ef\u30fc\u30c9\u306e\u30cf\u30c3\u30b7\u30e5\u5316<\/li>\n\n\n\n<li>\u30d6\u30eb\u30fc\u30c8\u30d5\u30a9\u30fc\u30b9\u653b\u6483\u5bfe\u7b56<\/li>\n\n\n\n<li>\u30bb\u30c3\u30b7\u30e7\u30f3\u7ba1\u7406<\/li>\n<\/ul>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u53ef\u80fd\u306a\u8a8d\u8a3c\u30d5\u30ed\u30fc<\/strong><\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30df\u30c9\u30eb\u30a6\u30a7\u30a2\u306b\u3088\u308b\u67d4\u8edf\u306a\u5236\u5fa1<\/li>\n\n\n\n<li>\u30a4\u30d9\u30f3\u30c8\u30ea\u30b9\u30ca\u30fc\u306e\u6d3b\u7528<\/li>\n\n\n\n<li>\u30d0\u30ea\u30c7\u30fc\u30b7\u30e7\u30f3\u30eb\u30fc\u30eb\u306e\u30ab\u30b9\u30bf\u30de\u30a4\u30ba<\/li>\n\n\n\n<li>\u591a\u8981\u7d20\u8a8d\u8a3c\u306e\u8ffd\u52a0<\/li>\n<\/ul>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u4fdd\u5b88\u6027\u306e\u9ad8\u3044\u30b3\u30fc\u30c9\u69cb\u9020<\/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\u30b3\u30f3\u30c8\u30ed\u30fc\u30e9\u306e\u4f8b\n   class LoginController extends Controller\n   {\n       use AuthenticatesUsers;\n\n       \/\/ \u30ea\u30c0\u30a4\u30ec\u30af\u30c8\u5148\u306e\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\n       protected $redirectTo = '\/home';\n\n       \/\/ \u8ffd\u52a0\u306e\u30d0\u30ea\u30c7\u30fc\u30b7\u30e7\u30f3\u30eb\u30fc\u30eb\n       protected function validateLogin(Request $request)\n       {\n           $request-&gt;validate([\n               $this-&gt;username() =&gt; 'required|string',\n               'password' =&gt; 'required|string',\n               'terms' =&gt; 'required|accepted'  \/\/ \u8ffd\u52a0\u306e\u30eb\u30fc\u30eb\n           ]);\n       }\n   }<\/pre>\n\n\n\n<p>\u3053\u306e\u6a5f\u80fd\u30bb\u30c3\u30c8\u306b\u3088\u308a\u3001\u958b\u767a\u8005\u306f\u4ee5\u4e0b\u306e\u3088\u3046\u306a\u9ad8\u5ea6\u306a\u8981\u4ef6\u306b\u3082\u5bfe\u5fdc\u3067\u304d\u307e\u3059\uff1a<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30bd\u30fc\u30b7\u30e3\u30eb\u30ed\u30b0\u30a4\u30f3\u306e\u7d71\u5408<\/li>\n\n\n\n<li>\u30ab\u30b9\u30bf\u30e0\u8a8d\u8a3c\u30d5\u30a3\u30fc\u30eb\u30c9\u306e\u8ffd\u52a0<\/li>\n\n\n\n<li>\u6a29\u9650\u7ba1\u7406\u30b7\u30b9\u30c6\u30e0\u306e\u5b9f\u88c5<\/li>\n\n\n\n<li>\u591a\u8a00\u8a9e\u5bfe\u5fdc\u306e\u8a8d\u8a3c\u30d5\u30a9\u30fc\u30e0<\/li>\n<\/ul>\n\n\n\n<p>\u4ee5\u4e0a\u306e\u3088\u3046\u306b\u3001Laravel UI\u306f\u5358\u306a\u308bUI\u30c4\u30fc\u30eb\u30ad\u30c3\u30c8\u3067\u306f\u306a\u304f\u3001\u30e2\u30c0\u30f3\u306aWeb\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u958b\u767a\u306b\u5fc5\u8981\u306a\u6a5f\u80fd\u3092\u7d71\u5408\u7684\u306b\u63d0\u4f9b\u3059\u308b\u30d1\u30c3\u30b1\u30fc\u30b8\u3068\u3057\u3066\u3001\u958b\u767a\u52b9\u7387\u3068\u54c1\u8cea\u306e\u4e21\u9762\u3067\u5927\u304d\u306a\u4fa1\u5024\u3092\u63d0\u4f9b\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"i-4\">Laravel UI\u306e\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3068\u521d\u671f\u8a2d\u5b9a\u3092\u5fb9\u5e95\u89e3\u8aac<\/h2>\n\n\n\n<p>Laravel UI\u306e\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u304b\u3089\u521d\u671f\u8a2d\u5b9a\u307e\u3067\u3001\u78ba\u5b9f\u306b\u74b0\u5883\u3092\u69cb\u7bc9\u3059\u308b\u305f\u3081\u306e\u624b\u9806\u3092\u89e3\u8aac\u3057\u307e\u3059\u3002\u30a8\u30e9\u30fc\u3092\u9632\u304e\u3001\u30b9\u30e0\u30fc\u30ba\u306b\u30bb\u30c3\u30c8\u30a2\u30c3\u30d7\u3092\u5b8c\u4e86\u3055\u305b\u308b\u305f\u3081\u306e\u30dd\u30a4\u30f3\u30c8\u3082\u4f75\u305b\u3066\u7d39\u4ecb\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-5\">composer\u3092\u4f7f\u7528\u3057\u305f\u78ba\u5b9f\u306a\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u624b\u9806<\/h3>\n\n\n\n<p>Laravel UI\u306e\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u306f\u3001\u4ee5\u4e0b\u306e\u624b\u9806\u3067\u884c\u3044\u307e\u3059\uff1a<\/p>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u524d\u63d0\u6761\u4ef6\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=\"\">   # PHP\u30d0\u30fc\u30b8\u30e7\u30f3\u306e\u78ba\u8a8d\n   php -v  # PHP 7.3\u4ee5\u4e0a\u304c\u5fc5\u8981\n\n   # Composer\u306e\u78ba\u8a8d\n   composer -V\n\n   # Node\u3068npm\u306e\u78ba\u8a8d\n   node -v  # Node.js 12.0\u4ee5\u4e0a\u304c\u5fc5\u8981\n   npm -v   # npm 6.0\u4ee5\u4e0a\u304c\u5fc5\u8981<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li><strong>Laravel UI\u30d1\u30c3\u30b1\u30fc\u30b8\u306e\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb<\/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=\"\">   # \u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u3067\u5b9f\u884c\n   composer require laravel\/ui\n\n   # \u30d0\u30fc\u30b8\u30e7\u30f3\u3092\u6307\u5b9a\u3059\u308b\u5834\u5408\n   composer require laravel\/ui \"^3.4\"<\/pre>\n\n\n\n<ol start=\"3\" 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=\"\">   # Bootstrap\u30d9\u30fc\u30b9\u306e\u8a8d\u8a3c\u30b9\u30ab\u30d5\u30a9\u30fc\u30eb\u30c9\u3092\u751f\u6210\n   php artisan ui bootstrap --auth\n\n   # Vue.js\u3092\u4f7f\u7528\u3059\u308b\u5834\u5408\n   php artisan ui vue --auth\n\n   # React\u3092\u4f7f\u7528\u3059\u308b\u5834\u5408\n   php artisan ui react --auth<\/pre>\n\n\n\n<p>\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u6642\u306e\u91cd\u8981\u306a\u30dd\u30a4\u30f3\u30c8\uff1a<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>composer\u306e\u30ad\u30e3\u30c3\u30b7\u30e5\u3092\u30af\u30ea\u30a2\u3059\u308b\uff1a<code>composer clear-cache<\/code><\/li>\n\n\n\n<li>\u65e2\u5b58\u306enode\u30e2\u30b8\u30e5\u30fc\u30eb\u3092\u524a\u9664\uff1a<code>rm -rf node_modules<\/code><\/li>\n\n\n\n<li>package.json\u306e\u4f9d\u5b58\u95a2\u4fc2\u3092\u78ba\u8a8d<\/li>\n\n\n\n<li>.env\u30d5\u30a1\u30a4\u30eb\u306e\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u8a2d\u5b9a\u3092\u78ba\u8a8d<\/li>\n<\/ul>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-6\">\u8a8d\u8a3c\u30b9\u30ab\u30d5\u30a9\u30fc\u30eb\u30c9\u306e\u751f\u6210\u3068\u57fa\u672c\u8a2d\u5b9a<\/h3>\n\n\n\n<p>\u8a8d\u8a3c\u30b7\u30b9\u30c6\u30e0\u306e\u57fa\u672c\u8a2d\u5b9a\u306b\u306f\u4ee5\u4e0b\u306e\u624b\u9806\u304c\u5fc5\u8981\u3067\u3059\uff1a<\/p>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u306e\u30de\u30a4\u30b0\u30ec\u30fc\u30b7\u30e7\u30f3<\/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\n   php artisan migrate\n\n   # \u30de\u30a4\u30b0\u30ec\u30fc\u30b7\u30e7\u30f3\u306e\u78ba\u8a8d\n   php artisan migrate:status<\/pre>\n\n\n\n<ol start=\"2\" 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\/Http\/Controllers\/Auth\/\u4ee5\u4e0b\u306b\u751f\u6210\u3055\u308c\u308b\u30d5\u30a1\u30a4\u30eb\n   - LoginController.php\n   - RegisterController.php\n   - ForgotPasswordController.php\n   - ResetPasswordController.php\n\n   \/\/ \u5fc5\u8981\u306b\u5fdc\u3058\u3066\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\n   class LoginController extends Controller\n   {\n       \/\/ \u30ed\u30b0\u30a4\u30f3\u5f8c\u306e\u30ea\u30c0\u30a4\u30ec\u30af\u30c8\u5148\u3092\u5909\u66f4\n       protected $redirectTo = '\/dashboard';\n\n       \/\/ \u30ed\u30b0\u30a4\u30f3\u306b\u4f7f\u7528\u3059\u308b\u30d5\u30a3\u30fc\u30eb\u30c9\u3092\u5909\u66f4\n       public function username()\n       {\n           return 'username'; \/\/ email\u306e\u4ee3\u308f\u308a\u306busername\u3092\u4f7f\u7528\n       }\n   }<\/pre>\n\n\n\n<ol start=\"3\" class=\"wp-block-list\">\n<li><strong>\u30eb\u30fc\u30c6\u30a3\u30f3\u30b0\u306e\u78ba\u8a8d\u3068\u8abf\u6574<\/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=\"\">   \/\/ routes\/web.php\u3067\u78ba\u8a8d\u3067\u304d\u308b\u751f\u6210\u3055\u308c\u305f\u30eb\u30fc\u30c8\n   Auth::routes();\n\n   \/\/ \u30aa\u30d7\u30b7\u30e7\u30f3\u306e\u8ffd\u52a0\n   Auth::routes([\n       'register' =&gt; true,  \/\/ \u767b\u9332\u6a5f\u80fd\u3092\u6709\u52b9\u5316\n       'reset' =&gt; true,     \/\/ \u30d1\u30b9\u30ef\u30fc\u30c9\u30ea\u30bb\u30c3\u30c8\u3092\u6709\u52b9\u5316\n       'verify' =&gt; true,    \/\/ \u30e1\u30fc\u30eb\u78ba\u8a8d\u3092\u6709\u52b9\u5316\n   ]);<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-7\">npm\u4f9d\u5b58\u95a2\u4fc2\u306e\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3068\u30a2\u30bb\u30c3\u30c8\u306e\u30b3\u30f3\u30d1\u30a4\u30eb<\/h3>\n\n\n\n<p>\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u306e\u74b0\u5883\u8a2d\u5b9a\u306f\u4ee5\u4e0b\u306e\u624b\u9806\u3067\u884c\u3044\u307e\u3059\uff1a<\/p>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>npm\u4f9d\u5b58\u95a2\u4fc2\u306e\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb<\/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=\"\">   # \u4f9d\u5b58\u30d1\u30c3\u30b1\u30fc\u30b8\u306e\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\n   npm install\n\n   # \u7279\u5b9a\u306e\u30d0\u30fc\u30b8\u30e7\u30f3\u3092\u6307\u5b9a\u3059\u308b\u5834\u5408\n   npm install --legacy-peer-deps<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li><strong>\u30a2\u30bb\u30c3\u30c8\u306e\u30b3\u30f3\u30d1\u30a4\u30eb<\/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=\"\">   # \u958b\u767a\u74b0\u5883\u7528\u306e\u30b3\u30f3\u30d1\u30a4\u30eb\n   npm run dev\n\n   # \u672c\u756a\u74b0\u5883\u7528\u306e\u30b3\u30f3\u30d1\u30a4\u30eb\n   npm run production\n\n   # \u5909\u66f4\u3092\u76e3\u8996\u3057\u306a\u304c\u3089\u30b3\u30f3\u30d1\u30a4\u30eb\n   npm run watch<\/pre>\n\n\n\n<ol start=\"3\" class=\"wp-block-list\">\n<li><strong>webpack.mix.js\u306e\u8a2d\u5b9a\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=\"\">   \/\/ webpack.mix.js\u306e\u57fa\u672c\u8a2d\u5b9a\n   mix.js('resources\/js\/app.js', 'public\/js')\n      .sass('resources\/sass\/app.scss', 'public\/css')\n      .version();  \/\/ \u30ad\u30e3\u30c3\u30b7\u30e5\u30d0\u30b9\u30c6\u30a3\u30f3\u30b0\u7528\n\n   \/\/ \u30bd\u30fc\u30b9\u30de\u30c3\u30d7\u306e\u6709\u52b9\u5316\uff08\u958b\u767a\u74b0\u5883\u7528\uff09\n   if (!mix.inProduction()) {\n       mix.sourceMaps();\n   }<\/pre>\n\n\n\n<p>\u30a2\u30bb\u30c3\u30c8\u30b3\u30f3\u30d1\u30a4\u30eb\u6642\u306e\u6ce8\u610f\u70b9\uff1a<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li><code>npm run dev<\/code>\u5b9f\u884c\u524d\u306bnode_modules\u304c\u6b63\u3057\u304f\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3055\u308c\u3066\u3044\u308b\u304b\u78ba\u8a8d<\/li>\n\n\n\n<li>\u30b3\u30f3\u30d1\u30a4\u30eb\u30a8\u30e9\u30fc\u304c\u767a\u751f\u3057\u305f\u5834\u5408\u306f<code>npm cache clean --force<\/code>\u3092\u8a66\u3059<\/li>\n\n\n\n<li>\u30d0\u30fc\u30b8\u30e7\u30f3\u306e\u7af6\u5408\u304c\u3042\u308b\u5834\u5408\u306f<code>package.json<\/code>\u306e\u4f9d\u5b58\u95a2\u4fc2\u3092\u898b\u76f4\u3059<\/li>\n\n\n\n<li>\u30e1\u30e2\u30ea\u4e0d\u8db3\u30a8\u30e9\u30fc\u304c\u767a\u751f\u3059\u308b\u5834\u5408\u306fNode.js\u306e\u30e1\u30e2\u30ea\u5236\u9650\u3092\u8abf\u6574<\/li>\n<\/ul>\n\n\n\n<p>\u4ee5\u4e0a\u306e\u624b\u9806\u3092\u6b63\u3057\u304f\u5b9f\u884c\u3059\u308b\u3053\u3068\u3067\u3001Laravel UI\u306e\u57fa\u672c\u7684\u306a\u74b0\u5883\u69cb\u7bc9\u304c\u5b8c\u4e86\u3057\u307e\u3059\u3002\u6b21\u306e\u30b9\u30c6\u30c3\u30d7\u3067\u306f\u3001\u3053\u306e\u57fa\u76e4\u306e\u4e0a\u306b\u72ec\u81ea\u306e\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u3092\u52a0\u3048\u3066\u3044\u304f\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"i-8\">Laravel UI\u8a8d\u8a3c\u30b7\u30b9\u30c6\u30e0\u306e\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u65b9\u6cd5<\/h2>\n\n\n\n<p>Laravel UI\u306e\u8a8d\u8a3c\u30b7\u30b9\u30c6\u30e0\u306f\u3001\u57fa\u672c\u6a5f\u80fd\u3092\u63d0\u4f9b\u3057\u306a\u304c\u3089\u3082\u9ad8\u5ea6\u306a\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u304c\u53ef\u80fd\u3067\u3059\u3002\u3053\u3053\u3067\u306f\u3001\u5b9f\u969b\u306e\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3067\u3088\u304f\u5fc5\u8981\u3068\u3055\u308c\u308b\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u65b9\u6cd5\u3092\u5177\u4f53\u7684\u306b\u89e3\u8aac\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-9\">\u30ed\u30b0\u30a4\u30f3\u30fb\u767b\u9332\u30d5\u30a9\u30fc\u30e0\u306e\u30c7\u30b6\u30a4\u30f3\u30ab\u30b9\u30bf\u30de\u30a4\u30ba<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u30d3\u30e5\u30fc\u30d5\u30a1\u30a4\u30eb\u306e\u30ab\u30b9\u30bf\u30de\u30a4\u30ba<\/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\u306e\u7de8\u96c6\u4f8b\n   @extends('layouts.app')\n\n   @section('content')\n   &lt;div class=\"container\"&gt;\n       &lt;div class=\"card custom-login-card\"&gt;\n           &lt;div class=\"card-header\"&gt;{{ __('\u30ed\u30b0\u30a4\u30f3') }}&lt;\/div&gt;\n\n           &lt;div class=\"card-body\"&gt;\n               &lt;form method=\"POST\" action=\"{{ route('login') }}\" class=\"custom-form\"&gt;\n                   @csrf\n\n                   &lt;!-- \u30ab\u30b9\u30bf\u30e0\u30b9\u30bf\u30a4\u30eb\u306e\u30e1\u30fc\u30eb\u30d5\u30a3\u30fc\u30eb\u30c9 --&gt;\n                   &lt;div class=\"form-group row mb-4\"&gt;\n                       &lt;label for=\"email\" class=\"col-md-4 col-form-label\"&gt;\n                           {{ __('\u30e1\u30fc\u30eb\u30a2\u30c9\u30ec\u30b9') }}\n                       &lt;\/label&gt;\n\n                       &lt;div class=\"col-md-8\"&gt;\n                           &lt;input id=\"email\" type=\"email\" \n                                  class=\"form-control @error('email') is-invalid @enderror\"\n                                  name=\"email\" value=\"{{ old('email') }}\" \n                                  required autocomplete=\"email\" autofocus&gt;\n\n                           @error('email')\n                               &lt;span class=\"invalid-feedback\" role=\"alert\"&gt;\n                                   &lt;strong&gt;{{ $message }}&lt;\/strong&gt;\n                               &lt;\/span&gt;\n                           @enderror\n                       &lt;\/div&gt;\n                   &lt;\/div&gt;\n\n                   &lt;!-- \u30ab\u30b9\u30bf\u30e0\u30dc\u30bf\u30f3\u30b9\u30bf\u30a4\u30eb --&gt;\n                   &lt;div class=\"form-group mb-0\"&gt;\n                       &lt;button type=\"submit\" class=\"btn btn-primary custom-btn\"&gt;\n                           {{ __('\u30ed\u30b0\u30a4\u30f3') }}\n                       &lt;\/button&gt;\n                   &lt;\/div&gt;\n               &lt;\/form&gt;\n           &lt;\/div&gt;\n       &lt;\/div&gt;\n   &lt;\/div&gt;\n   @endsection<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li><strong>\u30ab\u30b9\u30bf\u30e0CSS\u306e\u9069\u7528<\/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\/sass\/auth\/_custom.scss\n   .custom-login-card {\n       border-radius: 15px;\n       box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);\n\n       .card-header {\n           background: linear-gradient(to right, #4a90e2, #67b26f);\n           color: white;\n           border-radius: 15px 15px 0 0;\n       }\n\n       .custom-form {\n           padding: 20px;\n\n           .form-control {\n               border-radius: 8px;\n               border: 1px solid #ddd;\n\n               &amp;:focus {\n                   box-shadow: 0 0 0 0.2rem rgba(74, 144, 226, 0.25);\n               }\n           }\n\n           .custom-btn {\n               width: 100%;\n               padding: 12px;\n               border-radius: 8px;\n               background: linear-gradient(to right, #4a90e2, #67b26f);\n               border: none;\n\n               &amp;:hover {\n                   transform: translateY(-1px);\n                   box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);\n               }\n           }\n       }\n   }<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-10\">\u8a8d\u8a3c\u30d7\u30ed\u30bb\u30b9\u306e\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u3068\u30df\u30c9\u30eb\u30a6\u30a7\u30a2\u306e\u6d3b\u7528<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u30ab\u30b9\u30bf\u30e0\u8a8d\u8a3c\u30ed\u30b8\u30c3\u30af\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\/LoginController.php\n   class LoginController extends Controller\n   {\n       use AuthenticatesUsers;\n\n       \/\/ \u30ed\u30b0\u30a4\u30f3\u8a66\u884c\u56de\u6570\u306e\u5236\u9650\u3092\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\n       protected $maxAttempts = 5;\n       protected $decayMinutes = 30;\n\n       \/\/ \u30ab\u30b9\u30bf\u30e0\u8a8d\u8a3c\u6761\u4ef6\u306e\u8ffd\u52a0\n       protected function validateLogin(Request $request)\n       {\n           $request-&gt;validate([\n               $this-&gt;username() =&gt; 'required|string|email',\n               'password' =&gt; 'required|string',\n               'terms' =&gt; 'required|accepted',  \/\/ \u5229\u7528\u898f\u7d04\u540c\u610f\u306e\u8ffd\u52a0\n           ]);\n       }\n\n       \/\/ \u30ed\u30b0\u30a4\u30f3\u5f8c\u306e\u51e6\u7406\u3092\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\n       protected function authenticated(Request $request, $user)\n       {\n           \/\/ \u30e6\u30fc\u30b6\u30fc\u306e\u6700\u7d42\u30ed\u30b0\u30a4\u30f3\u65e5\u6642\u3092\u66f4\u65b0\n           $user-&gt;update([\n               'last_login_at' =&gt; now(),\n               'last_login_ip' =&gt; $request-&gt;ip(),\n           ]);\n\n           \/\/ \u30e6\u30fc\u30b6\u30fc\u306e\u5f79\u5272\u306b\u5fdc\u3058\u3066\u30ea\u30c0\u30a4\u30ec\u30af\u30c8\u5148\u3092\u5909\u66f4\n           if ($user-&gt;hasRole('admin')) {\n               return redirect()-&gt;intended('\/admin\/dashboard');\n           }\n\n           return redirect()-&gt;intended('\/home');\n       }\n   }<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li><strong>\u30ab\u30b9\u30bf\u30e0\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\/CheckUserStatus.php\n   class CheckUserStatus\n   {\n       public function handle($request, Closure $next)\n       {\n           if (auth()-&gt;check() &amp;&amp; !auth()-&gt;user()-&gt;is_active) {\n               auth()-&gt;logout();\n\n               return redirect()-&gt;route('login')\n                   -&gt;withErrors(['email' =&gt; '\u30a2\u30ab\u30a6\u30f3\u30c8\u304c\u7121\u52b9\u5316\u3055\u308c\u3066\u3044\u307e\u3059\u3002']);\n           }\n\n           return $next($request);\n       }\n   }\n\n   \/\/ app\/Http\/Kernel.php\u306b\u767b\u9332\n   protected $routeMiddleware = [\n       'check.status' =&gt; \\App\\Http\\Middleware\\CheckUserStatus::class,\n   ];<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-11\">\u591a\u8a00\u8a9e\u5bfe\u5fdc\u306e\u653b\u7565\u30c6\u30af\u30cb\u30c3\u30af<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u8a00\u8a9e\u30d5\u30a1\u30a4\u30eb\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=\"\">   \/\/ resources\/lang\/ja\/auth.php\n   return [\n       'failed' =&gt; '\u8a8d\u8a3c\u60c5\u5831\u304c\u8a18\u9332\u3068\u4e00\u81f4\u3057\u307e\u305b\u3093\u3002',\n       'throttle' =&gt; '\u30ed\u30b0\u30a4\u30f3\u8a66\u884c\u304c\u898f\u5b9a\u56de\u6570\u3092\u8d85\u3048\u307e\u3057\u305f\u3002:seconds\u79d2\u5f8c\u306b\u518d\u5ea6\u304a\u8a66\u3057\u304f\u3060\u3055\u3044\u3002',\n       'terms' =&gt; '\u5229\u7528\u898f\u7d04\u306b\u540c\u610f\u3059\u308b\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002',\n       'custom' =&gt; [\n           'email' =&gt; [\n               'required' =&gt; '\u30e1\u30fc\u30eb\u30a2\u30c9\u30ec\u30b9\u306f\u5fc5\u9808\u3067\u3059\u3002',\n               'email' =&gt; '\u6709\u52b9\u306a\u30e1\u30fc\u30eb\u30a2\u30c9\u30ec\u30b9\u3092\u5165\u529b\u3057\u3066\u304f\u3060\u3055\u3044\u3002',\n           ],\n       ],\n   ];<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li><strong>\u591a\u8a00\u8a9e\u5207\u308a\u66ff\u3048\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\/LocaleMiddleware.php\n   class LocaleMiddleware\n   {\n       public function handle($request, Closure $next)\n       {\n           if (session()-&gt;has('locale')) {\n               app()-&gt;setLocale(session('locale'));\n           }\n\n           return $next($request);\n       }\n   }\n\n   \/\/ \u8a00\u8a9e\u5207\u308a\u66ff\u3048\u30b3\u30f3\u30c8\u30ed\u30fc\u30e9\u30fc\n   class LanguageController extends Controller\n   {\n       public function switch($locale)\n       {\n           if (in_array($locale, ['en', 'ja', 'zh'])) {\n               session(['locale' =&gt; $locale]);\n           }\n\n           return back();\n       }\n   }<\/pre>\n\n\n\n<ol start=\"3\" class=\"wp-block-list\">\n<li><strong>\u30d3\u30e5\u30fc\u3067\u306e\u8a00\u8a9e\u5207\u308a\u66ff\u3048UI\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=\"\">   &lt;!-- \u8a00\u8a9e\u5207\u308a\u66ff\u3048\u30c9\u30ed\u30c3\u30d7\u30c0\u30a6\u30f3\u306e\u4f8b --&gt;\n   &lt;div class=\"dropdown\"&gt;\n       &lt;button class=\"btn dropdown-toggle\" type=\"button\" data-toggle=\"dropdown\"&gt;\n           {{ __('\u8a00\u8a9e\u9078\u629e') }}\n       &lt;\/button&gt;\n       &lt;div class=\"dropdown-menu\"&gt;\n           &lt;a class=\"dropdown-item\" href=\"{{ route('language.switch', 'ja') }}\"&gt;\u65e5\u672c\u8a9e&lt;\/a&gt;\n           &lt;a class=\"dropdown-item\" href=\"{{ route('language.switch', 'en') }}\"&gt;English&lt;\/a&gt;\n           &lt;a class=\"dropdown-item\" href=\"{{ route('language.switch', 'zh') }}\"&gt;\u4e2d\u6587&lt;\/a&gt;\n       &lt;\/div&gt;\n   &lt;\/div&gt;<\/pre>\n\n\n\n<p>\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\u30b7\u30b9\u30c6\u30e0\u3092\u69cb\u7bc9\u3059\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002\u7279\u306b\u91cd\u8981\u306a\u30dd\u30a4\u30f3\u30c8\u306f\uff1a<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u3092\u5e38\u306b\u610f\u8b58\u3057\u305f\u30ab\u30b9\u30bf\u30de\u30a4\u30ba<\/li>\n\n\n\n<li>\u30e6\u30fc\u30b6\u30fc\u4f53\u9a13\u3092\u5411\u4e0a\u3055\u305b\u308bUI\u30c7\u30b6\u30a4\u30f3<\/li>\n\n\n\n<li>\u4fdd\u5b88\u6027\u3092\u8003\u616e\u3057\u305f\u30b3\u30fc\u30c9\u8a2d\u8a08<\/li>\n\n\n\n<li>\u30b9\u30b1\u30fc\u30e9\u30d6\u30eb\u306a\u591a\u8a00\u8a9e\u5bfe\u5fdc\u306e\u5b9f\u88c5<\/li>\n<\/ul>\n\n\n\n<p>\u3067\u3059\u3002\u6b21\u306e\u30b9\u30c6\u30c3\u30d7\u3067\u306f\u3001\u3053\u308c\u3089\u306e\u5b9f\u88c5\u306b\u304a\u3051\u308b\u30c8\u30e9\u30d6\u30eb\u30b7\u30e5\u30fc\u30c6\u30a3\u30f3\u30b0\u306b\u3064\u3044\u3066\u89e3\u8aac\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"i-12\">Laravel UI\u3067\u3088\u304f\u3042\u308b\u30c8\u30e9\u30d6\u30eb\u3068\u89e3\u6c7a\u7b56<\/h2>\n\n\n\n<p>Laravel UI\u306e\u5c0e\u5165\u3084\u904b\u7528\u6642\u306b\u767a\u751f\u3057\u304c\u3061\u306a\u30c8\u30e9\u30d6\u30eb\u3068\u305d\u306e\u89e3\u6c7a\u65b9\u6cd5\u3092\u3001\u5b9f\u8df5\u7684\u306a\u5bfe\u51e6\u6cd5\u3068\u5171\u306b\u89e3\u8aac\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-13\">npm run dev\u3067\u306e\u30b3\u30f3\u30d1\u30a4\u30eb\u30a8\u30e9\u30fc\u306e\u5bfe\u51e6\u6cd5<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>Node.js\u306e\u30d0\u30fc\u30b8\u30e7\u30f3\u4e0d\u4e00\u81f4\u306b\u3088\u308b\u30a8\u30e9\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=\"\">   # \u30a8\u30e9\u30fc\u30e1\u30c3\u30bb\u30fc\u30b8\u4f8b\n   Error: Node Sass does not yet support your current environment: OS X 64-bit with Unsupported runtime (57)<\/pre>\n\n\n\n<p>\u89e3\u6c7a\u7b56\uff1a<\/p>\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=\"\">   # Node.js\u306e\u30d0\u30fc\u30b8\u30e7\u30f3\u3092\u78ba\u8a8d\n   node -v\n\n   # npm\u30d1\u30c3\u30b1\u30fc\u30b8\u3092\u518d\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\n   rm -rf node_modules\n   rm package-lock.json\n   npm cache clean --force\n   npm install\n\n   # \u307e\u305f\u306f\u7279\u5b9a\u306eNode.js\u30d0\u30fc\u30b8\u30e7\u30f3\u3092\u4f7f\u7528\n   nvm install 14\n   nvm use 14\n   npm install<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li><strong>\u4f9d\u5b58\u95a2\u4fc2\u306e\u7af6\u5408\u306b\u3088\u308b\u30a8\u30e9\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=\"\">   # \u30a8\u30e9\u30fc\u30e1\u30c3\u30bb\u30fc\u30b8\u4f8b\n   npm ERR! code ERESOLVE\n   npm ERR! ERESOLVE unable to resolve dependency tree<\/pre>\n\n\n\n<p>\u89e3\u6c7a\u7b56\uff1a<\/p>\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=\"\">   # \u30ec\u30ac\u30b7\u30fc\u30d4\u30a2\u4f9d\u5b58\u95a2\u4fc2\u3092\u8a31\u53ef\u3057\u3066\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\n   npm install --legacy-peer-deps\n\n   # \u307e\u305f\u306fpackage.json\u306e\u4f9d\u5b58\u95a2\u4fc2\u3092\u66f4\u65b0\n   {\n       \"devDependencies\": {\n           \"bootstrap\": \"^4.6.0\",\n           \"jquery\": \"^3.6\",\n           \"popper.js\": \"^1.16.1\",\n           \"sass\": \"^1.32.11\",\n           \"sass-loader\": \"^11.0.1\"\n       }\n   }<\/pre>\n\n\n\n<ol start=\"3\" class=\"wp-block-list\">\n<li><strong>\u30e1\u30e2\u30ea\u4e0d\u8db3\u30a8\u30e9\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=\"\">   # \u30a8\u30e9\u30fc\u30e1\u30c3\u30bb\u30fc\u30b8\u4f8b\n   FATAL ERROR: Ineffective mark-compacts near heap limit Allocation failed<\/pre>\n\n\n\n<p>\u89e3\u6c7a\u7b56\uff1a<\/p>\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=\"\">   # Node.js\u306e\u30e1\u30e2\u30ea\u5236\u9650\u3092\u5897\u3084\u3059\n   export NODE_OPTIONS=--max-old-space-size=4096\n\n   # \u307e\u305f\u306fnpm\u5b9f\u884c\u6642\u306b\u76f4\u63a5\u6307\u5b9a\n   NODE_OPTIONS=--max-old-space-size=4096 npm run dev<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-14\">\u8a8d\u8a3c\u95a2\u9023\u306e\u4e00\u822c\u7684\u306a\u30a8\u30e9\u30fc\u3068\u89e3\u6c7a\u65b9\u6cd5<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u30de\u30a4\u30b0\u30ec\u30fc\u30b7\u30e7\u30f3\u30a8\u30e9\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=\"\">   \/\/ \u30a8\u30e9\u30fc\u30e1\u30c3\u30bb\u30fc\u30b8\u4f8b\n   SQLSTATE[42S01]: Base table or view already exists: 1050 Table 'users' already exists\n\n   \/\/ \u89e3\u6c7a\u7b56\uff1a\u30de\u30a4\u30b0\u30ec\u30fc\u30b7\u30e7\u30f3\u3092\u30ea\u30bb\u30c3\u30c8\n   php artisan migrate:reset\n   php artisan migrate\n\n   \/\/ \u307e\u305f\u306f\u7279\u5b9a\u306e\u30c6\u30fc\u30d6\u30eb\u306e\u307f\u518d\u4f5c\u6210\n   Schema::dropIfExists('users');\n   Schema::create('users', function (Blueprint $table) {\n       \/\/ ...\n   });<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li><strong>\u8a8d\u8a3c\u30eb\u30fc\u30c8\u306e\u7af6\u5408<\/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=\"\">   \/\/ \u75c7\u72b6\uff1a\u8a8d\u8a3c\u30da\u30fc\u30b8\u306b\u30a2\u30af\u30bb\u30b9\u3067\u304d\u306a\u3044\n\n   \/\/ \u89e3\u6c7a\u7b56\uff1aroutes\/web.php\u3067\u306e\u6b63\u3057\u3044\u9806\u5e8f\u8a2d\u5b9a\n   \/\/ \u30ab\u30b9\u30bf\u30e0\u30eb\u30fc\u30c8\u3092\u5148\u306b\u5b9a\u7fa9\n   Route::get('\/custom-login', 'CustomAuthController@login');\n\n   \/\/ \u305d\u306e\u5f8c\u306b\u6a19\u6e96\u8a8d\u8a3c\u30eb\u30fc\u30c8\u3092\u5b9a\u7fa9\n   Auth::routes();\n\n   \/\/ \u5fc5\u8981\u306b\u5fdc\u3058\u3066\u30eb\u30fc\u30c8\u3092\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\n   Auth::routes([\n       'register' =&gt; true,\n       'reset' =&gt; true,\n       'verify' =&gt; true\n   ]);<\/pre>\n\n\n\n<ol start=\"3\" class=\"wp-block-list\">\n<li><strong>\u30bb\u30c3\u30b7\u30e7\u30f3\u95a2\u9023\u306e\u30a8\u30e9\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=\"\">   \/\/ \u30a8\u30e9\u30fc\u30e1\u30c3\u30bb\u30fc\u30b8\u4f8b\n   No application encryption key has been specified.\n\n   \/\/ \u89e3\u6c7a\u7b56\uff1a\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u30ad\u30fc\u306e\u751f\u6210\n   php artisan key:generate\n\n   \/\/ \u30bb\u30c3\u30b7\u30e7\u30f3\u8a2d\u5b9a\u306e\u78ba\u8a8d\n   \/\/ config\/session.php\n   return [\n       'driver' =&gt; env('SESSION_DRIVER', 'file'),\n       'lifetime' =&gt; env('SESSION_LIFETIME', 120),\n       'expire_on_close' =&gt; false,\n       \/\/ ...\n   ];<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-15\">\u30a2\u30c3\u30d7\u30b0\u30ec\u30fc\u30c9\u6642\u306e\u4e92\u63db\u6027\u554f\u984c\u3078\u306e\u5bfe\u5fdc<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>Bootstrap\u30d0\u30fc\u30b8\u30e7\u30f3\u4e92\u63db\u6027\u306e\u554f\u984c<\/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=\"\">   \/\/ package.json\u306e\u66f4\u65b0\u4f8b\n   {\n       \"devDependencies\": {\n           \"bootstrap\": \"^5.1.0\",\n           \"@popperjs\/core\": \"^2.10.2\",\n           \"sass\": \"^1.42.1\",\n           \"sass-loader\": \"^12.1.0\"\n       }\n   }<\/pre>\n\n\n\n<p>\u95a2\u9023\u3059\u308bSCSS\u306e\u66f4\u65b0\uff1a<\/p>\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\/sass\/app.scss\n   \/\/ Bootstrap 5\u5bfe\u5fdc\n   @import '~bootstrap\/scss\/bootstrap';\n\n   \/\/ \u30ab\u30b9\u30bf\u30e0\u30b9\u30bf\u30a4\u30eb\u306e\u8abf\u6574\n   .navbar-laravel {\n       background-color: #fff;\n       box-shadow: 0 2px 4px rgba(0, 0, 0, 0.04);\n   }<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li><strong>PHP\/Laravel\u30d0\u30fc\u30b8\u30e7\u30f3\u4e92\u63db\u6027\u306e\u554f\u984c<\/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\u306e\u66f4\u65b0\u4f8b\n   {\n       \"require\": {\n           \"php\": \"^7.3|^8.0\",\n           \"laravel\/framework\": \"^8.0\",\n           \"laravel\/ui\": \"^3.0\"\n       }\n   }\n\n   \/\/ \u4e92\u63db\u6027\u306e\u78ba\u8a8d\u3068\u30a2\u30c3\u30d7\u30c7\u30fc\u30c8\n   composer show laravel\/ui\n   composer update laravel\/ui --with-dependencies<\/pre>\n\n\n\n<ol start=\"3\" class=\"wp-block-list\">\n<li><strong>\u30d3\u30e5\u30fc\u30d5\u30a1\u30a4\u30eb\u306e\u4e92\u63db\u6027\u554f\u984c<\/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=\"\">   # \u30d3\u30e5\u30fc\u30d5\u30a1\u30a4\u30eb\u306e\u516c\u958b\uff08\u65e2\u5b58\u306e\u30d5\u30a1\u30a4\u30eb\u3092\u4e0a\u66f8\u304d\u3057\u306a\u3044\uff09\n   php artisan vendor:publish --tag=laravel-ui-views --force\n\n   # \u30ad\u30e3\u30c3\u30b7\u30e5\u306e\u30af\u30ea\u30a2\n   php artisan view:clear\n   php artisan cache:clear\n   php artisan config:clear<\/pre>\n\n\n\n<p>\u8ffd\u52a0\u306e\u30c8\u30e9\u30d6\u30eb\u30b7\u30e5\u30fc\u30c6\u30a3\u30f3\u30b0\u306e\u30d2\u30f3\u30c8\uff1a<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>\u30c7\u30d0\u30c3\u30b0\u30e2\u30fc\u30c9\u306e\u6d3b\u7528<\/strong><\/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=\"\">  \/\/ .env\u30d5\u30a1\u30a4\u30eb\n  APP_DEBUG=true\n\n  \/\/ storage\/logs\/laravel.log\u306e\u76e3\u8996\n  tail -f storage\/logs\/laravel.log<\/pre>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>\u30a8\u30e9\u30fc\u30ed\u30b0\u306e\u78ba\u8a8d<\/strong><\/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=\"\">  # npm\u306e\u30c7\u30d0\u30c3\u30b0\u30ed\u30b0\n  npm run dev --verbose\n\n  # Laravel\u306e\u30ed\u30b0\n  cat storage\/logs\/laravel.log<\/pre>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>\u958b\u767a\u74b0\u5883\u306e\u30af\u30ea\u30fc\u30f3\u30a2\u30c3\u30d7<\/strong><\/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=\"\">  # \u5168\u30ad\u30e3\u30c3\u30b7\u30e5\u306e\u30af\u30ea\u30a2\n  php artisan optimize:clear\n\n  # \u30a2\u30bb\u30c3\u30c8\u306e\u518d\u30b3\u30f3\u30d1\u30a4\u30eb\n  npm run dev<\/pre>\n\n\n\n<p>\u3053\u308c\u3089\u306e\u89e3\u6c7a\u7b56\u306f\u3001\u4e00\u822c\u7684\u306a\u30c8\u30e9\u30d6\u30eb\u306b\u5bfe\u3059\u308b\u57fa\u672c\u7684\u306a\u30a2\u30d7\u30ed\u30fc\u30c1\u3067\u3059\u3002\u500b\u3005\u306e\u74b0\u5883\u3084\u8981\u4ef6\u306b\u3088\u3063\u3066\u6700\u9069\u306a\u89e3\u6c7a\u7b56\u306f\u7570\u306a\u308b\u5834\u5408\u304c\u3042\u308b\u305f\u3081\u3001\u30a8\u30e9\u30fc\u30e1\u30c3\u30bb\u30fc\u30b8\u3092\u6ce8\u610f\u6df1\u304f\u8aad\u307f\u3001\u5fc5\u8981\u306b\u5fdc\u3058\u3066\u516c\u5f0f\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u3084\u30b3\u30df\u30e5\u30cb\u30c6\u30a3\u30d5\u30a9\u30fc\u30e9\u30e0\u3082\u53c2\u7167\u3059\u308b\u3053\u3068\u3092\u304a\u52e7\u3081\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"i-16\">Laravel UI\u3092\u4f7f\u7528\u3057\u305f\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u958b\u767a\u306e\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9<\/h2>\n\n\n\n<p>Laravel UI\u3092\u4f7f\u7528\u3057\u305f\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u958b\u767a\u306b\u304a\u3044\u3066\u3001\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u3001\u4fdd\u5b88\u6027\u3001\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u3092\u8003\u616e\u3057\u305f\u5b9f\u88c5\u65b9\u6cd5\u3068\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9\u3092\u89e3\u8aac\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-17\">\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u3092\u8003\u616e\u3057\u305f\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u306e\u65b9\u6cd5<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u8a8d\u8a3c\u30b7\u30b9\u30c6\u30e0\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=\"\">   \/\/ app\/Http\/Controllers\/Auth\/LoginController.php\n   class LoginController extends Controller\n   {\n       use AuthenticatesUsers;\n\n       \/\/ 2\u8981\u7d20\u8a8d\u8a3c\u306e\u5b9f\u88c5\u4f8b\n       protected function authenticated(Request $request, $user)\n       {\n           if ($user-&gt;two_factor_enabled) {\n               \/\/ 2\u8981\u7d20\u8a8d\u8a3c\u30b3\u30fc\u30c9\u306e\u751f\u6210\u3068\u9001\u4fe1\n               $code = mt_rand(100000, 999999);\n               $user-&gt;two_factor_code = Hash::make($code);\n               $user-&gt;two_factor_expires_at = now()-&gt;addMinutes(10);\n               $user-&gt;save();\n\n               \/\/ \u30b3\u30fc\u30c9\u3092\u30e1\u30fc\u30eb\u3067\u9001\u4fe1\n               Mail::to($user)-&gt;send(new TwoFactorCode($code));\n\n               return redirect()-&gt;route('2fa.verify');\n           }\n\n           return redirect()-&gt;intended($this-&gt;redirectPath());\n       }\n   }\n\n   \/\/ \u30bb\u30ad\u30e5\u30a2\u306a\u30d1\u30b9\u30ef\u30fc\u30c9\u30ea\u30bb\u30c3\u30c8\u51e6\u7406\n   class ResetPasswordController extends Controller\n   {\n       protected function rules()\n       {\n           return [\n               'token' =&gt; 'required',\n               'email' =&gt; 'required|email',\n               'password' =&gt; [\n                   'required',\n                   'confirmed',\n                   'min:12',\n                   'regex:\/^(?=.*[a-z])(?=.*[A-Z])(?=.*\\d)(?=.*[@$!%*?&amp;])[A-Za-z\\d@$!%*?&amp;]+$\/'\n               ],\n           ];\n       }\n   }<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li><strong>XSS\u5bfe\u7b56\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=\"\">   \/\/ Blade \u30c6\u30f3\u30d7\u30ec\u30fc\u30c8\u3067\u306e\u30a8\u30b9\u30b1\u30fc\u30d7\u51e6\u7406\n   &lt;div class=\"user-content\"&gt;\n       {!! clean($userContent) !!}  \/\/ HTMLPurifier\u3092\u4f7f\u7528\n   &lt;\/div&gt;\n\n   \/\/ HTMLPurifier\u306e\u8a2d\u5b9a\n   \/\/ app\/Providers\/AppServiceProvider.php\n   public function boot()\n   {\n       Blade::directive('purify', function ($expression) {\n           return \"&lt;?php echo clean($expression); ?&gt;\";\n       });\n   }<\/pre>\n\n\n\n<ol start=\"3\" class=\"wp-block-list\">\n<li><strong>CSRF\u3068\u30bb\u30c3\u30b7\u30e7\u30f3\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3<\/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\n   return [\n       'secure' =&gt; env('SESSION_SECURE_COOKIE', true),\n       'same_site' =&gt; 'lax',\n       'http_only' =&gt; true,\n   ];\n\n   \/\/ \u30df\u30c9\u30eb\u30a6\u30a7\u30a2\u3067\u306e\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u30d8\u30c3\u30c0\u30fc\u8ffd\u52a0\n   class SecurityHeaders\n   {\n       public function handle($request, Closure $next)\n       {\n           $response = $next($request);\n\n           $response-&gt;headers-&gt;set('X-Frame-Options', 'SAMEORIGIN');\n           $response-&gt;headers-&gt;set('X-XSS-Protection', '1; mode=block');\n           $response-&gt;headers-&gt;set('X-Content-Type-Options', 'nosniff');\n           $response-&gt;headers-&gt;set('Referrer-Policy', 'strict-origin-when-cross-origin');\n\n           return $response;\n       }\n   }<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-18\">\u4fdd\u5b88\u6027\u3092\u9ad8\u3081\u308b\u30b3\u30fc\u30c9\u8a2d\u8a08\u306e\u30dd\u30a4\u30f3\u30c8<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u8a8d\u8a3c\u95a2\u9023\u306e\u30ab\u30b9\u30bf\u30e0\u30c8\u30ec\u30a4\u30c8\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\/Traits\/AuthenticationCustomization.php\n   trait AuthenticationCustomization\n   {\n       \/\/ \u30ed\u30b0\u30a4\u30f3\u8a66\u884c\u56de\u6570\u306e\u5236\u9650\u3092\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\n       protected function hasTooManyLoginAttempts(Request $request)\n       {\n           return $this-&gt;limiter()-&gt;tooManyAttempts(\n               $this-&gt;throttleKey($request),\n               $this-&gt;getMaxLoginAttempts(),\n               $this-&gt;getDecayMinutes()\n           );\n       }\n\n       \/\/ \u30ab\u30b9\u30bf\u30e0\u30ed\u30b0\u30a4\u30f3\u6761\u4ef6\u306e\u8ffd\u52a0\n       protected function validateLogin(Request $request)\n       {\n           $this-&gt;validate($request, $this-&gt;customValidationRules());\n       }\n\n       \/\/ \u30d0\u30ea\u30c7\u30fc\u30b7\u30e7\u30f3\u30eb\u30fc\u30eb\u3092\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u53ef\u80fd\u306b\n       protected function customValidationRules()\n       {\n           return [\n               $this-&gt;username() =&gt; 'required|string',\n               'password' =&gt; 'required|string',\n           ];\n       }\n   }<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li><strong>\u30d3\u30e5\u30fc\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306e\u6d3b\u7528<\/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\/View\/Components\/Auth\/LoginForm.php\n   class LoginForm extends Component\n   {\n       public function render()\n       {\n           return view('components.auth.login-form', [\n               'socialProviders' =&gt; $this-&gt;getEnabledSocialProviders(),\n               'rememberMeEnabled' =&gt; config('auth.remember_me_enabled'),\n           ]);\n       }\n\n       private function getEnabledSocialProviders()\n       {\n           return collect(config('services'))\n               -&gt;only(['github', 'google', 'facebook'])\n               -&gt;filter(function ($config) {\n                   return isset($config['client_id']) &amp;&amp; isset($config['client_secret']);\n               })\n               -&gt;keys();\n       }\n   }<\/pre>\n\n\n\n<ol start=\"3\" class=\"wp-block-list\">\n<li><strong>\u30b5\u30fc\u30d3\u30b9\u30af\u30e9\u30b9\u306e\u6d3b\u7528<\/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\/Services\/AuthenticationService.php\n   class AuthenticationService\n   {\n       public function attemptLogin(array $credentials, bool $remember = false)\n       {\n           event(new LoginAttempted($credentials));\n\n           try {\n               $success = Auth::attempt($credentials, $remember);\n\n               if ($success) {\n                   event(new LoginSuccessful(Auth::user()));\n                   $this-&gt;updateLoginStats();\n               } else {\n                   event(new LoginFailed($credentials));\n               }\n\n               return $success;\n           } catch (\\Exception $e) {\n               report($e);\n               return false;\n           }\n       }\n\n       private function updateLoginStats()\n       {\n           Auth::user()-&gt;update([\n               'last_login_at' =&gt; now(),\n               'last_login_ip' =&gt; request()-&gt;ip(),\n           ]);\n       }\n   }<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-19\">\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u6700\u9069\u5316\u306e\u305f\u3081\u306e\u30d2\u30f3\u30c8<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u30a2\u30bb\u30c3\u30c8\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=\"\">   \/\/ webpack.mix.js\n   const mix = require('laravel-mix');\n\n   mix.js('resources\/js\/app.js', 'public\/js')\n      .sass('resources\/sass\/app.scss', 'public\/css')\n      .extract(['vue', 'jquery'])  \/\/ \u30d9\u30f3\u30c0\u30fc\u30d5\u30a1\u30a4\u30eb\u306e\u5206\u96e2\n      .version()\n      .sourceMaps();\n\n   if (mix.inProduction()) {\n       mix.options({\n           terser: {\n               terserOptions: {\n                   compress: {\n                       drop_console: true,\n                   },\n               },\n           },\n           cssNano: {\n               discardComments: {\n                   removeAll: true,\n               },\n           },\n       });\n   }<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li><strong>\u9045\u5ef6\u30ed\u30fc\u30c7\u30a3\u30f3\u30b0\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=\"\">   &lt;!-- resources\/views\/layouts\/app.blade.php --&gt;\n   &lt;head&gt;\n       &lt;!-- \u30af\u30ea\u30c6\u30a3\u30ab\u30ebCSS\u306e\u30a4\u30f3\u30e9\u30a4\u30f3\u5316 --&gt;\n       &lt;style&gt;\n           {!! file_get_contents(public_path('css\/critical.css')) !!}\n       &lt;\/style&gt;\n\n       &lt;!-- \u975e\u30af\u30ea\u30c6\u30a3\u30ab\u30ebCSS\u306e\u9045\u5ef6\u30ed\u30fc\u30c9 --&gt;\n       &lt;link rel=\"preload\" href=\"{{ mix('css\/app.css') }}\" as=\"style\" onload=\"this.onload=null;this.rel='stylesheet'\"&gt;\n       &lt;noscript&gt;&lt;link rel=\"stylesheet\" href=\"{{ mix('css\/app.css') }}\"&gt;&lt;\/noscript&gt;\n   &lt;\/head&gt;<\/pre>\n\n\n\n<ol start=\"3\" class=\"wp-block-list\">\n<li><strong>\u30ad\u30e3\u30c3\u30b7\u30e5\u306e\u6d3b\u7528<\/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\u95a2\u9023\u306e\u8a2d\u5b9a\u306e\u30ad\u30e3\u30c3\u30b7\u30e5\n   class AuthConfiguration\n   {\n       public function getLoginRules()\n       {\n           return Cache::remember('auth.login.rules', now()-&gt;addHours(24), function () {\n               return [\n                   'email' =&gt; ['required', 'email'],\n                   'password' =&gt; ['required'],\n                   \/\/ \u305d\u306e\u4ed6\u306e\u30eb\u30fc\u30eb\n               ];\n           });\n       }\n   }\n\n   \/\/ \u30d3\u30e5\u30fc\u306e\u30ad\u30e3\u30c3\u30b7\u30e5\n   if (app()-&gt;environment('production')) {\n       view()-&gt;cache();\n   }<\/pre>\n\n\n\n<p>\u5b9f\u88c5\u306b\u304a\u3051\u308b\u91cd\u8981\u306a\u30dd\u30a4\u30f3\u30c8\uff1a<\/p>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u5bfe\u7b56<\/strong><\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u5165\u529b\u5024\u306e\u9069\u5207\u306a\u30d0\u30ea\u30c7\u30fc\u30b7\u30e7\u30f3<\/li>\n\n\n\n<li>\u30bb\u30c3\u30b7\u30e7\u30f3\u7ba1\u7406\u306e\u5f37\u5316<\/li>\n\n\n\n<li>XSS\/CSRF\u5bfe\u7b56\u306e\u5fb9\u5e95<\/li>\n\n\n\n<li>\u30bb\u30ad\u30e5\u30a2\u306a\u30d1\u30b9\u30ef\u30fc\u30c9\u8981\u4ef6\u306e\u8a2d\u5b9a<\/li>\n<\/ul>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u30b3\u30fc\u30c9\u4fdd\u5b88\u6027<\/strong><\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u8cac\u52d9\u306e\u660e\u78ba\u306a\u5206\u96e2<\/li>\n\n\n\n<li>\u518d\u5229\u7528\u53ef\u80fd\u306a\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306e\u4f5c\u6210<\/li>\n\n\n\n<li>\u9069\u5207\u306a\u62bd\u8c61\u5316\u30ec\u30d9\u30eb\u306e\u7dad\u6301<\/li>\n\n\n\n<li>\u30c6\u30b9\u30c8\u5bb9\u6613\u6027\u306e\u78ba\u4fdd<\/li>\n<\/ul>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u6700\u9069\u5316<\/strong><\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30a2\u30bb\u30c3\u30c8\u306e\u6700\u9069\u5316<\/li>\n\n\n\n<li>\u30ad\u30e3\u30c3\u30b7\u30e5\u306e\u52b9\u679c\u7684\u306a\u6d3b\u7528<\/li>\n\n\n\n<li>\u9045\u5ef6\u30ed\u30fc\u30c7\u30a3\u30f3\u30b0\u306e\u5b9f\u88c5<\/li>\n\n\n\n<li>\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u30af\u30a8\u30ea\u306e\u6700\u9069\u5316<\/li>\n<\/ul>\n\n\n\n<p>\u3053\u308c\u3089\u306e\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9\u3092\u9069\u7528\u3059\u308b\u3053\u3068\u3067\u3001\u30bb\u30ad\u30e5\u30a2\u3067\u4fdd\u5b88\u6027\u304c\u9ad8\u304f\u3001\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u306e\u826f\u3044Laravel UI\u30d9\u30fc\u30b9\u306e\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u3092\u69cb\u7bc9\u3059\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<\/p>\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":[33,12],"tags":[],"class_list":{"0":"post-3226","1":"post","2":"type-post","3":"status-publish","4":"format-standard","6":"category-php-laravel","7":"category-php","8":"nothumb"},"_links":{"self":[{"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/posts\/3226","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=3226"}],"version-history":[{"count":2,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/posts\/3226\/revisions"}],"predecessor-version":[{"id":3228,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/posts\/3226\/revisions\/3228"}],"wp:attachment":[{"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=3226"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=3226"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=3226"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}