{"id":2488,"date":"2025-03-24T08:47:10","date_gmt":"2025-03-23T23:47:10","guid":{"rendered":"https:\/\/dexall.co.jp\/articles\/?p=2488"},"modified":"2025-03-24T08:47:40","modified_gmt":"2025-03-23T23:47:40","slug":"laravel-419%e3%82%a8%e3%83%a9%e3%83%bc%e3%81%ae%e5%ae%8c%e5%85%a8%e8%a7%a3%e6%b1%ba%e3%82%ac%e3%82%a4%e3%83%89-%e5%8e%9f%e5%9b%a0%e3%81%a8%e5%af%be%e5%87%a6%e6%b3%95%e3%82%92%e5%be%b9%e5%ba%95","status":"publish","type":"post","link":"https:\/\/dexall.co.jp\/articles\/?p=2488","title":{"rendered":"Laravel 419\u30a8\u30e9\u30fc\u306e\u5b8c\u5168\u89e3\u6c7a\u30ac\u30a4\u30c9 &#8211; \u539f\u56e0\u3068\u5bfe\u51e6\u6cd5\u3092\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\">419\u30a8\u30e9\u30fc\u3068\u306f\uff1f\u305d\u306e\u57fa\u790e\u77e5\u8b58<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-1\">419\u30a8\u30e9\u30fc\u304c\u767a\u751f\u3059\u308b\u4ed5\u7d44\u307f<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-2\">Laravel\u306e\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u6a5f\u80fd\u3068\u3057\u3066\u306e\u5f79\u5272<\/a>      <\/li>    <\/ul>  <\/li>  <li>    <a href=\"#i-3\">419\u30a8\u30e9\u30fc\u304c\u767a\u751f\u3059\u308b\u4e3b\u306a\u539f\u56e0<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-4\">CSRF\u30c8\u30fc\u30af\u30f3\u306e\u671f\u9650\u5207\u308c<\/a>      <\/li>      <li>        <a href=\"#i-5\">CSRF\u30c8\u30fc\u30af\u30f3\u306e\u4e0d\u4e00\u81f4<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-6\">\u30bb\u30c3\u30b7\u30e7\u30f3\u306e\u554f\u984c<\/a>      <\/li>    <\/ul>  <\/li>  <li>    <a href=\"#i-7\">419\u30a8\u30e9\u30fc\u306e\u5177\u4f53\u7684\u306a\u89e3\u6c7a\u65b9\u6cd5<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-8\">CSRF\u30c8\u30fc\u30af\u30f3\u306e\u6b63\u3057\u3044\u8a2d\u5b9a\u65b9\u6cd5<\/a>      <\/li>      <li>        <a href=\"#i-9\">\u30d5\u30a9\u30fc\u30e0\u9001\u4fe1\u6642\u306e\u5bfe\u51e6\u6cd5<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-10\">Ajax\u30ea\u30af\u30a8\u30b9\u30c8\u3067\u306eCSRF\u5bfe\u5fdc<\/a>      <\/li>    <\/ul>  <\/li>  <li>    <a href=\"#i-11\">419\u30a8\u30e9\u30fc\u306e\u9632\u6b62\u7b56\u3068\u958b\u767a\u306e\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-12\">\u6b63\u3057\u3044CSRF\u30c8\u30fc\u30af\u30f3\u306e\u7ba1\u7406\u65b9\u6cd5<\/a>      <\/li>      <li>        <a href=\"#i-13\">\u30bb\u30c3\u30b7\u30e7\u30f3\u8a2d\u5b9a\u306e\u6700\u9069\u5316<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-14\">\u30c6\u30b9\u30c8\u74b0\u5883\u3067\u306e\u78ba\u8a8d\u65b9\u6cd5<\/a>      <\/li>    <\/ul>  <\/li>  <li class=\"last\">    <a href=\"#i-15\">\u30c8\u30e9\u30d6\u30eb\u30b7\u30e5\u30fc\u30c6\u30a3\u30f3\u30b0\u3068\u5fdc\u7528\u7684\u306a\u5bfe\u51e6\u6cd5<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-16\">\u7279\u6b8a\u306a\u30b1\u30fc\u30b9\u3067\u306e\u5bfe\u5fdc\u65b9\u6cd5<\/a>      <\/li>      <li>        <a href=\"#i-17\">\u8907\u96d1\u306a\u30d5\u30a9\u30fc\u30e0\u51e6\u7406\u3067\u306e\u6ce8\u610f\u70b9<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-18\">SPA\u306e419\u30a8\u30e9\u30fc\u5bfe\u7b56<\/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\">419\u30a8\u30e9\u30fc\u3068\u306f\uff1f\u305d\u306e\u57fa\u790e\u77e5\u8b58<\/h2>\n\n\n\n<p>Laravel\u306b\u304a\u3051\u308b419\u30a8\u30e9\u30fc\u306f\u3001CSRF\u30c8\u30fc\u30af\u30f3\u306e\u691c\u8a3c\u5931\u6557\u6642\u306b\u767a\u751f\u3059\u308b\u91cd\u8981\u306a\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u95a2\u9023\u306e\u30a8\u30e9\u30fc\u3067\u3059\u3002\u3053\u306e\u30a8\u30e9\u30fc\u306f\u30e6\u30fc\u30b6\u30fc\u306e\u5b89\u5168\u3092\u5b88\u308b\u305f\u3081\u306e\u6a5f\u80fd\u3067\u3059\u304c\u3001\u958b\u767a\u6642\u306b\u306f\u982d\u3092\u60a9\u307e\u305b\u308b\u539f\u56e0\u306b\u3082\u306a\u308a\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-1\">419\u30a8\u30e9\u30fc\u304c\u767a\u751f\u3059\u308b\u4ed5\u7d44\u307f<\/h3>\n\n\n\n<p>419\u30a8\u30e9\u30fc\u306f\u3001\u4e3b\u306bLaravel\u306eCSRF\uff08Cross-Site Request Forgery\uff09\u4fdd\u8b77\u6a5f\u80fd\u306b\u3088\u308a\u767a\u751f\u3057\u307e\u3059\u3002\u4ee5\u4e0b\u306e\u3088\u3046\u306a\u6d41\u308c\u3067\u691c\u8a3c\u304c\u884c\u308f\u308c\u307e\u3059\uff1a<\/p>\n\n\n\n<ol class=\"wp-block-list\">\n<li>\u30d5\u30a9\u30fc\u30e0\u751f\u6210\u6642\u306e\u51e6\u7406<\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>Laravel\u304c\u30d5\u30a9\u30fc\u30e0\u3092\u751f\u6210\u3059\u308b\u969b\u3001CSRF\u30c8\u30fc\u30af\u30f3\u3092\u81ea\u52d5\u7684\u306b\u57cb\u3081\u8fbc\u3080<\/li>\n\n\n\n<li>\u3053\u306e\u30c8\u30fc\u30af\u30f3\u306f\u30bb\u30c3\u30b7\u30e7\u30f3\u306b\u4fdd\u5b58\u3055\u308c\u308b\u4e00\u610f\u306e\u5024<\/li>\n\n\n\n<li>\u30d5\u30a9\u30fc\u30e0\u306b\u306f<code>@csrf<\/code>\u30c7\u30a3\u30ec\u30af\u30c6\u30a3\u30d6\u306b\u3088\u308a\u81ea\u52d5\u7684\u306b\u8ffd\u52a0<\/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=\"\">&lt;!-- \u30d5\u30a9\u30fc\u30e0\u3067\u306eCSRF\u30c8\u30fc\u30af\u30f3\u306e\u5b9f\u88c5\u4f8b --&gt;\n&lt;form method=\"POST\" action=\"\/profile\"&gt;\n    @csrf\n    &lt;!-- \u30d5\u30a9\u30fc\u30e0\u306e\u5185\u5bb9 --&gt;\n&lt;\/form&gt;<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li>\u30ea\u30af\u30a8\u30b9\u30c8\u691c\u8a3c\u6642\u306e\u51e6\u7406<\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30e6\u30fc\u30b6\u30fc\u304c\u30d5\u30a9\u30fc\u30e0\u3092\u9001\u4fe1\u3059\u308b\u3068\u3001\u30c8\u30fc\u30af\u30f3\u3082\u4e00\u7dd2\u306b\u9001\u4fe1\u3055\u308c\u308b<\/li>\n\n\n\n<li>Laravel\u306f\u30ea\u30af\u30a8\u30b9\u30c8\u306b\u542b\u307e\u308c\u308b\u30c8\u30fc\u30af\u30f3\u3068\u30bb\u30c3\u30b7\u30e7\u30f3\u306e\u30c8\u30fc\u30af\u30f3\u3092\u6bd4\u8f03<\/li>\n\n\n\n<li>\u4e0d\u4e00\u81f4\u3084\u6b20\u843d\u304c\u3042\u3063\u305f\u5834\u5408\u3001419\u30a8\u30e9\u30fc\u304c\u767a\u751f<\/li>\n<\/ul>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-2\">Laravel\u306e\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u6a5f\u80fd\u3068\u3057\u3066\u306e\u5f79\u5272<\/h3>\n\n\n\n<p>419\u30a8\u30e9\u30fc\u306f\u3001\u4ee5\u4e0b\u306e\u3088\u3046\u306a\u91cd\u8981\u306a\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u6a5f\u80fd\u3092\u63d0\u4f9b\u3057\u3066\u3044\u307e\u3059\uff1a<\/p>\n\n\n\n<ol class=\"wp-block-list\">\n<li>CSRF\u653b\u6483\u304b\u3089\u306e\u4fdd\u8b77<\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u60aa\u610f\u306e\u3042\u308b\u30b5\u30a4\u30c8\u304b\u3089\u306e\u4e0d\u6b63\u306a\u30ea\u30af\u30a8\u30b9\u30c8\u9001\u4fe1\u3092\u9632\u6b62<\/li>\n\n\n\n<li>\u30e6\u30fc\u30b6\u30fc\u306e\u610f\u56f3\u3057\u306a\u3044\u30a2\u30af\u30b7\u30e7\u30f3\u306e\u5b9f\u884c\u3092\u963b\u6b62<\/li>\n\n\n\n<li>\u30bb\u30c3\u30b7\u30e7\u30f3\u30cf\u30a4\u30b8\u30e3\u30c3\u30af\u653b\u6483\u306e\u30ea\u30b9\u30af\u3092\u8efd\u6e1b<\/li>\n<\/ul>\n\n\n\n<ol class=\"wp-block-list\">\n<li>\u30bb\u30c3\u30b7\u30e7\u30f3\u7ba1\u7406\u306e\u6574\u5408\u6027\u78ba\u4fdd<\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30bb\u30c3\u30b7\u30e7\u30f3\u306e\u6709\u52b9\u6027\u3092\u78ba\u8a8d<\/li>\n\n\n\n<li>\u9069\u5207\u306a\u30e6\u30fc\u30b6\u30fc\u8a8d\u8a3c\u306e\u7dad\u6301<\/li>\n\n\n\n<li>\u5b89\u5168\u306a\u30d5\u30a9\u30fc\u30e0\u9001\u4fe1\u306e\u4fdd\u8a3c<\/li>\n<\/ul>\n\n\n\n<ol class=\"wp-block-list\">\n<li>\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u4fe1\u983c\u6027\u5411\u4e0a<\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u6b63\u898f\u306e\u30d5\u30a9\u30fc\u30e0\u9001\u4fe1\u306e\u307f\u3092\u8a31\u53ef<\/li>\n\n\n\n<li>\u30c7\u30fc\u30bf\u306e\u6574\u5408\u6027\u3092\u4fdd\u8b77<\/li>\n\n\n\n<li>\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u76e3\u67fb\u3078\u306e\u5bfe\u5fdc<\/li>\n<\/ul>\n\n\n\n<p>CSRF\u30c8\u30fc\u30af\u30f3\u306e\u8a2d\u5b9a\u306f<code>app\/Http\/Middleware\/VerifyCsrfToken.php<\/code>\u3067\u7ba1\u7406\u3055\u308c\u3001\u5fc5\u8981\u306b\u5fdc\u3058\u3066\u7279\u5b9a\u306eURL\u3092\u9664\u5916\u3059\u308b\u3053\u3068\u3082\u53ef\u80fd\u3067\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=\"\">protected $except = [\n    'api\/*', \/\/ API\u95a2\u9023\u306eURL\u3092\u9664\u5916\n    'webhook\/*' \/\/ Webhook\u3092\u9664\u5916\n];<\/pre>\n\n\n\n<p>\u3053\u306e\u3088\u3046\u306b\u3001419\u30a8\u30e9\u30fc\u306fLaravel\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u3092\u78ba\u4fdd\u3059\u308b\u91cd\u8981\u306a\u6a5f\u80fd\u3068\u3057\u3066\u6a5f\u80fd\u3057\u3066\u3044\u307e\u3059\u3002\u9069\u5207\u306b\u7406\u89e3\u3057\u7ba1\u7406\u3059\u308b\u3053\u3068\u3067\u3001\u5b89\u5168\u3067\u4fe1\u983c\u6027\u306e\u9ad8\u3044Web\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u958b\u767a\u304c\u53ef\u80fd\u3068\u306a\u308a\u307e\u3059\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"i-3\">419\u30a8\u30e9\u30fc\u304c\u767a\u751f\u3059\u308b\u4e3b\u306a\u539f\u56e0<\/h2>\n\n\n\n<p>419\u30a8\u30e9\u30fc\u306f\u69d8\u3005\u306a\u72b6\u6cc1\u3067\u767a\u751f\u3059\u308b\u53ef\u80fd\u6027\u304c\u3042\u308a\u307e\u3059\u304c\u3001\u4e3b\u306b\u4ee5\u4e0b\u306e3\u3064\u306e\u8981\u56e0\u306b\u5206\u985e\u3055\u308c\u307e\u3059\u3002\u305d\u308c\u305e\u308c\u306e\u539f\u56e0\u3092\u7406\u89e3\u3059\u308b\u3053\u3068\u3067\u3001\u52b9\u679c\u7684\u306a\u5bfe\u51e6\u304c\u53ef\u80fd\u3068\u306a\u308a\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-4\">CSRF\u30c8\u30fc\u30af\u30f3\u306e\u671f\u9650\u5207\u308c<\/h3>\n\n\n\n<p>CSRF\u30c8\u30fc\u30af\u30f3\u306b\u306f\u6709\u52b9\u671f\u9650\u304c\u8a2d\u5b9a\u3055\u308c\u3066\u304a\u308a\u3001\u3053\u306e\u671f\u9650\u3092\u8d85\u3048\u308b\u3068419\u30a8\u30e9\u30fc\u304c\u767a\u751f\u3057\u307e\u3059\u3002\u4e3b\u306a\u671f\u9650\u5207\u308c\u306e\u539f\u56e0\u306f\uff1a<\/p>\n\n\n\n<ol class=\"wp-block-list\">\n<li>\u30bb\u30c3\u30b7\u30e7\u30f3\u306e\u30bf\u30a4\u30e0\u30a2\u30a6\u30c8<\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30c7\u30d5\u30a9\u30eb\u30c8\u306e\u8a2d\u5b9a\uff1a120\u5206<\/li>\n\n\n\n<li><code>config\/session.php<\/code>\u3067\u306e\u8a2d\u5b9a\u5024<\/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=\"\">   \/\/ \u30bb\u30c3\u30b7\u30e7\u30f3\u306e\u6709\u52b9\u671f\u9650\u8a2d\u5b9a\n   'lifetime' =&gt; env('SESSION_LIFETIME', 120),<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li>\u30d6\u30e9\u30a6\u30b6\u306e\u9577\u6642\u9593\u653e\u7f6e<\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30bf\u30d6\u3092\u958b\u3044\u305f\u307e\u307e\u9577\u6642\u9593\u7d4c\u904e<\/li>\n\n\n\n<li>\u30bb\u30c3\u30b7\u30e7\u30f3\u30af\u30c3\u30ad\u30fc\u306e\u6d88\u5931<\/li>\n<\/ul>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li>\u30b5\u30fc\u30d0\u30fc\u306e\u518d\u8d77\u52d5<\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30bb\u30c3\u30b7\u30e7\u30f3\u30b9\u30c8\u30ec\u30fc\u30b8\u306e\u30af\u30ea\u30a2<\/li>\n\n\n\n<li>\u4e00\u6642\u7684\u306a\u30bb\u30c3\u30b7\u30e7\u30f3\u60c5\u5831\u306e\u640d\u5931<\/li>\n<\/ul>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-5\">CSRF\u30c8\u30fc\u30af\u30f3\u306e\u4e0d\u4e00\u81f4<\/h3>\n\n\n\n<p>\u30c8\u30fc\u30af\u30f3\u306e\u4e0d\u4e00\u81f4\u306f\u3001\u4ee5\u4e0b\u306e\u3088\u3046\u306a\u72b6\u6cc1\u3067\u767a\u751f\u3057\u307e\u3059\uff1a<\/p>\n\n\n\n<ol class=\"wp-block-list\">\n<li>\u30d5\u30a9\u30fc\u30e0\u9001\u4fe1\u6642\u306e\u554f\u984c<\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>CSRF\u30c8\u30fc\u30af\u30f3\u30d5\u30a3\u30fc\u30eb\u30c9\u306e\u6b20\u843d<\/li>\n\n\n\n<li>\u30c8\u30fc\u30af\u30f3\u5024\u306e\u6539\u3056\u3093\u3084\u640d\u50b7<\/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=\"\">   \/\/ \u6b63\u3057\u3044\u30d5\u30a9\u30fc\u30e0\u5b9f\u88c5\n   &lt;form method=\"POST\"&gt;\n       @csrf  \/\/ \u3053\u308c\u304c\u6b20\u843d\u3059\u308b\u3068419\u30a8\u30e9\u30fc\n       &lt;!-- \u30d5\u30a9\u30fc\u30e0\u306e\u5185\u5bb9 --&gt;\n   &lt;\/form&gt;<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li>Ajax\u30ea\u30af\u30a8\u30b9\u30c8\u306e\u8a2d\u5b9a\u30df\u30b9<\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30d8\u30c3\u30c0\u30fc\u306b\u30c8\u30fc\u30af\u30f3\u304c\u672a\u8a2d\u5b9a<\/li>\n\n\n\n<li>\u8aa4\u3063\u305f\u30c8\u30fc\u30af\u30f3\u5024\u306e\u9001\u4fe1<\/li>\n<\/ul>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li>\u30de\u30eb\u30c1\u30bf\u30d6\u64cd\u4f5c\u306b\u3088\u308b\u554f\u984c<\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u8907\u6570\u30bf\u30d6\u3067\u306e\u540c\u6642\u64cd\u4f5c<\/li>\n\n\n\n<li>\u7570\u306a\u308b\u30bb\u30c3\u30b7\u30e7\u30f3\u3067\u306e\u64cd\u4f5c<\/li>\n<\/ul>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-6\">\u30bb\u30c3\u30b7\u30e7\u30f3\u306e\u554f\u984c<\/h3>\n\n\n\n<p>\u30bb\u30c3\u30b7\u30e7\u30f3\u95a2\u9023\u306e\u554f\u984c\u3082419\u30a8\u30e9\u30fc\u306e\u4e3b\u8981\u306a\u539f\u56e0\u3068\u306a\u308a\u307e\u3059\uff1a<\/p>\n\n\n\n<ol class=\"wp-block-list\">\n<li>\u30bb\u30c3\u30b7\u30e7\u30f3\u8a2d\u5b9a\u306e\u4e0d\u9069\u5207\u306a\u69cb\u6210<\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30c9\u30e9\u30a4\u30d0\u30fc\u306e\u8a2d\u5b9a\u30df\u30b9<\/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=\"\">   \/\/ config\/session.php\n   'driver' =&gt; env('SESSION_DRIVER', 'file'),\n   'domain' =&gt; env('SESSION_DOMAIN', null),<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li>\u30bb\u30c3\u30b7\u30e7\u30f3\u30b9\u30c8\u30ec\u30fc\u30b8\u306e\u554f\u984c<\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30c7\u30a3\u30b9\u30af\u5bb9\u91cf\u306e\u4e0d\u8db3<\/li>\n\n\n\n<li>\u30d1\u30fc\u30df\u30c3\u30b7\u30e7\u30f3\u8a2d\u5b9a\u306e\u8aa4\u308a<\/li>\n\n\n\n<li>\u30b9\u30c8\u30ec\u30fc\u30b8\u3078\u306e\u66f8\u304d\u8fbc\u307f\u30a8\u30e9\u30fc<\/li>\n<\/ul>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li>\u5206\u6563\u30b7\u30b9\u30c6\u30e0\u3067\u306e\u6574\u5408\u6027\u554f\u984c<\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30ed\u30fc\u30c9\u30d0\u30e9\u30f3\u30b5\u30fc\u306e\u8a2d\u5b9a\u30df\u30b9<\/li>\n\n\n\n<li>\u30bb\u30c3\u30b7\u30e7\u30f3\u5171\u6709\u306e\u8a2d\u5b9a\u4e0d\u5099<\/li>\n\n\n\n<li>\u30ad\u30e3\u30c3\u30b7\u30e5\u30b5\u30fc\u30d0\u30fc\u3068\u306e\u540c\u671f\u30a8\u30e9\u30fc<\/li>\n<\/ul>\n\n\n\n<p>\u3053\u308c\u3089\u306e\u554f\u984c\u306b\u5bfe\u3059\u308b\u5177\u4f53\u7684\u306a\u78ba\u8a8d\u65b9\u6cd5\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=\"\">\/\/ \u30bb\u30c3\u30b7\u30e7\u30f3\u306e\u72b6\u614b\u78ba\u8a8d\nif (Session::has('_token')) {\n    \/\/ \u30c8\u30fc\u30af\u30f3\u304c\u5b58\u5728\u3059\u308b\u5834\u5408\u306e\u51e6\u7406\n    $token = Session::token();\n    Log::debug('Current CSRF token: ' . $token);\n} else {\n    \/\/ \u30c8\u30fc\u30af\u30f3\u304c\u5b58\u5728\u3057\u306a\u3044\u5834\u5408\u306e\u51e6\u7406\n    Log::warning('CSRF token is missing');\n}<\/pre>\n\n\n\n<p>419\u30a8\u30e9\u30fc\u306e\u767a\u751f\u539f\u56e0\u3092\u6b63\u78ba\u306b\u7279\u5b9a\u3059\u308b\u3053\u3068\u3067\u3001\u9069\u5207\u306a\u5bfe\u51e6\u65b9\u6cd5\u3092\u9078\u629e\u3059\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002\u6b21\u306e\u30bb\u30af\u30b7\u30e7\u30f3\u3067\u306f\u3001\u3053\u308c\u3089\u306e\u554f\u984c\u306b\u5bfe\u3059\u308b\u5177\u4f53\u7684\u306a\u89e3\u6c7a\u65b9\u6cd5\u306b\u3064\u3044\u3066\u8aac\u660e\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"i-7\">419\u30a8\u30e9\u30fc\u306e\u5177\u4f53\u7684\u306a\u89e3\u6c7a\u65b9\u6cd5<\/h2>\n\n\n\n<p>419\u30a8\u30e9\u30fc\u306b\u906d\u9047\u3057\u305f\u969b\u306e\u5177\u4f53\u7684\u306a\u89e3\u6c7a\u65b9\u6cd5\u3092\u3001\u30b7\u30c1\u30e5\u30a8\u30fc\u30b7\u30e7\u30f3\u5225\u306b\u8a73\u3057\u304f\u89e3\u8aac\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-8\">CSRF\u30c8\u30fc\u30af\u30f3\u306e\u6b63\u3057\u3044\u8a2d\u5b9a\u65b9\u6cd5<\/h3>\n\n\n\n<p>CSRF\u30c8\u30fc\u30af\u30f3\u306e\u8a2d\u5b9a\u306f\u3001Laravel\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u306e\u8981\u3068\u306a\u308a\u307e\u3059\u3002\u4ee5\u4e0b\u306e\u624b\u9806\u3067\u9069\u5207\u306b\u8a2d\u5b9a\u3057\u307e\u3057\u3087\u3046\uff1a<\/p>\n\n\n\n<ol class=\"wp-block-list\">\n<li>\u57fa\u672c\u7684\u306a\u8a2d\u5b9a\u78ba\u8a8d<\/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 \u3067\u306e\u78ba\u8a8d\nprotected $middlewareGroups = [\n    'web' =&gt; [\n        \/\/ VerifyCsrfToken\u30df\u30c9\u30eb\u30a6\u30a7\u30a2\u304c\u542b\u307e\u308c\u3066\u3044\u308b\u304b\u78ba\u8a8d\n        \\App\\Http\\Middleware\\VerifyCsrfToken::class,\n    ],\n];<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li>API\u3084Webhook\u306e\u9664\u5916\u8a2d\u5b9a<\/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\/VerifyCsrfToken.php\nclass VerifyCsrfToken extends Middleware\n{\n    protected $except = [\n        \/\/ CSRF\u30c8\u30fc\u30af\u30f3\u691c\u8a3c\u304c\u4e0d\u8981\u306a\u30eb\u30fc\u30c8\u3092\u6307\u5b9a\n        'api\/*',\n        'webhook\/*'\n    ];\n}<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-9\">\u30d5\u30a9\u30fc\u30e0\u9001\u4fe1\u6642\u306e\u5bfe\u51e6\u6cd5<\/h3>\n\n\n\n<p>\u30d5\u30a9\u30fc\u30e0\u9001\u4fe1\u3067419\u30a8\u30e9\u30fc\u304c\u767a\u751f\u3059\u308b\u5834\u5408\u3001\u4ee5\u4e0b\u306e\u5bfe\u7b56\u3092\u5b9f\u65bd\u3057\u307e\u3059\uff1a<\/p>\n\n\n\n<ol class=\"wp-block-list\">\n<li>\u5168\u3066\u306e\u30d5\u30a9\u30fc\u30e0\u306b@csrf\u30c7\u30a3\u30ec\u30af\u30c6\u30a3\u30d6\u3092\u8ffd\u52a0<\/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;form method=\"POST\" action=\"\/submit\"&gt;\n    @csrf  &lt;!-- \u3053\u308c\u304c\u5fc5\u9808 --&gt;\n    &lt;input type=\"text\" name=\"name\"&gt;\n    &lt;button type=\"submit\"&gt;\u9001\u4fe1&lt;\/button&gt;\n&lt;\/form&gt;<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li>\u30a8\u30e9\u30fc\u767a\u751f\u6642\u306e\u9069\u5207\u306a\u30ea\u30c0\u30a4\u30ec\u30af\u30c8\u51e6\u7406<\/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\/Exceptions\/Handler.php\nuse Illuminate\\Session\\TokenMismatchException;\n\npublic function render($request, Throwable $exception)\n{\n    if ($exception instanceof TokenMismatchException) {\n        return redirect()\n            -&gt;back()\n            -&gt;withInput()\n            -&gt;with('error', '\u30bb\u30c3\u30b7\u30e7\u30f3\u304c\u5207\u308c\u307e\u3057\u305f\u3002\u3082\u3046\u4e00\u5ea6\u304a\u8a66\u3057\u304f\u3060\u3055\u3044\u3002');\n    }\n\n    return parent::render($request, $exception);\n}<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-10\">Ajax\u30ea\u30af\u30a8\u30b9\u30c8\u3067\u306eCSRF\u5bfe\u5fdc<\/h3>\n\n\n\n<p>Ajax\u30ea\u30af\u30a8\u30b9\u30c8\u3067\u306e419\u30a8\u30e9\u30fc\u5bfe\u7b56\u306b\u306f\u3001\u4ee5\u4e0b\u306e\u65b9\u6cd5\u304c\u52b9\u679c\u7684\u3067\u3059\uff1a<\/p>\n\n\n\n<ol class=\"wp-block-list\">\n<li>\u30e1\u30bf\u30bf\u30b0\u306e\u8a2d\u5b9a<\/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;!-- head\u90e8\u5206\u306b\u8ffd\u52a0 --&gt;\n&lt;meta name=\"csrf-token\" content=\"{{ csrf_token() }}\"&gt;<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li>Axios\u3067\u306e\u5b9f\u88c5\u4f8b<\/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=\"\">\/\/ CSRF\u30c8\u30fc\u30af\u30f3\u306e\u8a2d\u5b9a\naxios.defaults.headers.common['X-CSRF-TOKEN'] = document\n    .querySelector('meta[name=\"csrf-token\"]')\n    .getAttribute('content');\n\n\/\/ \u30ea\u30af\u30a8\u30b9\u30c8\u4f8b\nasync function submitData() {\n    try {\n        const response = await axios.post('\/api\/data', {\n            \/\/ \u30ea\u30af\u30a8\u30b9\u30c8\u30c7\u30fc\u30bf\n        });\n        \/\/ \u6210\u529f\u6642\u306e\u51e6\u7406\n    } catch (error) {\n        if (error.response?.status === 419) {\n            \/\/ \u30c8\u30fc\u30af\u30f3\u5207\u308c\u306e\u5834\u5408\u306e\u51e6\u7406\n            location.reload(); \/\/ \u307e\u305f\u306f\u9069\u5207\u306a\u30a8\u30e9\u30fc\u30e1\u30c3\u30bb\u30fc\u30b8\u3092\u8868\u793a\n        }\n    }\n}<\/pre>\n\n\n\n<ol start=\"3\" class=\"wp-block-list\">\n<li>jQuery\u3067\u306e\u5b9f\u88c5\u4f8b<\/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=\"\">$.ajaxSetup({\n    headers: {\n        'X-CSRF-TOKEN': $('meta[name=\"csrf-token\"]').attr('content')\n    }\n});\n\n\/\/ Ajax\u30ea\u30af\u30a8\u30b9\u30c8\u306e\u4f8b\n$.ajax({\n    url: '\/api\/data',\n    method: 'POST',\n    data: formData,\n    error: function(xhr) {\n        if (xhr.status === 419) {\n            alert('\u30bb\u30c3\u30b7\u30e7\u30f3\u304c\u5207\u308c\u307e\u3057\u305f\u3002\u30da\u30fc\u30b8\u3092\u66f4\u65b0\u3057\u307e\u3059\u3002');\n            location.reload();\n        }\n    }\n});<\/pre>\n\n\n\n<p>\u5b9f\u88c5\u6642\u306e\u91cd\u8981\u306a\u30dd\u30a4\u30f3\u30c8\uff1a<\/p>\n\n\n\n<ol class=\"wp-block-list\">\n<li>\u30bb\u30c3\u30b7\u30e7\u30f3\u7ba1\u7406<\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30bb\u30c3\u30b7\u30e7\u30f3\u306e\u6709\u52b9\u671f\u9650\u3092\u9069\u5207\u306b\u8a2d\u5b9a<\/li>\n\n\n\n<li>\u91cd\u8981\u306a\u64cd\u4f5c\u524d\u306b\u30bb\u30c3\u30b7\u30e7\u30f3\u306e\u6709\u52b9\u6027\u3092\u78ba\u8a8d<\/li>\n<\/ul>\n\n\n\n<ol class=\"wp-block-list\">\n<li>\u30a8\u30e9\u30fc\u30cf\u30f3\u30c9\u30ea\u30f3\u30b0<\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30e6\u30fc\u30b6\u30fc\u30d5\u30ec\u30f3\u30c9\u30ea\u30fc\u306a\u30a8\u30e9\u30fc\u30e1\u30c3\u30bb\u30fc\u30b8<\/li>\n\n\n\n<li>\u81ea\u52d5\u30ea\u30c8\u30e9\u30a4\u307e\u305f\u306f\u30ea\u30c0\u30a4\u30ec\u30af\u30c8\u6a5f\u80fd\u306e\u5b9f\u88c5<\/li>\n<\/ul>\n\n\n\n<ol class=\"wp-block-list\">\n<li>\u30c7\u30d0\u30c3\u30b0\u3068\u30e2\u30cb\u30bf\u30ea\u30f3\u30b0<\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30a8\u30e9\u30fc\u30ed\u30b0\u306e\u8a18\u9332<\/li>\n\n\n\n<li>\u767a\u751f\u983b\u5ea6\u306e\u76e3\u8996<\/li>\n<\/ul>\n\n\n\n<p>\u4ee5\u4e0a\u306e\u5bfe\u7b56\u3092\u5b9f\u88c5\u3059\u308b\u3053\u3068\u3067\u3001\u307b\u3068\u3093\u3069\u306e419\u30a8\u30e9\u30fc\u3092\u52b9\u679c\u7684\u306b\u9632\u3050\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002\u7279\u306b\u91cd\u8981\u306a\u306e\u306f\u3001\u30e6\u30fc\u30b6\u30fc\u4f53\u9a13\u3092\u640d\u306a\u308f\u306a\u3044\u3088\u3046\u3001\u30a8\u30e9\u30fc\u767a\u751f\u6642\u306e\u9069\u5207\u306a\u30cf\u30f3\u30c9\u30ea\u30f3\u30b0\u3092\u5b9f\u88c5\u3059\u308b\u3053\u3068\u3067\u3059\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"i-11\">419\u30a8\u30e9\u30fc\u306e\u9632\u6b62\u7b56\u3068\u958b\u767a\u306e\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9<\/h2>\n\n\n\n<p>419\u30a8\u30e9\u30fc\u3092\u672a\u7136\u306b\u9632\u304e\u3001\u5b89\u5b9a\u3057\u305f\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u904b\u7528\u3092\u5b9f\u73fe\u3059\u308b\u305f\u3081\u306e\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-12\">\u6b63\u3057\u3044CSRF\u30c8\u30fc\u30af\u30f3\u306e\u7ba1\u7406\u65b9\u6cd5<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li>\u30bb\u30c3\u30b7\u30e7\u30f3\u8a2d\u5b9a\u306e\u6700\u9069\u5316<\/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    \/\/ \u30bb\u30c3\u30b7\u30e7\u30f3\u306e\u6709\u52b9\u671f\u9650\u3092\u9069\u5207\u306b\u8a2d\u5b9a\n    'lifetime' =&gt; env('SESSION_LIFETIME', 120),\n\n    \/\/ \u30bb\u30ad\u30e5\u30a2\u30af\u30c3\u30ad\u30fc\u306e\u8a2d\u5b9a\n    'secure' =&gt; env('SESSION_SECURE_COOKIE', true),\n    'same_site' =&gt; 'lax',\n\n    \/\/ \u30bb\u30c3\u30b7\u30e7\u30f3\u30c9\u30e9\u30a4\u30d0\u30fc\u306e\u9078\u629e\n    'driver' =&gt; env('SESSION_DRIVER', 'redis'),\n];<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li>\u30df\u30c9\u30eb\u30a6\u30a7\u30a2\u306e\u9069\u5207\u306a\u8a2d\u5b9a\u3068\u7ba1\u7406<\/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\nRoute::middleware(['web'])-&gt;group(function () {\n    \/\/ Web\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u30eb\u30fc\u30c8\u3092CSRF\u4fdd\u8b77\u306e\u5bfe\u8c61\u306b\n    Route::get('\/dashboard', 'DashboardController@index');\n});\n\nRoute::middleware(['api'])-&gt;prefix('api')-&gt;group(function () {\n    \/\/ API\u30eb\u30fc\u30c8\u306fCSRF\u4fdd\u8b77\u304b\u3089\u9664\u5916\n    Route::post('\/webhook', 'WebhookController@handle');\n});<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-13\">\u30bb\u30c3\u30b7\u30e7\u30f3\u8a2d\u5b9a\u306e\u6700\u9069\u5316<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li>\u30bb\u30c3\u30b7\u30e7\u30f3\u30b9\u30c8\u30ec\u30fc\u30b8\u306e\u9078\u629e<\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u672c\u756a\u74b0\u5883\u3067\u306e\u63a8\u5968\u8a2d\u5b9a\uff1a<\/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\nSESSION_DRIVER=redis\nSESSION_CONNECTION=session\nREDIS_CLIENT=predis<\/pre>\n\n\n\n<ul class=\"wp-block-list\">\n<li>Redis\u30bb\u30c3\u30b7\u30e7\u30f3\u306e\u8a2d\u5b9a\uff1a<\/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=\"\">\/\/ config\/database.php\n'redis' =&gt; [\n    'session' =&gt; [\n        'host' =&gt; env('REDIS_HOST', '127.0.0.1'),\n        'password' =&gt; env('REDIS_PASSWORD'),\n        'port' =&gt; env('REDIS_PORT', 6379),\n        'database' =&gt; 1,  \/\/ \u30bb\u30c3\u30b7\u30e7\u30f3\u5c02\u7528\u306e\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\n    ],\n],<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li>\u30bb\u30c3\u30b7\u30e7\u30f3\u7ba1\u7406\u306e\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9<\/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    \/\/ \u30bb\u30c3\u30b7\u30e7\u30f3\u306e\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u8a2d\u5b9a\n    Config::set('session.secure', true);\n\n    \/\/ \u30bb\u30c3\u30b7\u30e7\u30f3ID\u306e\u518d\u751f\u6210\n    if (Auth::check()) {\n        Session::regenerate();\n    }\n}<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-14\">\u30c6\u30b9\u30c8\u74b0\u5883\u3067\u306e\u78ba\u8a8d\u65b9\u6cd5<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li>\u81ea\u52d5\u30c6\u30b9\u30c8\u306e\u5b9f\u88c5<\/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=\"\">\/\/ tests\/Feature\/CsrfProtectionTest.php\nuse Tests\\TestCase;\nuse Illuminate\\Foundation\\Testing\\RefreshDatabase;\n\nclass CsrfProtectionTest extends TestCase\n{\n    use RefreshDatabase;\n\n    public function test_post_request_requires_csrf_token()\n    {\n        $response = $this-&gt;post('\/api\/data', [\n            'test' =&gt; 'value'\n        ]);\n\n        $response-&gt;assertStatus(419);\n    }\n\n    public function test_valid_csrf_token_allows_post_request()\n    {\n        $response = $this-&gt;withHeaders([\n            'X-CSRF-TOKEN' =&gt; csrf_token(),\n        ])-&gt;post('\/api\/data', [\n            'test' =&gt; 'value'\n        ]);\n\n        $response-&gt;assertSuccessful();\n    }\n}<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li>\u958b\u767a\u74b0\u5883\u3067\u306e\u30c7\u30d0\u30c3\u30b0\u30c4\u30fc\u30eb\u8a2d\u5b9a<\/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    if (config('app.debug')) {\n        \/\/ \u30c7\u30d0\u30c3\u30b0\u30e2\u30fc\u30c9\u6642\u306eCSRF\u30c8\u30fc\u30af\u30f3\u691c\u8a3c\u30ed\u30b0\n        $this-&gt;app['events']-&gt;listen('csrf.token.mismatch', function ($event) {\n            \\Log::debug('CSRF token mismatch', [\n                'url' =&gt; request()-&gt;url(),\n                'method' =&gt; request()-&gt;method(),\n                'token' =&gt; request()-&gt;header('X-CSRF-TOKEN'),\n                'session_token' =&gt; session()-&gt;token(),\n            ]);\n        });\n    }\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>\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u5bfe\u7b56\u306e\u57fa\u672c\u539f\u5247<\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u6700\u5c0f\u6a29\u9650\u306e\u539f\u5247\u3092\u9069\u7528<\/li>\n\n\n\n<li>\u5fc5\u8981\u306a\u30eb\u30fc\u30c8\u306e\u307f\u3092CSRF\u4fdd\u8b77\u306e\u5bfe\u8c61\u306b<\/li>\n\n\n\n<li>\u30bb\u30c3\u30b7\u30e7\u30f3\u306e\u9069\u5207\u306a\u6709\u52b9\u671f\u9650\u8a2d\u5b9a<\/li>\n<\/ul>\n\n\n\n<ol class=\"wp-block-list\">\n<li>\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u306e\u6700\u9069\u5316<\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30bb\u30c3\u30b7\u30e7\u30f3\u30c9\u30e9\u30a4\u30d0\u30fc\u306e\u9069\u5207\u306a\u9078\u629e<\/li>\n\n\n\n<li>\u30ad\u30e3\u30c3\u30b7\u30e5\u306e\u52b9\u679c\u7684\u306a\u6d3b\u7528<\/li>\n\n\n\n<li>\u4e0d\u8981\u306a\u30bb\u30c3\u30b7\u30e7\u30f3\u30c7\u30fc\u30bf\u306e\u524a\u9664<\/li>\n<\/ul>\n\n\n\n<ol class=\"wp-block-list\">\n<li>\u30e2\u30cb\u30bf\u30ea\u30f3\u30b0\u3068\u4fdd\u5b88<\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30a8\u30e9\u30fc\u30ed\u30b0\u306e\u5b9a\u671f\u7684\u306a\u78ba\u8a8d<\/li>\n\n\n\n<li>\u30bb\u30c3\u30b7\u30e7\u30f3\u30b9\u30c8\u30ec\u30fc\u30b8\u306e\u76e3\u8996<\/li>\n\n\n\n<li>\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u30e1\u30c8\u30ea\u30af\u30b9\u306e\u53ce\u96c6<\/li>\n<\/ul>\n\n\n\n<p>\u4ee5\u4e0a\u306e\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9\u3092\u9069\u7528\u3059\u308b\u3053\u3068\u3067\u3001419\u30a8\u30e9\u30fc\u306e\u767a\u751f\u3092\u6700\u5c0f\u9650\u306b\u6291\u3048\u3001\u5b89\u5b9a\u3057\u305f\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u904b\u7528\u304c\u53ef\u80fd\u3068\u306a\u308a\u307e\u3059\u3002\u7279\u306b\u672c\u756a\u74b0\u5883\u3067\u306f\u3001\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u3068\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u306e\u30d0\u30e9\u30f3\u30b9\u3092\u8003\u616e\u3057\u306a\u304c\u3089\u3001\u9069\u5207\u306a\u8a2d\u5b9a\u3092\u884c\u3046\u3053\u3068\u304c\u91cd\u8981\u3067\u3059\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"i-15\">\u30c8\u30e9\u30d6\u30eb\u30b7\u30e5\u30fc\u30c6\u30a3\u30f3\u30b0\u3068\u5fdc\u7528\u7684\u306a\u5bfe\u51e6\u6cd5<\/h2>\n\n\n\n<p>\u7279\u6b8a\u306a\u30b1\u30fc\u30b9\u3084\u8907\u96d1\u306a\u5b9f\u88c5\u3067\u306e419\u30a8\u30e9\u30fc\u5bfe\u7b56\u306b\u3064\u3044\u3066\u3001\u5177\u4f53\u7684\u306a\u89e3\u6c7a\u65b9\u6cd5\u3092\u89e3\u8aac\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-16\">\u7279\u6b8a\u306a\u30b1\u30fc\u30b9\u3067\u306e\u5bfe\u5fdc\u65b9\u6cd5<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li>\u30ed\u30fc\u30c9\u30d0\u30e9\u30f3\u30b5\u30fc\u74b0\u5883\u3067\u306e\u5bfe\u7b56<\/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    \/\/ Redis\u3092\u4f7f\u7528\u3057\u3066\u30bb\u30c3\u30b7\u30e7\u30f3\u3092\u5171\u6709\n    'driver' =&gt; env('SESSION_DRIVER', 'redis'),\n\n    \/\/ \u30bb\u30c3\u30b7\u30e7\u30f3Cookie\u306e\u30c9\u30e1\u30a4\u30f3\u8a2d\u5b9a\n    'domain' =&gt; env('SESSION_DOMAIN', '.example.com'),\n\n    \/\/ \u9069\u5207\u306a\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u8a2d\u5b9a\n    'secure' =&gt; true,\n    'same_site' =&gt; 'lax',\n];<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li>WebSockets\u3067\u306e\u5bfe\u5fdc<\/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\/websockets.php\nreturn [\n    'dashboard' =&gt; [\n        'port' =&gt; env('LARAVEL_WEBSOCKETS_PORT', 6001),\n        'middleware' =&gt; [\n            \/\/ WebSocket\u63a5\u7d9a\u6642\u306eCSRF\u691c\u8a3c\u3092\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\n            \\App\\Http\\Middleware\\CustomWebSocketAuthentication::class,\n        ],\n    ],\n];\n\n\/\/ app\/Http\/Middleware\/CustomWebSocketAuthentication.php\npublic function handle($request, Closure $next)\n{\n    if ($this-&gt;isValidSocketConnection($request)) {\n        return $next($request);\n    }\n\n    throw new HttpException(419, 'CSRF token mismatch');\n}<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-17\">\u8907\u96d1\u306a\u30d5\u30a9\u30fc\u30e0\u51e6\u7406\u3067\u306e\u6ce8\u610f\u70b9<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li>\u30d5\u30a1\u30a4\u30eb\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3092\u542b\u3080\u30d5\u30a9\u30fc\u30e0\u306e\u51e6\u7406<\/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\/FileUploadController.php\npublic function upload(Request $request)\n{\n    try {\n        \/\/ \u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u51e6\u7406\u4e2d\u306e\u30bb\u30c3\u30b7\u30e7\u30f3\u5ef6\u9577\n        $this-&gt;extendSessionLifetime();\n\n        \/\/ \u30d5\u30a1\u30a4\u30eb\u306e\u51e6\u7406\n        $path = $request-&gt;file('document')-&gt;store('uploads');\n\n        return response()-&gt;json([\n            'success' =&gt; true,\n            'path' =&gt; $path,\n            \/\/ \u65b0\u3057\u3044CSRF\u30c8\u30fc\u30af\u30f3\u3092\u8fd4\u3059\n            'token' =&gt; csrf_token()\n        ]);\n    } catch (\\Exception $e) {\n        return response()-&gt;json([\n            'error' =&gt; true,\n            'message' =&gt; '\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u306b\u5931\u6557\u3057\u307e\u3057\u305f',\n            'token' =&gt; csrf_token()\n        ], 500);\n    }\n}\n\nprivate function extendSessionLifetime()\n{\n    $lifetime = config('session.lifetime');\n    config(['session.lifetime' =&gt; $lifetime + 30]);\n    session()-&gt;regenerate();\n}<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li>\u30de\u30eb\u30c1\u30b9\u30c6\u30c3\u30d7\u30d5\u30a9\u30fc\u30e0\u306e\u5b9f\u88c5<\/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\/MultiStepFormController.php\nclass MultiStepFormController extends Controller\n{\n    public function processStep(Request $request, $step)\n    {\n        \/\/ \u30bb\u30c3\u30b7\u30e7\u30f3\u306b\u30b9\u30c6\u30c3\u30d7\u30c7\u30fc\u30bf\u3092\u4fdd\u5b58\n        $request-&gt;session()-&gt;put(\"form_step_{$step}\", $request-&gt;all());\n\n        \/\/ \u9032\u6357\u72b6\u6cc1\u306e\u66f4\u65b0\n        $progress = $request-&gt;session()-&gt;get('form_progress', []);\n        $progress[$step] = true;\n        $request-&gt;session()-&gt;put('form_progress', $progress);\n\n        \/\/ \u30bb\u30c3\u30b7\u30e7\u30f3\u306e\u6709\u52b9\u671f\u9650\u3092\u5ef6\u9577\n        $this-&gt;refreshSession();\n\n        return response()-&gt;json([\n            'success' =&gt; true,\n            'next_step' =&gt; $step + 1,\n            'token' =&gt; csrf_token()\n        ]);\n    }\n\n    private function refreshSession()\n    {\n        session()-&gt;regenerate(true);\n        return csrf_token();\n    }\n}<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-18\">SPA\u306e419\u30a8\u30e9\u30fc\u5bfe\u7b56<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li>Token Refresh\u30a4\u30f3\u30bf\u30fc\u30bb\u30d7\u30bf\u30fc\u306e\u5b9f\u88c5<\/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\/js\/services\/axiosSetup.js\nimport axios from 'axios';\n\n\/\/ \u30a4\u30f3\u30bf\u30fc\u30bb\u30d7\u30bf\u30fc\u306e\u8a2d\u5b9a\naxios.interceptors.response.use(\n    response =&gt; response,\n    async error =&gt; {\n        if (error.response?.status === 419) {\n            \/\/ CSRF\u30c8\u30fc\u30af\u30f3\u306e\u518d\u53d6\u5f97\n            const newToken = await refreshCsrfToken();\n\n            \/\/ \u30ea\u30af\u30a8\u30b9\u30c8\u306e\u518d\u8a66\u884c\n            error.config.headers['X-CSRF-TOKEN'] = newToken;\n            return axios.request(error.config);\n        }\n        return Promise.reject(error);\n    }\n);\n\n\/\/ \u30c8\u30fc\u30af\u30f3\u30ea\u30d5\u30ec\u30c3\u30b7\u30e5\u95a2\u6570\nasync function refreshCsrfToken() {\n    const response = await axios.get('\/csrf-token');\n    const token = response.data.token;\n\n    \/\/ \u30e1\u30bf\u30bf\u30b0\u306e\u66f4\u65b0\n    document.querySelector('meta[name=\"csrf-token\"]')\n        .setAttribute('content', token);\n\n    return token;\n}<\/pre>\n\n\n\n<ol start=\"2\" class=\"wp-block-list\">\n<li>Vuex\u3067\u306e\u72b6\u614b\u7ba1\u7406<\/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\/js\/store\/modules\/csrf.js\nconst state = {\n    token: document.querySelector('meta[name=\"csrf-token\"]')\n        ?.getAttribute('content')\n};\n\nconst mutations = {\n    updateToken(state, token) {\n        state.token = token;\n    }\n};\n\nconst actions = {\n    async refreshToken({ commit }) {\n        try {\n            const response = await axios.get('\/api\/refresh-token');\n            const newToken = response.data.token;\n            commit('updateToken', newToken);\n            return newToken;\n        } catch (error) {\n            console.error('Failed to refresh CSRF token:', error);\n            throw error;\n        }\n    }\n};<\/pre>\n\n\n\n<p>\u5b9f\u88c5\u6642\u306e\u91cd\u8981\u306a\u30dd\u30a4\u30f3\u30c8\uff1a<\/p>\n\n\n\n<ol class=\"wp-block-list\">\n<li>\u30a8\u30e9\u30fc\u30cf\u30f3\u30c9\u30ea\u30f3\u30b0<\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u5168\u3066\u306e\u30b1\u30fc\u30b9\u3067\u30e6\u30fc\u30b6\u30fc\u30d5\u30ec\u30f3\u30c9\u30ea\u30fc\u306a\u30a8\u30e9\u30fc\u30e1\u30c3\u30bb\u30fc\u30b8\u3092\u8868\u793a<\/li>\n\n\n\n<li>\u9069\u5207\u306a\u30ed\u30b0\u8a18\u9332\u306b\u3088\u308b\u554f\u984c\u306e\u8ffd\u8de1<\/li>\n\n\n\n<li>\u30b0\u30ec\u30fc\u30b9\u30d5\u30eb\u306a\u30d5\u30a9\u30fc\u30eb\u30d0\u30c3\u30af\u51e6\u7406\u306e\u5b9f\u88c5<\/li>\n<\/ul>\n\n\n\n<ol class=\"wp-block-list\">\n<li>\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u8003\u616e\u4e8b\u9805<\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30c8\u30fc\u30af\u30f3\u306e\u9069\u5207\u306a\u66f4\u65b0\u30bf\u30a4\u30df\u30f3\u30b0<\/li>\n\n\n\n<li>\u30bb\u30c3\u30b7\u30e7\u30f3\u6709\u52b9\u671f\u9650\u306e\u9069\u5207\u306a\u7ba1\u7406<\/li>\n\n\n\n<li>\u8a8d\u8a3c\u72b6\u614b\u306e\u78ba\u5b9f\u306a\u7dad\u6301<\/li>\n<\/ul>\n\n\n\n<ol class=\"wp-block-list\">\n<li>\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u6700\u9069\u5316<\/li>\n<\/ol>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u4e0d\u8981\u306a\u30c8\u30fc\u30af\u30f3\u66f4\u65b0\u306e\u56de\u907f<\/li>\n\n\n\n<li>\u52b9\u7387\u7684\u306a\u30bb\u30c3\u30b7\u30e7\u30f3\u7ba1\u7406<\/li>\n\n\n\n<li>\u30ea\u30af\u30a8\u30b9\u30c8\u306e\u9069\u5207\u306a\u30ad\u30e3\u30c3\u30b7\u30f3\u30b0<\/li>\n<\/ul>\n\n\n\n<p>\u3053\u308c\u3089\u306e\u5fdc\u7528\u7684\u306a\u5bfe\u51e6\u6cd5\u3092\u5b9f\u88c5\u3059\u308b\u3053\u3068\u3067\u3001\u8907\u96d1\u306a\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u3067\u3082419\u30a8\u30e9\u30fc\u3092\u52b9\u679c\u7684\u306b\u7ba1\u7406\u3067\u304d\u307e\u3059\u3002\u7279\u306b\u91cd\u8981\u306a\u306e\u306f\u3001\u30e6\u30fc\u30b6\u30fc\u4f53\u9a13\u3092\u640d\u306a\u308f\u306a\u3044\u3088\u3046\u3001\u30a8\u30e9\u30fc\u304b\u3089\u306e\u56de\u5fa9\u3092\u30b9\u30e0\u30fc\u30ba\u306b\u884c\u3046\u3053\u3068\u3067\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":[12],"tags":[],"class_list":{"0":"post-2488","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\/2488","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=2488"}],"version-history":[{"count":2,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/posts\/2488\/revisions"}],"predecessor-version":[{"id":2490,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/posts\/2488\/revisions\/2490"}],"wp:attachment":[{"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=2488"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=2488"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=2488"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}