{"id":16066,"date":"2025-06-15T14:35:11","date_gmt":"2025-06-15T05:35:11","guid":{"rendered":"https:\/\/jyakusyadansei.com\/?p=16066"},"modified":"2025-06-15T14:35:30","modified_gmt":"2025-06-15T05:35:30","slug":"%f0%9f%90%bb%e2%9d%84%ef%b8%8f-github%e3%81%a8claude-code%e3%81%ae%e6%9c%80%e5%bc%b7%e9%80%a3%e6%90%ba%e3%82%ac%e3%82%a4%e3%83%89-%e5%ae%9f%e8%b7%b5%e3%82%b3%e3%83%9e%e3%83%b3%e3%83%89","status":"publish","type":"post","link":"https:\/\/jyakusyadansei.com\/?p=16066","title":{"rendered":"\u3010\u8ab0\u3067\u3082\u308f\u304b\u308b\uff0f\u5b8c\u5168\u7528\u8a9e\u89e3\u8aac\u3011\ud83d\udc3b\u200d\u2744\ufe0f GitHub\u3068Claude Code\u306e\u6700\u5f37\u9023\u643a\u30ac\u30a4\u30c9 &#8211; \u5b9f\u8df5\u30b3\u30de\u30f3\u30c9\u5b8c\u5168\u7248\u306a\u306e\u3058\u3083"},"content":{"rendered":"<p class=\"whitespace-normal break-words\">\u308f\u3057\u306f\u4eca\u65e5\u3001\u304a\u4e3b\u3089\u306b\u7279\u5225\u306a\u8a71\u3092\u3057\u3088\u3046\u3068\u601d\u3046\u306e\u3058\u3083\u3002GitHub\u3068\u306f\u4f55\u305e\u3084\uff1f\u304b\u3089\u59cb\u307e\u3063\u3066\u3001Claude Code\u306e\u5b9f\u8df5\u7684\u306a\u4f7f\u3044\u65b9\u307e\u3067\u3001\u624b\u53d6\u308a\u8db3\u53d6\u308a\u6559\u3048\u3066\u3044\u304f\u3067\u3059\u305e\u301c\uff01\u7279\u306b\u300c\u5b9f\u969b\u306b\u3069\u3046\u3084\u3063\u3066\u4f7f\u3046\u306e\uff1f\u300d\u3068\u3044\u3046\u7591\u554f\u306b\u30d0\u30c3\u30c1\u30ea\u7b54\u3048\u3066\u3084\u308b\u306e\u3058\u3083\u2728<\/p>\n<h2 class=\"text-xl font-bold text-text-100 mt-1 -mb-0.5\">\ud83c\udf1f \u7b2c1\u7ae0\uff1a\u305d\u3082\u305d\u3082GitHub\u3068\u306f\u4f55\u3058\u3083\uff1f<\/h2>\n<p class=\"whitespace-pre-wrap break-words\">\ud83d\udc3b\u200d\u2744\ufe0f\u300c\u307e\u305a\u306f\u57fa\u672c\u4e2d\u306e\u57fa\u672c\u304b\u3089\u59cb\u3081\u308b\u305e\u3044\u3002GitHub\u3063\u3066\u805e\u3044\u305f\u3053\u3068\u306f\u3042\u308b\u3051\u3069\u3001\u5b9f\u969b\u4f55\u304c\u3067\u304d\u308b\u3093\u3058\u3083\uff1f\u300d \ud83e\uddf8\u300c\u78ba\u304b\u306b\uff01\u3088\u304f\u805e\u304f\u540d\u524d\u3060\u3051\u3069\u3001\u8a73\u3057\u304f\u306f\u77e5\u3089\u306a\u3044\u30af\u30de&#8230;\u300d<\/p>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">\ud83d\udcda GitHub\u306e\u6b63\u4f53\u3092\u66b4\u304f\u306e\u3058\u3083<\/h3>\n<p class=\"whitespace-normal break-words\">GitHub\u3068\u306f\u3001\u4e16\u754c\u6700\u5927\u306e\u30bd\u30fc\u30b9\u30b3\u30fc\u30c9\u7ba1\u7406\u30fb\u5171\u6709\u30d7\u30e9\u30c3\u30c8\u30d5\u30a9\u30fc\u30e0\u306a\u306e\u3058\u3083\u3002\u7c21\u5358\u306b\u8a00\u3048\u3070\u3001\u300c\u30d7\u30ed\u30b0\u30e9\u30de\u30fc\u306e\u305f\u3081\u306eSNS + \u8d85\u9ad8\u6a5f\u80fd\u306a\u30d5\u30a1\u30a4\u30eb\u7ba1\u7406\u30b7\u30b9\u30c6\u30e0\u300d\u307f\u305f\u3044\u306a\u3082\u306e\u3067\u3059\u305e\uff01<\/p>\n<p class=\"whitespace-normal break-words\"><strong>GitHub\u3067\u3067\u304d\u308b\u4e3b\u306a\u3053\u3068<\/strong><\/p>\n<ul class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-disc space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\">\ud83d\udcc1 <strong>\u30b3\u30fc\u30c9\u306e\u4fdd\u5b58\u3068\u7ba1\u7406<\/strong>: \u30af\u30e9\u30a6\u30c9\u4e0a\u3067\u30bd\u30fc\u30b9\u30b3\u30fc\u30c9\u3092\u5b89\u5168\u306b\u4fdd\u7ba1<\/li>\n<li class=\"whitespace-normal break-words\">\ud83d\udc65 <strong>\u30c1\u30fc\u30e0\u3067\u306e\u5354\u529b\u4f5c\u696d<\/strong>: \u8907\u6570\u4eba\u3067\u540c\u3058\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3092\u52b9\u7387\u7684\u306b\u958b\u767a<\/li>\n<li class=\"whitespace-normal break-words\">\ud83d\udd04 <strong>\u30d0\u30fc\u30b8\u30e7\u30f3\u7ba1\u7406<\/strong>: \u30b3\u30fc\u30c9\u306e\u5909\u66f4\u5c65\u6b74\u3092\u8a73\u7d30\u306b\u8ffd\u8de1<\/li>\n<li class=\"whitespace-normal break-words\">\ud83d\udc1b <strong>Issue\u7ba1\u7406<\/strong>: \u30d0\u30b0\u5831\u544a\u3084\u6a5f\u80fd\u8981\u671b\u306e\u6574\u7406<\/li>\n<li class=\"whitespace-normal break-words\">\ud83d\ude80 <strong>\u81ea\u52d5\u5316<\/strong>: CI\/CD\u306b\u3088\u308b\u81ea\u52d5\u30c6\u30b9\u30c8\u30fb\u30c7\u30d7\u30ed\u30a4<\/li>\n<li class=\"whitespace-normal break-words\">\ud83c\udf10 <strong>\u30dd\u30fc\u30c8\u30d5\u30a9\u30ea\u30aa<\/strong>: \u81ea\u5206\u306e\u958b\u767a\u5b9f\u7e3e\u3092\u4e16\u754c\u306b\u516c\u958b<\/li>\n<\/ul>\n<h2 class=\"text-xl font-bold text-text-100 mt-1 -mb-0.5\">\ud83c\udfaf \u7b2c2\u7ae0\uff1a\u500b\u4eba\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3067\u306eGitHub\u6d3b\u7528\u4f8b<\/h2>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">\ud83c\udfe0 \u500b\u4eba\u958b\u767a\u3067GitHub\u3092\u4f7f\u3046\u30e1\u30ea\u30c3\u30c8<\/h3>\n<p class=\"whitespace-normal break-words\"><strong>\ud83d\udcf1 \u500b\u4eba\u30a2\u30d7\u30ea\u958b\u767a\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u4f8b<\/strong><\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code>\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u540d: \u300c\u5bb6\u8a08\u7c3f\u30a2\u30d7\u30ea\u300d\r\n- \u30e1\u30a4\u30f3\u6a5f\u80fd: \u53ce\u652f\u7ba1\u7406\u3001\u30ab\u30c6\u30b4\u30ea\u5206\u6790\u3001\u30b0\u30e9\u30d5\u8868\u793a\r\n- \u4f7f\u7528\u6280\u8853: React, Node.js, MongoDB\r\n- \u958b\u767a\u671f\u9593: 3\u30f6\u6708\r\n\r\nGitHub\u3067\u306e\u7ba1\u7406\u65b9\u6cd5:\r\n\u251c\u2500\u2500 \ud83d\udcc1 frontend\/ (React \u30a2\u30d7\u30ea)\r\n\u251c\u2500\u2500 \ud83d\udcc1 backend\/ (Node.js API)\r\n\u251c\u2500\u2500 \ud83d\udcc1 docs\/ (\u8a2d\u8a08\u66f8\u30fb\u4ed5\u69d8\u66f8)\r\n\u251c\u2500\u2500 \ud83d\udcc4 README.md (\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u8aac\u660e)\r\n\u2514\u2500\u2500 \ud83d\udcc4 CHANGELOG.md (\u66f4\u65b0\u5c65\u6b74)<\/code><\/pre>\n<\/div>\n<\/div>\n<p class=\"whitespace-normal break-words\"><strong>\ud83c\udfa8 \u30dd\u30fc\u30c8\u30d5\u30a9\u30ea\u30aa\u30b5\u30a4\u30c8<\/strong><\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code>\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u540d: \u300c\u500b\u4eba\u30dd\u30fc\u30c8\u30d5\u30a9\u30ea\u30aa\u300d  \r\n- \u81ea\u5206\u306e\u4f5c\u54c1\u96c6\u3092\u7f8e\u3057\u304f\u5c55\u793a\r\n- GitHub Pages\u3067\u7121\u6599\u516c\u958b\r\n- \u5c31\u8077\u6d3b\u52d5\u3067\u306e\u30a2\u30d4\u30fc\u30eb\u6750\u6599\u306b\r\n\r\n\u30d5\u30a9\u30eb\u30c0\u69cb\u6210:\r\n\u251c\u2500\u2500 \ud83d\udcc1 src\/ (\u30bd\u30fc\u30b9\u30b3\u30fc\u30c9)\r\n\u251c\u2500\u2500 \ud83d\udcc1 assets\/ (\u753b\u50cf\u30fbCSS)\r\n\u251c\u2500\u2500 \ud83d\udcc1 projects\/ (\u4f5c\u54c1\u30c7\u30fc\u30bf)\r\n\u2514\u2500\u2500 \ud83d\udcc4 index.html (\u30e1\u30a4\u30f3\u30da\u30fc\u30b8)<\/code><\/pre>\n<\/div>\n<\/div>\n<h2 class=\"text-xl font-bold text-text-100 mt-1 -mb-0.5\">\ud83d\udc65 \u7b2c3\u7ae0\uff1a\u30c1\u30fc\u30e0\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3067\u306eGitHub\u5a01\u529b<\/h2>\n<p class=\"whitespace-normal break-words\"><strong>\ud83c\udfe2 \u4f01\u696d\u3067\u306e\u958b\u767a\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u4f8b<\/strong><\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code>\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u540d: \u300cEC\u30b5\u30a4\u30c8\u30ea\u30cb\u30e5\u30fc\u30a2\u30eb\u300d\r\n\u30c1\u30fc\u30e0\u69cb\u6210:\r\n- \u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u958b\u767a\u8005: 3\u540d\r\n- \u30d0\u30c3\u30af\u30a8\u30f3\u30c9\u958b\u767a\u8005: 2\u540d  \r\n- \u30c7\u30b6\u30a4\u30ca\u30fc: 1\u540d\r\n- \u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u30de\u30cd\u30fc\u30b8\u30e3\u30fc: 1\u540d\r\n\r\nGitHub\u3067\u306e\u5f79\u5272\u5206\u62c5:\r\n\u251c\u2500\u2500 \ud83c\udf3f main \u30d6\u30e9\u30f3\u30c1 (\u672c\u756a\u74b0\u5883)\r\n\u251c\u2500\u2500 \ud83c\udf3f develop \u30d6\u30e9\u30f3\u30c1 (\u958b\u767a\u74b0\u5883)  \r\n\u251c\u2500\u2500 \ud83c\udf3f feature\/user-auth (\u30e6\u30fc\u30b6\u30fc\u8a8d\u8a3c\u6a5f\u80fd)\r\n\u251c\u2500\u2500 \ud83c\udf3f feature\/payment (\u6c7a\u6e08\u6a5f\u80fd)\r\n\u251c\u2500\u2500 \ud83c\udf3f feature\/admin-panel (\u7ba1\u7406\u753b\u9762)\r\n\u2514\u2500\u2500 \ud83c\udf3f hotfix\/login-bug (\u7dca\u6025\u30d0\u30b0\u4fee\u6b63)<\/code><\/pre>\n<\/div>\n<\/div>\n<h2 class=\"text-xl font-bold text-text-100 mt-1 -mb-0.5\">\ud83d\ude80 \u7b2c4\u7ae0\uff1aGitHub\u30a2\u30ab\u30a6\u30f3\u30c8\u4f5c\u6210\u304b\u3089API\u9023\u643a\u307e\u3067<\/h2>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">\ud83d\udcdd \u30b9\u30c6\u30c3\u30d71\uff1aGitHub\u30a2\u30ab\u30a6\u30f3\u30c8\u4f5c\u6210<\/h3>\n<p class=\"whitespace-normal break-words\"><strong>\u30a2\u30ab\u30a6\u30f3\u30c8\u4f5c\u6210\u624b\u9806<\/strong><\/p>\n<ol class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-decimal space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\"><strong>GitHub\u516c\u5f0f\u30b5\u30a4\u30c8\u306b\u30a2\u30af\u30bb\u30b9<\/strong>\n<ul class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-disc space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\"><a class=\"underline\" href=\"https:\/\/github.com\">https:\/\/github.com<\/a> \u306b\u30a2\u30af\u30bb\u30b9<\/li>\n<li class=\"whitespace-normal break-words\">\u300cSign up\u300d\u30dc\u30bf\u30f3\u3092\u30af\u30ea\u30c3\u30af<\/li>\n<\/ul>\n<\/li>\n<li class=\"whitespace-normal break-words\"><strong>\u57fa\u672c\u60c5\u5831\u306e\u5165\u529b<\/strong>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code>Username: \u3042\u306a\u305f\u306e\u597d\u304d\u306a\u30e6\u30fc\u30b6\u30fc\u540d\uff08\u82f1\u6570\u5b57\u30fb\u30cf\u30a4\u30d5\u30f3\uff09\r\nEmail: \u666e\u6bb5\u4f7f\u3046\u30e1\u30fc\u30eb\u30a2\u30c9\u30ec\u30b9  \r\nPassword: \u5f37\u529b\u306a\u30d1\u30b9\u30ef\u30fc\u30c9\uff08\u5927\u6587\u5b57\u30fb\u5c0f\u6587\u5b57\u30fb\u6570\u5b57\u30fb\u8a18\u53f7\uff09<\/code><\/pre>\n<\/div>\n<\/div>\n<\/li>\n<li class=\"whitespace-normal break-words\"><strong>\u30d7\u30e9\u30f3\u9078\u629e<\/strong>\n<ul class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-disc space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\">\ud83c\udd93 <strong>Free<\/strong>: \u500b\u4eba\u5229\u7528\u306a\u3089\u5341\u5206\uff08\u30d1\u30d6\u30ea\u30c3\u30af\u30ea\u30dd\u30b8\u30c8\u30ea\u7121\u5236\u9650\uff09<\/li>\n<li class=\"whitespace-normal break-words\">\ud83d\udcb0 <strong>Pro<\/strong>: \u30d7\u30e9\u30a4\u30d9\u30fc\u30c8\u30ea\u30dd\u30b8\u30c8\u30ea\u306e\u9ad8\u5ea6\u306a\u6a5f\u80fd\u304c\u5fc5\u8981\u306a\u5834\u5408<\/li>\n<\/ul>\n<\/li>\n<\/ol>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">\ud83d\udd11 \u30b9\u30c6\u30c3\u30d72\uff1aSSH\u9375\u306e\u8a2d\u5b9a<\/h3>\n<p class=\"whitespace-normal break-words\"><strong>SSH\u9375\u751f\u6210\u624b\u9806<\/strong><\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"text-text-500 text-xs p-3.5 pb-0\">bash<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code class=\"language-bash\"><span class=\"token\"># 1. SSH\u9375\u3092\u751f\u6210\uff08\u30e1\u30fc\u30eb\u30a2\u30c9\u30ec\u30b9\u306f\u81ea\u5206\u306e\u3082\u306e\u306b\u5909\u66f4\uff09<\/span>\r\nssh-keygen -t ed25519 -C <span class=\"token\">\"your-email@example.com\"<\/span>\r\n\r\n<span class=\"token\"># 2. \u30a8\u30f3\u30bf\u30fc\u30ad\u30fc\u30923\u56de\u62bc\u3059\uff08\u30c7\u30d5\u30a9\u30eb\u30c8\u8a2d\u5b9a\u3067OK\uff09<\/span>\r\nEnter <span class=\"token\">file<\/span> <span class=\"token\">in<\/span> <span class=\"token\">which<\/span> to save the key: <span class=\"token\">[<\/span>Enter<span class=\"token\">]<\/span>\r\nEnter passphrase <span class=\"token\">(<\/span>empty <span class=\"token\">for<\/span> no passphrase<span class=\"token\">)<\/span>: <span class=\"token\">[<\/span>Enter<span class=\"token\">]<\/span>  \r\nEnter same passphrase again: <span class=\"token\">[<\/span>Enter<span class=\"token\">]<\/span>\r\n\r\n<span class=\"token\"># 3. \u516c\u958b\u9375\u306e\u5185\u5bb9\u3092\u30af\u30ea\u30c3\u30d7\u30dc\u30fc\u30c9\u306b\u30b3\u30d4\u30fc<\/span>\r\n<span class=\"token\"># Mac \u306e\u5834\u5408<\/span>\r\npbcopy <span class=\"token\">&lt;<\/span> ~\/.ssh\/id_ed25519.pub\r\n\r\n<span class=\"token\"># Windows \u306e\u5834\u5408  <\/span>\r\nclip <span class=\"token\">&lt;<\/span> ~\/.ssh\/id_ed25519.pub\r\n\r\n<span class=\"token\"># Linux \u306e\u5834\u5408<\/span>\r\nxclip -sel clip <span class=\"token\">&lt;<\/span> ~\/.ssh\/id_ed25519.pub<\/code><\/pre>\n<\/div>\n<\/div>\n<p class=\"whitespace-normal break-words\"><strong>GitHub\u306bSSH\u9375\u3092\u767b\u9332<\/strong><\/p>\n<ol class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-decimal space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\">GitHub \u2192 Settings \u2192 SSH and GPG keys<\/li>\n<li class=\"whitespace-normal break-words\">\u300cNew SSH key\u300d\u3092\u30af\u30ea\u30c3\u30af<\/li>\n<li class=\"whitespace-normal break-words\">Title: \u300cMy Computer\u300d\u306a\u3069\u8b58\u5225\u3067\u304d\u308b\u540d\u524d<\/li>\n<li class=\"whitespace-normal break-words\">Key: \u30b3\u30d4\u30fc\u3057\u305f\u516c\u958b\u9375\u3092\u30da\u30fc\u30b9\u30c8<\/li>\n<li class=\"whitespace-normal break-words\">\u300cAdd SSH key\u300d\u3092\u30af\u30ea\u30c3\u30af<\/li>\n<\/ol>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">\ud83d\udcc1 \u30b9\u30c6\u30c3\u30d73\uff1a\u6700\u521d\u306e\u30ea\u30dd\u30b8\u30c8\u30ea\u4f5c\u6210\u3068\u57fa\u672c\u64cd\u4f5c<\/h3>\n<p class=\"whitespace-normal break-words\"><strong>GitHub\u4e0a\u3067\u30ea\u30dd\u30b8\u30c8\u30ea\u4f5c\u6210<\/strong><\/p>\n<ol class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-decimal space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\">GitHub \u2192 \u53f3\u4e0a\u306e\u300c+\u300d\u2192 \u300cNew repository\u300d<\/li>\n<li class=\"whitespace-normal break-words\">Repository name: <code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">my-first-project<\/code><\/li>\n<li class=\"whitespace-normal break-words\">Description: \u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306e\u8aac\u660e\uff08\u4efb\u610f\uff09<\/li>\n<li class=\"whitespace-normal break-words\">Public\/Private \u3092\u9078\u629e<\/li>\n<li class=\"whitespace-normal break-words\">\u300cAdd a README file\u300d\u306b\u30c1\u30a7\u30c3\u30af<\/li>\n<li class=\"whitespace-normal break-words\">\u300cCreate repository\u300d\u3092\u30af\u30ea\u30c3\u30af<\/li>\n<\/ol>\n<p class=\"whitespace-normal break-words\"><strong>\u30ed\u30fc\u30ab\u30eb\u3067\u306e\u57fa\u672c\u64cd\u4f5c<\/strong><\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"text-text-500 text-xs p-3.5 pb-0\">bash<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code class=\"language-bash\"><span class=\"token\"># GitHub\u304b\u3089\u30ed\u30fc\u30ab\u30ebPC\u306b\u30b3\u30d4\u30fc<\/span>\r\n<span class=\"token\">git<\/span> clone git@github.com:username\/my-first-project.git\r\n\r\n<span class=\"token\"># \u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u306b\u79fb\u52d5<\/span>\r\n<span class=\"token\">cd<\/span> my-first-project\r\n\r\n<span class=\"token\"># \u30d5\u30a1\u30a4\u30eb\u3092\u7de8\u96c6<\/span>\r\n<span class=\"token\">echo<\/span> <span class=\"token\">\"Hello, GitHub!\"<\/span> <span class=\"token\">&gt;<\/span> hello.txt\r\n\r\n<span class=\"token\"># \u5909\u66f4\u3092\u30b9\u30c6\u30fc\u30b8\u30f3\u30b0\uff08\u6e96\u5099\uff09<\/span>\r\n<span class=\"token\">git<\/span> <span class=\"token\">add<\/span> hello.txt\r\n\r\n<span class=\"token\"># \u30b3\u30df\u30c3\u30c8\uff08\u5909\u66f4\u3092\u8a18\u9332\uff09<\/span>\r\n<span class=\"token\">git<\/span> commit -m <span class=\"token\">\"Add hello.txt file\"<\/span>\r\n\r\n<span class=\"token\"># GitHub\u306b\u30d7\u30c3\u30b7\u30e5\uff08\u5909\u66f4\u3092\u9001\u4fe1\uff09<\/span>\r\n<span class=\"token\">git<\/span> push origin main<\/code><\/pre>\n<\/div>\n<\/div>\n<p class=\"whitespace-normal break-words\">\ud83d\udc3b\u200d\u2744\ufe0f\u300c\u3053\u308c\u3067\u57fa\u672c\u7684\u306aGit\u306e\u64cd\u4f5c\u306f\u899a\u3048\u305f\u305e\u3044\uff01\u6b21\u306f\u3044\u3088\u3044\u3088Claude Code\u306e\u51fa\u756a\u3058\u3083\u300d<\/p>\n<h2 class=\"text-xl font-bold text-text-100 mt-1 -mb-0.5\">\ud83e\udd16 \u7b2c5\u7ae0\uff1aClaude Code \u5b8c\u5168\u6d3b\u7528\u30ac\u30a4\u30c9<\/h2>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">\ud83d\udee0\ufe0f Claude Code \u30bb\u30c3\u30c8\u30a2\u30c3\u30d7<\/h3>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"text-text-500 text-xs p-3.5 pb-0\">bash<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code class=\"language-bash\"><span class=\"token\"># Node.js \u304c\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3055\u308c\u3066\u3044\u308b\u3053\u3068\u3092\u78ba\u8a8d<\/span>\r\n<span class=\"token\">node<\/span> --version\r\n<span class=\"token\">npm<\/span> --version\r\n\r\n<span class=\"token\"># Claude Code \u3092\u30b0\u30ed\u30fc\u30d0\u30eb\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb<\/span>\r\n<span class=\"token\">npm<\/span> <span class=\"token\">install<\/span> -g @anthropic-ai\/claude-code\r\n\r\n<span class=\"token\"># \u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u3067\u8d77\u52d5<\/span>\r\n<span class=\"token\">cd<\/span> your-project\r\nclaude\r\n\r\n<span class=\"token\"># \u521d\u56de\u8d77\u52d5\u6642\u306e\u8a8d\u8a3c\u753b\u9762\u3067Anthropic\u30a2\u30ab\u30a6\u30f3\u30c8\u306b\u30ed\u30b0\u30a4\u30f3<\/span><\/code><\/pre>\n<\/div>\n<\/div>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">\ud83d\udccb Claude Code GitHub\u30b3\u30de\u30f3\u30c9\u4e00\u89a7\u8868<\/h3>\n<p class=\"whitespace-normal break-words\">\ud83d\udc3b\u200d\u2744\ufe0f\u300c\u3053\u3053\u304c\u4eca\u65e5\u306e\u672c\u547d\u3058\u3083\uff01Claude Code\u3067GitHub\u3092\u64cd\u4f5c\u3059\u308b\u5b9f\u7528\u7684\u306a\u30b3\u30de\u30f3\u30c9\u96c6\u3092\u5927\u516c\u958b\u3059\u308b\u305e\u3044\u300d<\/p>\n<h4 class=\"text-base font-bold text-text-100 mt-1\">\ud83d\udd0d <strong>\u30ea\u30dd\u30b8\u30c8\u30ea\u5206\u6790\u30fb\u8abf\u67fb\u7cfb<\/strong><\/h4>\n<div class=\"table-outer\"><table class=\"bg-bg-100 min-w-full border-separate border-spacing-0 text-sm leading-[1.88888] whitespace-normal\">\n<thead class=\"border-b-border-100\/50 border-b-[0.5px] text-left\">\n<tr class=\"[tbody&gt;&amp;]:odd:bg-bg-500\/10\">\n<th class=\"text-text-000 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] font-400 px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u30b3\u30de\u30f3\u30c9\u4f8b<\/th>\n<th class=\"text-text-000 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] font-400 px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u5b9f\u884c\u3055\u308c\u308b\u51e6\u7406<\/th>\n<th class=\"text-text-000 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] font-400 px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u4f7f\u7528\u5834\u9762<\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr class=\"[tbody&gt;&amp;]:odd:bg-bg-500\/10\">\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">claude \"\u3053\u306e\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306e\u69cb\u9020\u3092\u6559\u3048\u3066\"<\/code><\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u30d5\u30a1\u30a4\u30eb\u69cb\u9020\u3092\u5206\u6790\u3057\u3001\u4e3b\u8981\u6a5f\u80fd\u3092\u8aac\u660e<\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u65b0\u3057\u3044\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306b\u53c2\u52a0\u3057\u305f\u6642<\/td>\n<\/tr>\n<tr class=\"[tbody&gt;&amp;]:odd:bg-bg-500\/10\">\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">claude \"\u6700\u8fd1\u306e\u30b3\u30df\u30c3\u30c8\u5c65\u6b74\u30925\u4ef6\u8868\u793a\u3057\u3066\"<\/code><\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">git log --oneline -5<\/code> \u3092\u5b9f\u884c<\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u6700\u65b0\u306e\u5909\u66f4\u5185\u5bb9\u3092\u78ba\u8a8d\u3057\u305f\u3044\u6642<\/td>\n<\/tr>\n<tr class=\"[tbody&gt;&amp;]:odd:bg-bg-500\/10\">\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">claude \"\u30d0\u30b0\u95a2\u9023\u306e\u30b3\u30df\u30c3\u30c8\u3092\u63a2\u3057\u3066\"<\/code><\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">git log --grep=\"bug|fix\"<\/code> \u3067\u691c\u7d22<\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u904e\u53bb\u306e\u30d0\u30b0\u4fee\u6b63\u3092\u8abf\u3079\u305f\u3044\u6642<\/td>\n<\/tr>\n<tr class=\"[tbody&gt;&amp;]:odd:bg-bg-500\/10\">\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">claude \"12\u6708\u4ee5\u964d\u306e\u5909\u66f4\u3092\u8abf\u3079\u3066\"<\/code><\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">git log --since=\"2023-12-01\"<\/code> \u3092\u5b9f\u884c<\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u7279\u5b9a\u671f\u9593\u306e\u5909\u66f4\u5c65\u6b74\u3092\u78ba\u8a8d<\/td>\n<\/tr>\n<tr class=\"[tbody&gt;&amp;]:odd:bg-bg-500\/10\">\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">claude \"\u3053\u306e\u30d5\u30a1\u30a4\u30eb\u3092\u6700\u5f8c\u306b\u5909\u66f4\u3057\u305f\u4eba\u306f\uff1f\"<\/code><\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">git log -1 --pretty=format:\"%an\" filename<\/code><\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u8cac\u4efb\u8005\u3092\u78ba\u8a8d\u3057\u305f\u3044\u6642<\/td>\n<\/tr>\n<\/tbody>\n<\/table><\/div>\n<h4 class=\"text-base font-bold text-text-100 mt-1\">\ud83d\udcdd <strong>\u30b3\u30df\u30c3\u30c8\u30fb\u30d7\u30c3\u30b7\u30e5\u7cfb<\/strong><\/h4>\n<div class=\"table-outer\"><table class=\"bg-bg-100 min-w-full border-separate border-spacing-0 text-sm leading-[1.88888] whitespace-normal\">\n<thead class=\"border-b-border-100\/50 border-b-[0.5px] text-left\">\n<tr class=\"[tbody&gt;&amp;]:odd:bg-bg-500\/10\">\n<th class=\"text-text-000 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] font-400 px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u30b3\u30de\u30f3\u30c9\u4f8b<\/th>\n<th class=\"text-text-000 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] font-400 px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u5b9f\u884c\u3055\u308c\u308b\u51e6\u7406<\/th>\n<th class=\"text-text-000 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] font-400 px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u4f7f\u7528\u5834\u9762<\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr class=\"[tbody&gt;&amp;]:odd:bg-bg-500\/10\">\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">claude \"\u5909\u66f4\u3092\u30b3\u30df\u30c3\u30c8\u3057\u3066\"<\/code><\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u5909\u66f4\u5206\u6790\u2192\u30b3\u30df\u30c3\u30c8\u30e1\u30c3\u30bb\u30fc\u30b8\u751f\u6210\u2192\u30b3\u30df\u30c3\u30c8\u5b9f\u884c<\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u5b9a\u578b\u7684\u306a\u30b3\u30df\u30c3\u30c8\u4f5c\u696d<\/td>\n<\/tr>\n<tr class=\"[tbody&gt;&amp;]:odd:bg-bg-500\/10\">\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">claude \"Conventional Commits\u3067\u30b3\u30df\u30c3\u30c8\u3057\u3066\"<\/code><\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u898f\u7d04\u306b\u5f93\u3063\u305f\u30e1\u30c3\u30bb\u30fc\u30b8\u3067\u81ea\u52d5\u30b3\u30df\u30c3\u30c8<\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u30c1\u30fc\u30e0\u958b\u767a\u3067\u306e\u6a19\u6e96\u5316<\/td>\n<\/tr>\n<tr class=\"[tbody&gt;&amp;]:odd:bg-bg-500\/10\">\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">claude \"\u5168\u3066\u306e\u5909\u66f4\u3092\u30b9\u30c6\u30fc\u30b8\u3057\u3066\u30b3\u30df\u30c3\u30c8\"<\/code><\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">git add .<\/code> \u2192 \u30b3\u30df\u30c3\u30c8\u30e1\u30c3\u30bb\u30fc\u30b8\u751f\u6210\u2192\u30b3\u30df\u30c3\u30c8<\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u4e00\u62ec\u3067\u30b3\u30df\u30c3\u30c8\u3057\u305f\u3044\u6642<\/td>\n<\/tr>\n<tr class=\"[tbody&gt;&amp;]:odd:bg-bg-500\/10\">\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">claude \"\u30b3\u30df\u30c3\u30c8\u3057\u3066\u30d7\u30c3\u30b7\u30e5\u3057\u3066\"<\/code><\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u30b3\u30df\u30c3\u30c8\u2192 <code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">git push origin main<\/code> \u3092\u5b9f\u884c<\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u30ef\u30f3\u30b9\u30c8\u30c3\u30d7\u3067\u516c\u958b\u3057\u305f\u3044\u6642<\/td>\n<\/tr>\n<tr class=\"[tbody&gt;&amp;]:odd:bg-bg-500\/10\">\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">claude \"\u76f4\u524d\u306e\u30b3\u30df\u30c3\u30c8\u30e1\u30c3\u30bb\u30fc\u30b8\u3092\u4fee\u6b63\u3057\u3066\"<\/code><\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">git commit --amend<\/code> \u3067\u4fee\u6b63<\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u30b3\u30df\u30c3\u30c8\u30e1\u30c3\u30bb\u30fc\u30b8\u306e\u8aa4\u5b57\u3092\u76f4\u3057\u305f\u3044\u6642<\/td>\n<\/tr>\n<\/tbody>\n<\/table><\/div>\n<h4 class=\"text-base font-bold text-text-100 mt-1\">\ud83c\udf3f <strong>\u30d6\u30e9\u30f3\u30c1\u64cd\u4f5c\u7cfb<\/strong><\/h4>\n<div class=\"table-outer\"><table class=\"bg-bg-100 min-w-full border-separate border-spacing-0 text-sm leading-[1.88888] whitespace-normal\">\n<thead class=\"border-b-border-100\/50 border-b-[0.5px] text-left\">\n<tr class=\"[tbody&gt;&amp;]:odd:bg-bg-500\/10\">\n<th class=\"text-text-000 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] font-400 px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u30b3\u30de\u30f3\u30c9\u4f8b<\/th>\n<th class=\"text-text-000 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] font-400 px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u5b9f\u884c\u3055\u308c\u308b\u51e6\u7406<\/th>\n<th class=\"text-text-000 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] font-400 px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u4f7f\u7528\u5834\u9762<\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr class=\"[tbody&gt;&amp;]:odd:bg-bg-500\/10\">\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">claude \"feature-login\u30d6\u30e9\u30f3\u30c1\u3092\u4f5c\u6210\u3057\u3066\"<\/code><\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">git checkout -b feature-login<\/code><\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u65b0\u6a5f\u80fd\u958b\u767a\u958b\u59cb\u6642<\/td>\n<\/tr>\n<tr class=\"[tbody&gt;&amp;]:odd:bg-bg-500\/10\">\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">claude \"main\u30d6\u30e9\u30f3\u30c1\u306b\u623b\u3063\u3066\"<\/code><\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">git checkout main<\/code><\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u30e1\u30a4\u30f3\u30d6\u30e9\u30f3\u30c1\u306b\u623b\u308a\u305f\u3044\u6642<\/td>\n<\/tr>\n<tr class=\"[tbody&gt;&amp;]:odd:bg-bg-500\/10\">\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">claude \"feature-login\u3092main\u306b\u30de\u30fc\u30b8\u3057\u3066\"<\/code><\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u30de\u30fc\u30b8\u51e6\u7406\u3068\u30b3\u30f3\u30d5\u30ea\u30af\u30c8\u89e3\u6c7a<\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u6a5f\u80fd\u5b8c\u6210\u5f8c\u306e\u7d71\u5408<\/td>\n<\/tr>\n<tr class=\"[tbody&gt;&amp;]:odd:bg-bg-500\/10\">\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">claude \"\u4f7f\u308f\u306a\u3044\u30d6\u30e9\u30f3\u30c1\u3092\u524a\u9664\u3057\u3066\"<\/code><\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u4e0d\u8981\u306a\u30ed\u30fc\u30ab\u30eb\u30d6\u30e9\u30f3\u30c1\u3092\u7279\u5b9a\u3057\u3066\u524a\u9664<\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u30d6\u30e9\u30f3\u30c1\u6574\u7406<\/td>\n<\/tr>\n<tr class=\"[tbody&gt;&amp;]:odd:bg-bg-500\/10\">\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">claude \"\u30ea\u30e2\u30fc\u30c8\u30d6\u30e9\u30f3\u30c1\u3092\u66f4\u65b0\u3057\u3066\"<\/code><\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">git fetch origin<\/code> \u3067\u6700\u65b0\u60c5\u5831\u3092\u53d6\u5f97<\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u4ed6\u306e\u4eba\u306e\u5909\u66f4\u3092\u78ba\u8a8d\u3057\u305f\u3044\u6642<\/td>\n<\/tr>\n<\/tbody>\n<\/table><\/div>\n<h4 class=\"text-base font-bold text-text-100 mt-1\">\ud83d\udd04 <strong>\u540c\u671f\u30fb\u66f4\u65b0\u7cfb<\/strong><\/h4>\n<div class=\"table-outer\"><table class=\"bg-bg-100 min-w-full border-separate border-spacing-0 text-sm leading-[1.88888] whitespace-normal\">\n<thead class=\"border-b-border-100\/50 border-b-[0.5px] text-left\">\n<tr class=\"[tbody&gt;&amp;]:odd:bg-bg-500\/10\">\n<th class=\"text-text-000 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] font-400 px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u30b3\u30de\u30f3\u30c9\u4f8b<\/th>\n<th class=\"text-text-000 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] font-400 px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u5b9f\u884c\u3055\u308c\u308b\u51e6\u7406<\/th>\n<th class=\"text-text-000 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] font-400 px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u4f7f\u7528\u5834\u9762<\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr class=\"[tbody&gt;&amp;]:odd:bg-bg-500\/10\">\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">claude \"\u30ea\u30e2\u30fc\u30c8\u304b\u3089\u6700\u65b0\u7248\u3092\u53d6\u5f97\u3057\u3066\"<\/code><\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">git pull origin main<\/code> \u3092\u5b9f\u884c<\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u4ed6\u306e\u4eba\u306e\u5909\u66f4\u3092\u53d6\u308a\u8fbc\u307f\u305f\u3044\u6642<\/td>\n<\/tr>\n<tr class=\"[tbody&gt;&amp;]:odd:bg-bg-500\/10\">\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">claude \"\u30b3\u30f3\u30d5\u30ea\u30af\u30c8\u3092\u89e3\u6c7a\u3057\u3066\"<\/code><\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u30de\u30fc\u30b8\u30b3\u30f3\u30d5\u30ea\u30af\u30c8\u306e\u81ea\u52d5\u89e3\u6c7a\u3092\u8a66\u884c<\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u30de\u30fc\u30b8\u6642\u306e\u7af6\u5408\u89e3\u6c7a<\/td>\n<\/tr>\n<tr class=\"[tbody&gt;&amp;]:odd:bg-bg-500\/10\">\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">claude \"\u30ed\u30fc\u30ab\u30eb\u306e\u5909\u66f4\u3092\u4e00\u6642\u4fdd\u5b58\u3057\u3066\"<\/code><\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">git stash<\/code> \u3067\u5909\u66f4\u3092\u9000\u907f<\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u5225\u4f5c\u696d\u306e\u305f\u3081\u306b\u4e00\u6642\u7684\u306b\u9000\u907f<\/td>\n<\/tr>\n<tr class=\"[tbody&gt;&amp;]:odd:bg-bg-500\/10\">\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">claude \"\u4fdd\u5b58\u3057\u305f\u5909\u66f4\u3092\u5fa9\u5143\u3057\u3066\"<\/code><\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">git stash pop<\/code> \u3067\u5909\u66f4\u3092\u5fa9\u5143<\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u9000\u907f\u3057\u305f\u5909\u66f4\u3092\u623b\u3057\u305f\u3044\u6642<\/td>\n<\/tr>\n<\/tbody>\n<\/table><\/div>\n<h4 class=\"text-base font-bold text-text-100 mt-1\">\ud83d\udea8 <strong>\u7dca\u6025\u5bfe\u5fdc\u30fb\u4fee\u6b63\u7cfb<\/strong><\/h4>\n<div class=\"table-outer\"><table class=\"bg-bg-100 min-w-full border-separate border-spacing-0 text-sm leading-[1.88888] whitespace-normal\">\n<thead class=\"border-b-border-100\/50 border-b-[0.5px] text-left\">\n<tr class=\"[tbody&gt;&amp;]:odd:bg-bg-500\/10\">\n<th class=\"text-text-000 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] font-400 px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u30b3\u30de\u30f3\u30c9\u4f8b<\/th>\n<th class=\"text-text-000 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] font-400 px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u5b9f\u884c\u3055\u308c\u308b\u51e6\u7406<\/th>\n<th class=\"text-text-000 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] font-400 px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u4f7f\u7528\u5834\u9762<\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr class=\"[tbody&gt;&amp;]:odd:bg-bg-500\/10\">\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">claude \"\u76f4\u524d\u306e\u30b3\u30df\u30c3\u30c8\u3092\u53d6\u308a\u6d88\u3057\u3066\"<\/code><\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">git reset HEAD~1<\/code> \u3092\u5b9f\u884c<\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u9593\u9055\u3063\u305f\u30b3\u30df\u30c3\u30c8\u306e\u53d6\u308a\u6d88\u3057<\/td>\n<\/tr>\n<tr class=\"[tbody&gt;&amp;]:odd:bg-bg-500\/10\">\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">claude \"\u3053\u306e\u30d5\u30a1\u30a4\u30eb\u306e\u5909\u66f4\u3092\u53d6\u308a\u6d88\u3057\u3066\"<\/code><\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">git checkout -- filename<\/code><\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u30d5\u30a1\u30a4\u30eb\u306e\u5909\u66f4\u3092\u5143\u306b\u623b\u3057\u305f\u3044\u6642<\/td>\n<\/tr>\n<tr class=\"[tbody&gt;&amp;]:odd:bg-bg-500\/10\">\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">claude \"\u5371\u967a\u306a\u30b3\u30df\u30c3\u30c8\u3092revert\u3057\u3066\"<\/code><\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">git revert commitID<\/code> \u3067\u5b89\u5168\u306b\u53d6\u308a\u6d88\u3057<\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u672c\u756a\u74b0\u5883\u3078\u306e\u5b89\u5168\u306a\u4fee\u6b63<\/td>\n<\/tr>\n<tr class=\"[tbody&gt;&amp;]:odd:bg-bg-500\/10\">\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">claude \"hotfix\u30d6\u30e9\u30f3\u30c1\u3092\u4f5c\u3063\u3066\u7dca\u6025\u4fee\u6b63\"<\/code><\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u7dca\u6025\u4fee\u6b63\u7528\u30d6\u30e9\u30f3\u30c1\u4f5c\u6210\u2192\u4fee\u6b63\u2192\u30de\u30fc\u30b8<\/td>\n<td class=\"border-t-border-100\/50 [&amp;:not(:first-child)]:-x-[hsla(var(--border-100) \/ 0.5)] border-t-[0.5px] px-2 [&amp;:not(:first-child)]:border-l-[0.5px]\">\u672c\u756a\u30d0\u30b0\u306e\u7dca\u6025\u5bfe\u5fdc<\/td>\n<\/tr>\n<\/tbody>\n<\/table><\/div>\n<p class=\"whitespace-pre-wrap break-words\">\ud83e\uddf8\u300c\u308f\u3041\uff01\u30b3\u30de\u30f3\u30c9\u304c\u3044\u3063\u3071\u3044\u30af\u30de\uff01\u899a\u3048\u304d\u308c\u306a\u3044\u3088\u301c\u300d \ud83d\udc3b\u200d\u2744\ufe0f\u300c\u5fc3\u914d\u3054\u7121\u7528\u3058\u3083\uff01\u5168\u90e8\u899a\u3048\u308b\u5fc5\u8981\u306f\u306a\u3044\u305e\u3044\u3002\u3088\u304f\u4f7f\u3046\u3082\u306e\u304b\u3089\u5c11\u3057\u305a\u3064\u899a\u3048\u3066\u3044\u3051\u3070\u3044\u3044\u306e\u3058\u3083\u300d<\/p>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">\ud83d\udcac \u5b9f\u8df5\u4f1a\u8a71\u4f8b\uff1a\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u958b\u767a\u306e\u4e00\u65e5<\/h3>\n<p class=\"whitespace-normal break-words\">\u3053\u3053\u304b\u3089\u306f\u3001\u5b9f\u969b\u306bClaude Code\u3092\u4f7f\u3063\u305f\u958b\u767a\u306e\u69d8\u5b50\u3092\u3001\u4f1a\u8a71\u5f62\u5f0f\u3067\u7d39\u4ecb\u3059\u308b\u305e\u3044\uff01<\/p>\n<h4 class=\"text-base font-bold text-text-100 mt-1\">\ud83c\udf05 <strong>\u671d\u306e\u4f5c\u696d\u958b\u59cb<\/strong><\/h4>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code>\u958b\u767a\u8005: GitHub Pages\u3088\u308a\u9ad8\u6a5f\u80fd\u306aNetlify\u3092\u4f7f\u3063\u3066\u307f\u305f\u3044\r\n\r\nclaude: Netlify \u306f\u7d20\u6674\u3089\u3057\u3044\u9078\u629e\u3067\u3059\uff01\u81ea\u52d5\u30d3\u30eb\u30c9\u3001\u74b0\u5883\u5909\u6570\u3001\u30d5\u30a9\u30fc\u30e0\u51e6\u7406\u306a\u3069\r\nGitHub Pages \u306b\u306f\u306a\u3044\u9ad8\u6a5f\u80fd\u304c\u4f7f\u3048\u307e\u3059\u3002\r\n\r\n\u8a2d\u5b9a\u65b9\u6cd5\u3092\u65e5\u672c\u8a9e\u3067\u8aac\u660e\u3057\u306a\u304c\u3089\u9032\u3081\u307e\u3059\u306d\uff1a\r\n\r\n## \ud83d\udccb Netlify \u30c7\u30d7\u30ed\u30a4\u306e\u624b\u9806\r\n\r\n### 1. netlify.toml \u8a2d\u5b9a\u30d5\u30a1\u30a4\u30eb\u306e\u4f5c\u6210\r\n\r\n[netlify.toml \u3092\u4f5c\u6210\u4e2d...]\r\n\r\n```toml\r\n[build]\r\n  # \u30d3\u30eb\u30c9\u30b3\u30de\u30f3\u30c9\uff08npm run build \u3092\u5b9f\u884c\uff09\r\n  command = \"npm run build\"\r\n  # \u516c\u958b\u3059\u308b\u30d5\u30a9\u30eb\u30c0\uff08React \u306e\u5834\u5408\u306f build \u30d5\u30a9\u30eb\u30c0\uff09\r\n  publish = \"build\"\r\n\r\n[build.environment]\r\n  # Node.js \u306e\u30d0\u30fc\u30b8\u30e7\u30f3\u3092\u6307\u5b9a\r\n  NODE_VERSION = \"18\"\r\n\r\n[[redirects]]\r\n  # SPA \u5bfe\u5fdc\uff1a\u5168\u3066\u306e\u30ea\u30af\u30a8\u30b9\u30c8\u3092 index.html \u306b\u30ea\u30c0\u30a4\u30ec\u30af\u30c8\r\n  from = \"\/*\"\r\n  to = \"\/index.html\"\r\n  status = 200\r\n\r\n[context.production.environment]\r\n  # \u672c\u756a\u74b0\u5883\u5c02\u7528\u306e\u74b0\u5883\u5909\u6570\r\n  REACT_APP_API_URL = \"https:\/\/api.myapp.com\"\r\n\r\n[context.deploy-preview.environment]\r\n  # \u30d7\u30ec\u30d3\u30e5\u30fc\u74b0\u5883\u7528\u306e\u74b0\u5883\u5909\u6570\r\n  REACT_APP_API_URL = \"https:\/\/staging-api.myapp.com\"<\/code><\/pre>\n<\/div>\n<\/div>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">2. \u74b0\u5883\u5909\u6570\u306e\u8a2d\u5b9a\u4f8b<\/h3>\n<p class=\"whitespace-normal break-words\">\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306b .env.example \u3082\u4f5c\u6210\u3057\u3066\u304a\u304d\u307e\u3059\uff1a<\/p>\n<p class=\"whitespace-normal break-words\">[.env.example \u3092\u4f5c\u6210\u4e2d&#8230;]<\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"text-text-500 text-xs p-3.5 pb-0\">bash<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code class=\"language-bash\"><span class=\"token\"># API \u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u30c8<\/span>\r\n<span class=\"token assign-left\">REACT_APP_API_URL<\/span><span class=\"token\">=<\/span>https:\/\/localhost:3001\r\n\r\n<span class=\"token\"># Firebase \u8a2d\u5b9a\uff08\u4f8b\uff09<\/span>\r\n<span class=\"token assign-left\">REACT_APP_FIREBASE_API_KEY<\/span><span class=\"token\">=<\/span>your-api-key\r\n<span class=\"token assign-left\">REACT_APP_FIREBASE_AUTH_DOMAIN<\/span><span class=\"token\">=<\/span>your-domain.firebaseapp.com\r\n\r\n<span class=\"token\"># Google Analytics\uff08\u4f8b\uff09<\/span>\r\n<span class=\"token assign-left\">REACT_APP_GA_TRACKING_ID<\/span><span class=\"token\">=<\/span>GA-XXXXXXXXX-X<\/code><\/pre>\n<\/div>\n<\/div>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">3. GitHub \u30ea\u30dd\u30b8\u30c8\u30ea\u3068\u306e\u9023\u643a<\/h3>\n<ol class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-decimal space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\">Netlify \u30a2\u30ab\u30a6\u30f3\u30c8\u4f5c\u6210\uff08GitHub \u3067\u30ed\u30b0\u30a4\u30f3\u53ef\u80fd\uff09<\/li>\n<li class=\"whitespace-normal break-words\">\u300cNew site from Git\u300d\u3092\u30af\u30ea\u30c3\u30af<\/li>\n<li class=\"whitespace-normal break-words\">GitHub \u30ea\u30dd\u30b8\u30c8\u30ea\u3092\u9078\u629e<\/li>\n<li class=\"whitespace-normal break-words\">\u30d3\u30eb\u30c9\u8a2d\u5b9a\uff08netlify.toml \u304c\u3042\u308c\u3070\u81ea\u52d5\u691c\u51fa\uff09<\/li>\n<li class=\"whitespace-normal break-words\">\u300cDeploy site\u300d\u3092\u30af\u30ea\u30c3\u30af<\/li>\n<\/ol>\n<p class=\"whitespace-normal break-words\">\u5b8c\u4e86\u3059\u308b\u3068\u3001\u4ee5\u4e0b\u306e\u3088\u3046\u306a URL \u304c\u767a\u884c\u3055\u308c\u307e\u3059\uff1a \ud83c\udf10 <a class=\"underline\" href=\"https:\/\/amazing-app-name.netlify.app\">https:\/\/amazing-app-name.netlify.app<\/a><\/p>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">4. \u30ab\u30b9\u30bf\u30e0\u30c9\u30e1\u30a4\u30f3\u306e\u8a2d\u5b9a\uff08\u30aa\u30d7\u30b7\u30e7\u30f3\uff09<\/h3>\n<p class=\"whitespace-normal break-words\">\u72ec\u81ea\u30c9\u30e1\u30a4\u30f3\u3092\u4f7f\u3044\u305f\u3044\u5834\u5408\uff1a<\/p>\n<ol class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-decimal space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\">Domain settings \u2192 Add custom domain<\/li>\n<li class=\"whitespace-normal break-words\">DNS \u8a2d\u5b9a\u3067CNAME\u30ec\u30b3\u30fc\u30c9\u3092\u8ffd\u52a0<\/li>\n<li class=\"whitespace-normal break-words\">SSL\u8a3c\u660e\u66f8\u306e\u81ea\u52d5\u767a\u884c\uff08Let&#8217;s Encrypt\uff09<\/li>\n<\/ol>\n<p class=\"whitespace-normal break-words\">\u30b3\u30df\u30c3\u30c8\u3057\u3066\u8a2d\u5b9a\u3092\u53cd\u6620\u3055\u305b\u307e\u3059\u304b\uff1f<\/p>\n<p class=\"whitespace-normal break-words\">\u958b\u767a\u8005: \u306f\u3044\u3001\u304a\u9858\u3044\u3057\u307e\u3059<\/p>\n<p class=\"whitespace-normal break-words\">claude: netlify.toml \u3068 .env.example \u3092\u30b3\u30df\u30c3\u30c8\u3057\u307e\u3059\u3002<\/p>\n<p class=\"whitespace-pre-wrap break-words\">[git add netlify.toml .env.example] [git commit -m &#8220;feat(deploy): Netlify \u30c7\u30d7\u30ed\u30a4\u8a2d\u5b9a\u3092\u8ffd\u52a0&#8221;] [git push origin main]<\/p>\n<p class=\"whitespace-normal break-words\">\u2705 \u8a2d\u5b9a\u3092\u30d7\u30c3\u30b7\u30e5\u3057\u307e\u3057\u305f<\/p>\n<p class=\"whitespace-pre-wrap break-words\">Netlify \u5074\u3067 GitHub \u30ea\u30dd\u30b8\u30c8\u30ea\u3092\u9023\u643a\u3059\u308b\u3068\u3001 \u4eca\u5f8c\u306f main \u30d6\u30e9\u30f3\u30c1\u306b\u30d7\u30c3\u30b7\u30e5\u3059\u308b\u305f\u3073\u306b\u81ea\u52d5\u30c7\u30d7\u30ed\u30a4\u3055\u308c\u307e\u3059\u3002<\/p>\n<p class=\"whitespace-pre-wrap break-words\">\u30d7\u30ec\u30d3\u30e5\u30fc\u30c7\u30d7\u30ed\u30a4\u6a5f\u80fd\u306b\u3088\u308a\u3001Pull Request \u3054\u3068\u306b \u4e00\u6642\u7684\u306a\u30d7\u30ec\u30d3\u30e5\u30fc\u30b5\u30a4\u30c8\u3082\u81ea\u52d5\u751f\u6210\u3055\u308c\u307e\u3059\u3088\uff01<\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code>\r\n### \ud83d\udc33 Docker \u3092\u4f7f\u3063\u305f\u672c\u683c\u30c7\u30d7\u30ed\u30a4\r\n\r\n**Docker \u3063\u3066\u4f55\u3058\u3083\uff1f**\r\nDocker \u306f\u3001\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u3092\u300c\u30b3\u30f3\u30c6\u30ca\u300d\u3068\u3044\u3046\u7bb1\u306b\u5165\u308c\u3066\u3001\u3069\u3093\u306a\u74b0\u5883\u3067\u3082\u540c\u3058\u3088\u3046\u306b\u52d5\u304b\u305b\u308b\u6280\u8853\u3058\u3083\u3002\u300c\u3069\u3053\u3067\u3082\u52d5\u304f\u9b54\u6cd5\u306e\u7bb1\u300d\u307f\u305f\u3044\u306a\u3082\u306e\u3067\u3059\u305e\uff01<\/code><\/pre>\n<\/div>\n<\/div>\n<p class=\"whitespace-normal break-words\">\u958b\u767a\u8005: Docker\u3092\u4f7f\u3063\u3066\u30a2\u30d7\u30ea\u3092\u30b3\u30f3\u30c6\u30ca\u5316\u3057\u305f\u3044<\/p>\n<p class=\"whitespace-pre-wrap break-words\">claude: Docker \u3092\u4f7f\u3063\u305f\u30b3\u30f3\u30c6\u30ca\u5316\u3092\u884c\u3044\u307e\u3059\u306d\u3002 \u672c\u683c\u7684\u306a\u672c\u756a\u74b0\u5883\u30c7\u30d7\u30ed\u30a4\u306b\u5411\u3051\u305f\u8a2d\u5b9a\u3092\u3057\u307e\u3059\u3002<\/p>\n<h2 class=\"text-xl font-bold text-text-100 mt-1 -mb-0.5\">\ud83d\udce6 Docker \u8a2d\u5b9a\u306e\u4f5c\u6210<\/h2>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">1. Dockerfile \u306e\u4f5c\u6210<\/h3>\n<p class=\"whitespace-normal break-words\">[Dockerfile \u3092\u4f5c\u6210\u4e2d&#8230;]<\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"text-text-500 text-xs p-3.5 pb-0\">dockerfile<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code class=\"language-dockerfile\"><span class=\"token\"># Node.js \u306e\u516c\u5f0f\u30a4\u30e1\u30fc\u30b8\u3092\u4f7f\u7528\uff08\u8efd\u91cf\u7248\u306eAlpineLinux\uff09<\/span>\r\n<span class=\"token instruction\">FROM<\/span><span class=\"token instruction\"> node:18-alpine<\/span>\r\n\r\n<span class=\"token\"># \u4f5c\u696d\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u3092\u8a2d\u5b9a<\/span>\r\n<span class=\"token instruction\">WORKDIR<\/span><span class=\"token instruction\"> \/app<\/span>\r\n\r\n<span class=\"token\"># package.json \u3068 package-lock.json \u3092\u30b3\u30d4\u30fc<\/span>\r\n<span class=\"token\"># \uff08\u4f9d\u5b58\u95a2\u4fc2\u306e\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3092\u30ad\u30e3\u30c3\u30b7\u30e5\u52b9\u7387\u5316\uff09<\/span>\r\n<span class=\"token instruction\">COPY<\/span><span class=\"token instruction\"> package*.json .\/<\/span>\r\n\r\n<span class=\"token\"># \u4f9d\u5b58\u95a2\u4fc2\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb<\/span>\r\n<span class=\"token instruction\">RUN<\/span><span class=\"token instruction\"> npm ci --only=production<\/span>\r\n\r\n<span class=\"token\"># \u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u30bd\u30fc\u30b9\u30b3\u30fc\u30c9\u3092\u30b3\u30d4\u30fc<\/span>\r\n<span class=\"token instruction\">COPY<\/span><span class=\"token instruction\"> . .<\/span>\r\n\r\n<span class=\"token\"># \u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u3092\u30d3\u30eb\u30c9<\/span>\r\n<span class=\"token instruction\">RUN<\/span><span class=\"token instruction\"> npm run build<\/span>\r\n\r\n<span class=\"token\"># \u672c\u756a\u7528\u306e\u8efd\u91cfWeb\u30b5\u30fc\u30d0\u30fc\uff08Nginx\uff09\u3092\u4f7f\u7528<\/span>\r\n<span class=\"token instruction\">FROM<\/span><span class=\"token instruction\"> nginx:alpine<\/span>\r\n\r\n<span class=\"token\"># \u30d3\u30eb\u30c9\u6e08\u307f\u30a2\u30d7\u30ea\u3092Nginx\u306e\u516c\u958b\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u306b\u30b3\u30d4\u30fc<\/span>\r\n<span class=\"token instruction\">COPY<\/span> <span class=\"token instruction options\">--from<\/span><span class=\"token instruction options\">=<\/span><span class=\"token instruction options\">0<\/span><span class=\"token instruction\"> \/app\/build \/usr\/share\/nginx\/html<\/span>\r\n\r\n<span class=\"token\"># Nginx \u306e\u8a2d\u5b9a\u30d5\u30a1\u30a4\u30eb\u3092\u30b3\u30d4\u30fc<\/span>\r\n<span class=\"token instruction\">COPY<\/span><span class=\"token instruction\"> nginx.conf \/etc\/nginx\/nginx.conf<\/span>\r\n\r\n<span class=\"token\"># \u30dd\u30fc\u30c880\u3092\u516c\u958b<\/span>\r\n<span class=\"token instruction\">EXPOSE<\/span><span class=\"token instruction\"> 80<\/span>\r\n\r\n<span class=\"token\"># Nginx \u3092\u8d77\u52d5<\/span>\r\n<span class=\"token instruction\">CMD<\/span><span class=\"token instruction\"> [<\/span><span class=\"token instruction\">\"nginx\"<\/span><span class=\"token instruction\">, <\/span><span class=\"token instruction\">\"-g\"<\/span><span class=\"token instruction\">, <\/span><span class=\"token instruction\">\"daemon off;\"<\/span><span class=\"token instruction\">]<\/span><\/code><\/pre>\n<\/div>\n<\/div>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">2. Nginx \u8a2d\u5b9a\u30d5\u30a1\u30a4\u30eb<\/h3>\n<p class=\"whitespace-normal break-words\">[nginx.conf \u3092\u4f5c\u6210\u4e2d&#8230;]<\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"text-text-500 text-xs p-3.5 pb-0\">nginx<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code class=\"language-nginx\"><span class=\"token directive\">events<\/span> <span class=\"token\">{<\/span>\r\n    <span class=\"token directive\">worker_connections<\/span> <span class=\"token directive\">1024<\/span><span class=\"token\">;<\/span>\r\n<span class=\"token\">}<\/span>\r\n\r\n<span class=\"token directive\">http<\/span> <span class=\"token\">{<\/span>\r\n    <span class=\"token directive\">include<\/span><span class=\"token directive\">       \/etc\/nginx\/mime.types<\/span><span class=\"token\">;<\/span>\r\n    <span class=\"token directive\">default_type<\/span><span class=\"token directive\">  application\/octet-stream<\/span><span class=\"token\">;<\/span>\r\n\r\n    <span class=\"token\"># gzip \u5727\u7e2e\u3092\u6709\u52b9\u5316\uff08\u9ad8\u901f\u5316\uff09<\/span>\r\n    <span class=\"token directive\">gzip<\/span> <span class=\"token directive\">on<\/span><span class=\"token\">;<\/span>\r\n    <span class=\"token directive\">gzip_types<\/span><span class=\"token directive\"> text\/plain text\/css application\/json application\/javascript<\/span><span class=\"token\">;<\/span>\r\n\r\n    <span class=\"token directive\">server<\/span> <span class=\"token\">{<\/span>\r\n        <span class=\"token directive\">listen<\/span> <span class=\"token directive\">80<\/span><span class=\"token\">;<\/span>\r\n        <span class=\"token directive\">server_name<\/span><span class=\"token directive\"> localhost<\/span><span class=\"token\">;<\/span>\r\n\r\n        <span class=\"token\"># SPA\u306e\u30eb\u30fc\u30c6\u30a3\u30f3\u30b0\u5bfe\u5fdc<\/span>\r\n        <span class=\"token directive\">location<\/span><span class=\"token directive\"> \/<\/span> <span class=\"token\">{<\/span>\r\n            <span class=\"token directive\">root<\/span><span class=\"token directive\"> \/usr\/share\/nginx\/html<\/span><span class=\"token\">;<\/span>\r\n            <span class=\"token directive\">index<\/span><span class=\"token directive\"> index.html index.htm<\/span><span class=\"token\">;<\/span>\r\n            <span class=\"token directive\">try_files<\/span> <span class=\"token directive\">$uri<\/span> <span class=\"token directive\">$uri<\/span><span class=\"token directive\">\/ \/index.html<\/span><span class=\"token\">;<\/span>\r\n        <span class=\"token\">}<\/span>\r\n\r\n        <span class=\"token\"># \u9759\u7684\u30d5\u30a1\u30a4\u30eb\u306e\u30ad\u30e3\u30c3\u30b7\u30e5\u8a2d\u5b9a<\/span>\r\n        <span class=\"token directive\">location<\/span><span class=\"token directive\"> ~* \\.(js|css|png|jpg|jpeg|gif|ico|svg)$<\/span> <span class=\"token\">{<\/span>\r\n            <span class=\"token directive\">expires<\/span> <span class=\"token directive\">1y<\/span><span class=\"token\">;<\/span>\r\n            <span class=\"token directive\">add_header<\/span><span class=\"token directive\"> Cache-Control <\/span><span class=\"token directive\">\"public, immutable\"<\/span><span class=\"token\">;<\/span>\r\n        <span class=\"token\">}<\/span>\r\n    <span class=\"token\">}<\/span>\r\n<span class=\"token\">}<\/span><\/code><\/pre>\n<\/div>\n<\/div>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">3. Docker Compose \u30d5\u30a1\u30a4\u30eb\uff08\u958b\u767a\u7528\uff09<\/h3>\n<p class=\"whitespace-normal break-words\">[docker-compose.yml \u3092\u4f5c\u6210\u4e2d&#8230;]<\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"text-text-500 text-xs p-3.5 pb-0\">yaml<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code class=\"language-yaml\"><span class=\"token key\">version<\/span><span class=\"token\">:<\/span> <span class=\"token\">'3.8'<\/span>\r\n\r\n<span class=\"token key\">services<\/span><span class=\"token\">:<\/span>\r\n  <span class=\"token\"># \u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\uff08React \u30a2\u30d7\u30ea\uff09<\/span>\r\n  <span class=\"token key\">frontend<\/span><span class=\"token\">:<\/span>\r\n    <span class=\"token key\">build<\/span><span class=\"token\">:<\/span> .\r\n    <span class=\"token key\">ports<\/span><span class=\"token\">:<\/span>\r\n      <span class=\"token\">-<\/span> <span class=\"token\">\"3000:80\"<\/span>\r\n    <span class=\"token key\">environment<\/span><span class=\"token\">:<\/span>\r\n      <span class=\"token\">-<\/span> REACT_APP_API_URL=http<span class=\"token\">:<\/span>\/\/localhost<span class=\"token\">:<\/span><span class=\"token\">3001<\/span>\r\n    <span class=\"token key\">depends_on<\/span><span class=\"token\">:<\/span>\r\n      <span class=\"token\">-<\/span> backend\r\n\r\n  <span class=\"token\"># \u30d0\u30c3\u30af\u30a8\u30f3\u30c9\uff08Node.js API\uff09<\/span>\r\n  <span class=\"token key\">backend<\/span><span class=\"token\">:<\/span>\r\n    <span class=\"token key\">build<\/span><span class=\"token\">:<\/span> .\/backend\r\n    <span class=\"token key\">ports<\/span><span class=\"token\">:<\/span>\r\n      <span class=\"token\">-<\/span> <span class=\"token\">\"3001:3001\"<\/span>\r\n    <span class=\"token key\">environment<\/span><span class=\"token\">:<\/span>\r\n      <span class=\"token\">-<\/span> NODE_ENV=development\r\n      <span class=\"token\">-<\/span> DB_HOST=database\r\n      <span class=\"token\">-<\/span> DB_PORT=5432\r\n      <span class=\"token\">-<\/span> DB_NAME=myapp\r\n      <span class=\"token\">-<\/span> DB_USER=postgres\r\n      <span class=\"token\">-<\/span> DB_PASSWORD=password\r\n    <span class=\"token key\">depends_on<\/span><span class=\"token\">:<\/span>\r\n      <span class=\"token\">-<\/span> database\r\n\r\n  <span class=\"token\"># \u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\uff08PostgreSQL\uff09<\/span>\r\n  <span class=\"token key\">database<\/span><span class=\"token\">:<\/span>\r\n    <span class=\"token key\">image<\/span><span class=\"token\">:<\/span> postgres<span class=\"token\">:<\/span>15<span class=\"token\">-<\/span>alpine\r\n    <span class=\"token key\">environment<\/span><span class=\"token\">:<\/span>\r\n      <span class=\"token\">-<\/span> POSTGRES_DB=myapp\r\n      <span class=\"token\">-<\/span> POSTGRES_USER=postgres\r\n      <span class=\"token\">-<\/span> POSTGRES_PASSWORD=password\r\n    <span class=\"token key\">volumes<\/span><span class=\"token\">:<\/span>\r\n      <span class=\"token\">-<\/span> postgres_data<span class=\"token\">:<\/span>\/var\/lib\/postgresql\/data\r\n    <span class=\"token key\">ports<\/span><span class=\"token\">:<\/span>\r\n      <span class=\"token\">-<\/span> <span class=\"token\">\"5432:5432\"<\/span>\r\n\r\n<span class=\"token key\">volumes<\/span><span class=\"token\">:<\/span>\r\n  postgres_data<span class=\"token\">:<\/span><\/code><\/pre>\n<\/div>\n<\/div>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">4. .dockerignore \u30d5\u30a1\u30a4\u30eb<\/h3>\n<p class=\"whitespace-normal break-words\">[.dockerignore \u3092\u4f5c\u6210\u4e2d&#8230;]<\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code>node_modules\r\nnpm-debug.log\r\nbuild\r\n.git\r\n.gitignore\r\nREADME.md\r\n.env\r\n.nyc_output\r\ncoverage\r\n.coverage<\/code><\/pre>\n<\/div>\n<\/div>\n<p class=\"whitespace-normal break-words\">Docker \u74b0\u5883\u3092\u30c6\u30b9\u30c8\u3057\u307e\u3059\u304b\uff1f<\/p>\n<p class=\"whitespace-normal break-words\">\u958b\u767a\u8005: \u30c6\u30b9\u30c8\u3057\u3066\u307f\u3066<\/p>\n<p class=\"whitespace-normal break-words\">claude: Docker \u74b0\u5883\u3092\u30c6\u30b9\u30c8\u3057\u307e\u3059\u3002<\/p>\n<p class=\"whitespace-normal break-words\">[docker build -t my-react-app . \u3092\u5b9f\u884c\u4e2d&#8230;]<\/p>\n<p class=\"whitespace-normal break-words\">\ud83d\udce6 Docker \u30a4\u30e1\u30fc\u30b8\u3092\u30d3\u30eb\u30c9\u4e2d&#8230; \u2705 \u30d3\u30eb\u30c9\u5b8c\u4e86\uff1amy-react-app:latest<\/p>\n<p class=\"whitespace-normal break-words\">[docker run -p 3000:80 my-react-app \u3092\u5b9f\u884c\u4e2d&#8230;]<\/p>\n<p class=\"whitespace-normal break-words\">\ud83d\ude80 \u30b3\u30f3\u30c6\u30ca\u3092\u8d77\u52d5\u3057\u307e\u3057\u305f \ud83c\udf10 \u30a2\u30af\u30bb\u30b9\u5148\uff1a<a class=\"underline\" href=\"http:\/\/localhost:3000\">http:\/\/localhost:3000<\/a><\/p>\n<p class=\"whitespace-pre-wrap break-words\">\u52d5\u4f5c\u78ba\u8a8d\u4e2d&#8230; \u2705 \u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u304c\u6b63\u5e38\u306b\u52d5\u4f5c\u3057\u3066\u3044\u307e\u3059 \u2705 SPA\u30eb\u30fc\u30c6\u30a3\u30f3\u30b0\u3082\u6b63\u5e38\u306b\u6a5f\u80fd\u3057\u3066\u3044\u307e\u3059 \u2705 \u9759\u7684\u30d5\u30a1\u30a4\u30eb\u306e\u914d\u4fe1\u3082\u554f\u984c\u3042\u308a\u307e\u305b\u3093<\/p>\n<p class=\"whitespace-normal break-words\">\u672c\u756a\u74b0\u5883\u30c7\u30d7\u30ed\u30a4\u7528\u306e\u30b3\u30de\u30f3\u30c9\u3082\u4f5c\u6210\u3057\u3066\u304a\u304d\u307e\u3059\u306d\uff1a<\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"text-text-500 text-xs p-3.5 pb-0\">bash<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code class=\"language-bash\"><span class=\"token\"># \u30a4\u30e1\u30fc\u30b8\u3092\u30d3\u30eb\u30c9<\/span>\r\n<span class=\"token\">docker<\/span> build -t my-react-app:v1.0.0 <span class=\"token\">.<\/span>\r\n\r\n<span class=\"token\"># \u30ec\u30b8\u30b9\u30c8\u30ea\u306b\u30d7\u30c3\u30b7\u30e5\uff08\u4f8b\uff1aDocker Hub\uff09<\/span>\r\n<span class=\"token\">docker<\/span> tag my-react-app:v1.0.0 username\/my-react-app:v1.0.0\r\n<span class=\"token\">docker<\/span> push username\/my-react-app:v1.0.0\r\n\r\n<span class=\"token\"># \u672c\u756a\u30b5\u30fc\u30d0\u30fc\u3067\u306e\u8d77\u52d5<\/span>\r\n<span class=\"token\">docker<\/span> run -d --name my-app -p <span class=\"token\">80<\/span>:80 username\/my-react-app:v1.0.0<\/code><\/pre>\n<\/div>\n<\/div>\n<p class=\"whitespace-normal break-words\">\u8a2d\u5b9a\u3092\u30b3\u30df\u30c3\u30c8\u3057\u307e\u3059\u304b\uff1f<\/p>\n<p class=\"whitespace-normal break-words\">\u958b\u767a\u8005: \u306f\u3044<\/p>\n<p class=\"whitespace-normal break-words\">claude: Docker \u8a2d\u5b9a\u3092\u30b3\u30df\u30c3\u30c8\u3057\u307e\u3059\u3002<\/p>\n<p class=\"whitespace-pre-wrap break-words\">[git add Dockerfile nginx.conf docker-compose.yml .dockerignore] [git commit -m &#8220;feat(docker): Docker \u30b3\u30f3\u30c6\u30ca\u5316\u8a2d\u5b9a\u3092\u8ffd\u52a0<\/p>\n<ul class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-disc space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\">\u30de\u30eb\u30c1\u30b9\u30c6\u30fc\u30b8\u30d3\u30eb\u30c9\u3067\u8efd\u91cf\u5316<\/li>\n<li class=\"whitespace-normal break-words\">Nginx \u3067\u306e\u9ad8\u901f\u914d\u4fe1<\/li>\n<li class=\"whitespace-normal break-words\">SPA \u30eb\u30fc\u30c6\u30a3\u30f3\u30b0\u5bfe\u5fdc<\/li>\n<li class=\"whitespace-normal break-words\">\u958b\u767a\u7528 docker-compose \u8a2d\u5b9a&#8221;] [git push origin main]<\/li>\n<\/ul>\n<p class=\"whitespace-normal break-words\">\u2705 Docker \u8a2d\u5b9a\u3092\u30d7\u30c3\u30b7\u30e5\u3057\u307e\u3057\u305f<\/p>\n<p class=\"whitespace-pre-wrap break-words\">\u3053\u308c\u3067\u672c\u683c\u7684\u306a\u672c\u756a\u74b0\u5883\u30c7\u30d7\u30ed\u30a4\u306e\u6e96\u5099\u304c\u6574\u3044\u307e\u3057\u305f\uff01 AWS\u3001Google Cloud\u3001Azure \u306a\u3069\u306e\u5404\u7a2e\u30af\u30e9\u30a6\u30c9\u30b5\u30fc\u30d3\u30b9\u3067\u3082 \u3053\u306e\u30b3\u30f3\u30c6\u30ca\u3092\u305d\u306e\u307e\u307e\u30c7\u30d7\u30ed\u30a4\u3067\u304d\u307e\u3059\u3002<\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code>\r\n## \ud83d\udd04 \u7b2c7\u7ae0\uff1a\u30ed\u30fc\u30eb\u30d0\u30c3\u30af\uff08\u5dfb\u304d\u623b\u3057\uff09\u306e\u5b8c\u5168\u30ac\u30a4\u30c9\r\n\r\n\ud83d\udc3b\u200d\u2744\ufe0f\u300c\u958b\u767a\u4e2d\u306b\u306f\u5fc5\u305a\u300e\u3042\u3063\u3001\u3084\u3063\u3061\u3083\u3063\u305f\uff01\u300f\u3068\u3044\u3046\u77ac\u9593\u304c\u3042\u308b\u3082\u306e\u3058\u3083\u3002\u305d\u3093\u306a\u6642\u306e\u5bfe\u51e6\u6cd5\u3092\u6559\u3048\u3066\u3084\u308b\u305e\u3044\u300d\r\n\ud83e\uddf8\u300c\u6016\u3044\u8a71\u30af\u30de...\u3067\u3082\u77e5\u3063\u3066\u304a\u304b\u306a\u3044\u3068\uff01\u300d\r\n\r\n### \u23ea \u30ec\u30d9\u30eb\u5225\u30ed\u30fc\u30eb\u30d0\u30c3\u30af\u6226\u7565\r\n\r\n**\ud83d\udfe2 \u30ec\u30d9\u30eb1\uff1a\u30ed\u30fc\u30ab\u30eb\u3067\u306e\u8efd\u5fae\u306a\u5909\u66f4\u53d6\u308a\u6d88\u3057**<\/code><\/pre>\n<\/div>\n<\/div>\n<p class=\"whitespace-normal break-words\">\u958b\u767a\u8005: \u30d5\u30a1\u30a4\u30eb\u306e\u5909\u66f4\u3092\u9593\u9055\u3048\u305f\u3001\u5143\u306b\u623b\u3057\u305f\u3044<\/p>\n<p class=\"whitespace-normal break-words\">claude: \u3069\u306e\u30ec\u30d9\u30eb\u306e\u53d6\u308a\u6d88\u3057\u304c\u5fc5\u8981\u3067\u3059\u304b\uff1f<\/p>\n<ol class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-decimal space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\">\u4f5c\u696d\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u306e\u5909\u66f4\uff08\u672a\u30b9\u30c6\u30fc\u30b8\u30f3\u30b0\uff09<\/li>\n<li class=\"whitespace-normal break-words\">\u30b9\u30c6\u30fc\u30b8\u30f3\u30b0\u30a8\u30ea\u30a2\u306e\u5909\u66f4\uff08\u30b3\u30df\u30c3\u30c8\u524d\uff09<\/li>\n<li class=\"whitespace-normal break-words\">\u76f4\u524d\u306e\u30b3\u30df\u30c3\u30c8\uff08\u30d7\u30c3\u30b7\u30e5\u524d\uff09<\/li>\n<\/ol>\n<p class=\"whitespace-normal break-words\">\u72b6\u6cc1\u3092\u6559\u3048\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n<p class=\"whitespace-normal break-words\">\u958b\u767a\u8005: \u30d5\u30a1\u30a4\u30eb\u3092\u7de8\u96c6\u3057\u305f\u3051\u3069\u3001\u307e\u3060 git add \u3057\u3066\u306a\u3044<\/p>\n<p class=\"whitespace-normal break-words\">claude: \u672a\u30b9\u30c6\u30fc\u30b8\u30f3\u30b0\u306e\u5909\u66f4\u3092\u53d6\u308a\u6d88\u3057\u307e\u3059\u306d\u3002<\/p>\n<p class=\"whitespace-normal break-words\">\u73fe\u5728\u306e\u5909\u66f4\u30d5\u30a1\u30a4\u30eb\u3092\u78ba\u8a8d\u3057\u307e\u3059\uff1a<\/p>\n<p class=\"whitespace-normal break-words\">[git status \u3092\u5b9f\u884c\u4e2d&#8230;]<\/p>\n<p class=\"whitespace-normal break-words\">\u5909\u66f4\u3055\u308c\u305f\u30d5\u30a1\u30a4\u30eb\uff1a<\/p>\n<ul class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-disc space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\">src\/components\/Header.js<\/li>\n<li class=\"whitespace-normal break-words\">src\/styles\/main.css<\/li>\n<\/ul>\n<p class=\"whitespace-normal break-words\">\u3053\u308c\u3089\u306e\u5909\u66f4\u3092\u53d6\u308a\u6d88\u3057\u307e\u3059\u304b\uff1f\uff08\u5371\u967a\uff1a\u5909\u66f4\u5185\u5bb9\u306f\u5931\u308f\u308c\u307e\u3059\uff09<\/p>\n<p class=\"whitespace-normal break-words\">\u958b\u767a\u8005: Header.js \u3060\u3051\u5143\u306b\u623b\u3057\u305f\u3044<\/p>\n<p class=\"whitespace-normal break-words\">claude: Header.js \u306e\u307f\u5143\u306b\u623b\u3057\u307e\u3059\u3002<\/p>\n<p class=\"whitespace-normal break-words\">[git checkout &#8212; src\/components\/Header.js \u3092\u5b9f\u884c]<\/p>\n<p class=\"whitespace-pre-wrap break-words\">\u2705 Header.js \u3092\u6700\u5f8c\u306e\u30b3\u30df\u30c3\u30c8\u72b6\u614b\u306b\u623b\u3057\u307e\u3057\u305f \u26a0\ufe0f \u7de8\u96c6\u5185\u5bb9\u306f\u5931\u308f\u308c\u307e\u3057\u305f<\/p>\n<p class=\"whitespace-pre-wrap break-words\">main.css \u306e\u5909\u66f4\u306f\u4fdd\u6301\u3055\u308c\u3066\u3044\u307e\u3059\u3002 \u78ba\u8a8d\u3057\u3066\u304f\u3060\u3055\u3044\uff1agit status<\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code>\r\n**\ud83d\udfe1 \u30ec\u30d9\u30eb2\uff1a\u30b3\u30df\u30c3\u30c8\u6e08\u307f\u3060\u304c\u3001\u30d7\u30c3\u30b7\u30e5\u524d\u306e\u5909\u66f4\u53d6\u308a\u6d88\u3057**<\/code><\/pre>\n<\/div>\n<\/div>\n<p class=\"whitespace-normal break-words\">\u958b\u767a\u8005: \u3055\u3063\u304d\u30b3\u30df\u30c3\u30c8\u3057\u305f\u3051\u3069\u3001\u3084\u3063\u3071\u308a\u53d6\u308a\u6d88\u3057\u305f\u3044<\/p>\n<p class=\"whitespace-normal break-words\">claude: \u30d7\u30c3\u30b7\u30e5\u524d\u306e\u30b3\u30df\u30c3\u30c8\u53d6\u308a\u6d88\u3057\u3067\u3059\u306d\u3002\u5b89\u5168\u306a\u65b9\u6cd5\u3067\u884c\u3044\u307e\u3059\u3002<\/p>\n<p class=\"whitespace-normal break-words\">\u6700\u8fd1\u306e\u30b3\u30df\u30c3\u30c8\u5c65\u6b74\u3092\u78ba\u8a8d\u3057\u307e\u3059\uff1a<\/p>\n<p class=\"whitespace-normal break-words\">[git log &#8211;oneline -5 \u3092\u5b9f\u884c\u4e2d&#8230;]<\/p>\n<p class=\"whitespace-pre-wrap break-words\">\u76f4\u8fd1\u306e\u30b3\u30df\u30c3\u30c8\u5c65\u6b74\uff1a a1b2c3d (HEAD -&gt; main) fix: \u30d8\u30c3\u30c0\u30fc\u306e\u30b9\u30bf\u30a4\u30eb\u3092\u4fee\u6b63 e4f5g6h feat: \u30e6\u30fc\u30b6\u30fc\u30d7\u30ed\u30d5\u30a3\u30fc\u30eb\u6a5f\u80fd\u3092\u8ffd\u52a0 i7j8k9l docs: README \u3092\u66f4\u65b0<\/p>\n<p class=\"whitespace-normal break-words\">\u3069\u306e\u30b3\u30df\u30c3\u30c8\u3092\u53d6\u308a\u6d88\u3057\u307e\u3059\u304b\uff1f<\/p>\n<p class=\"whitespace-normal break-words\">\u958b\u767a\u8005: \u4e00\u756a\u65b0\u3057\u3044\u300c\u30d8\u30c3\u30c0\u30fc\u306e\u30b9\u30bf\u30a4\u30eb\u3092\u4fee\u6b63\u300d\u3092\u53d6\u308a\u6d88\u3057\u305f\u3044<\/p>\n<p class=\"whitespace-normal break-words\">claude: \u6700\u65b0\u306e\u30b3\u30df\u30c3\u30c8 a1b2c3d \u3092\u53d6\u308a\u6d88\u3057\u307e\u3059\u3002<\/p>\n<p class=\"whitespace-normal break-words\">2\u3064\u306e\u65b9\u6cd5\u304c\u3042\u308a\u307e\u3059\uff1a<\/p>\n<ol class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-decimal space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\"><strong>&#8211;soft<\/strong>: \u30b3\u30df\u30c3\u30c8\u3060\u3051\u53d6\u308a\u6d88\u3057\u3001\u5909\u66f4\u306f\u6b8b\u3059\uff08\u63a8\u5968\uff09<\/li>\n<li class=\"whitespace-normal break-words\"><strong>&#8211;hard<\/strong>: \u30b3\u30df\u30c3\u30c8\u3068\u5909\u66f4\u3092\u5b8c\u5168\u306b\u524a\u9664\uff08\u5371\u967a\uff09<\/li>\n<\/ol>\n<p class=\"whitespace-normal break-words\">&#8211;soft \u3067\u53d6\u308a\u6d88\u3057\u307e\u3059\u306d\uff1a<\/p>\n<p class=\"whitespace-normal break-words\">[git reset &#8211;soft HEAD~1 \u3092\u5b9f\u884c]<\/p>\n<p class=\"whitespace-pre-wrap break-words\">\u2705 \u30b3\u30df\u30c3\u30c8 a1b2c3d \u3092\u53d6\u308a\u6d88\u3057\u307e\u3057\u305f \ud83d\udcc1 \u5909\u66f4\u5185\u5bb9\u306f\u30b9\u30c6\u30fc\u30b8\u30f3\u30b0\u30a8\u30ea\u30a2\u306b\u6b8b\u3063\u3066\u3044\u307e\u3059<\/p>\n<p class=\"whitespace-pre-wrap break-words\">\u4fee\u6b63\u3057\u3066\u304b\u3089\u518d\u5ea6\u30b3\u30df\u30c3\u30c8\u3067\u304d\u307e\u3059\u3002 \u78ba\u8a8d\uff1agit status<\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code>\r\n**\ud83d\udd34 \u30ec\u30d9\u30eb3\uff1a\u30d7\u30c3\u30b7\u30e5\u6e08\u307f\u306e\u5371\u967a\u306a\u5909\u66f4\u306e\u5b89\u5168\u306a\u53d6\u308a\u6d88\u3057**<\/code><\/pre>\n<\/div>\n<\/div>\n<p class=\"whitespace-normal break-words\">\u958b\u767a\u8005: \u672c\u756a\u74b0\u5883\u306b\u30d0\u30b0\u306e\u3042\u308b\u30b3\u30fc\u30c9\u3092\u30d7\u30c3\u30b7\u30e5\u3057\u3066\u3057\u307e\u3063\u305f\uff01<\/p>\n<p class=\"whitespace-normal break-words\">claude: \u7dca\u6025\u4e8b\u614b\u3067\u3059\u306d\uff01\u672c\u756a\u74b0\u5883\u3078\u306e\u5f71\u97ff\u3092\u6700\u5c0f\u9650\u306b\u6291\u3048\u308b\u65b9\u6cd5\u3067\u5bfe\u51e6\u3057\u307e\u3059\u3002<\/p>\n<p class=\"whitespace-normal break-words\">\u30c1\u30fc\u30e0\u958b\u767a\u3067\u306f <code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">git revert<\/code> \u3092\u4f7f\u7528\u3057\u3066\u3001\u5c65\u6b74\u3092\u4fdd\u6301\u3057\u306a\u304c\u3089 \u5b89\u5168\u306b\u5909\u66f4\u3092\u6253\u3061\u6d88\u3057\u307e\u3059\u3002<\/p>\n<p class=\"whitespace-normal break-words\">\u307e\u305a\u554f\u984c\u306e\u3042\u308b\u30b3\u30df\u30c3\u30c8\u3092\u7279\u5b9a\u3057\u307e\u3057\u3087\u3046\uff1a<\/p>\n<p class=\"whitespace-normal break-words\">[git log &#8211;oneline &#8211;graph \u3092\u5b9f\u884c\u4e2d&#8230;]<\/p>\n<p class=\"whitespace-normal break-words\">\u6700\u8fd1\u306e\u30b3\u30df\u30c3\u30c8\uff1a<\/p>\n<ul class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-disc space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\">f9e8d7c (HEAD -&gt; main, origin\/main) feat: \u65b0\u3057\u3044\u6c7a\u6e08\u6a5f\u80fd\u3092\u8ffd\u52a0<\/li>\n<li class=\"whitespace-normal break-words\">c6b5a4e fix: \u30e6\u30fc\u30b6\u30fc\u8a8d\u8a3c\u306e\u30d0\u30b0\u3092\u4fee\u6b63<\/li>\n<li class=\"whitespace-normal break-words\">3d2c1b0 feat: \u30e6\u30fc\u30b6\u30fc\u30d7\u30ed\u30d5\u30a3\u30fc\u30eb\u6a5f\u80fd<\/li>\n<\/ul>\n<p class=\"whitespace-normal break-words\">\u3069\u306e\u30b3\u30df\u30c3\u30c8\u306b\u554f\u984c\u304c\u3042\u308a\u307e\u3059\u304b\uff1f<\/p>\n<p class=\"whitespace-normal break-words\">\u958b\u767a\u8005: \u300c\u65b0\u3057\u3044\u6c7a\u6e08\u6a5f\u80fd\u3092\u8ffd\u52a0\u300d\u3067\u30d0\u30b0\u304c\u5165\u3063\u305f<\/p>\n<p class=\"whitespace-normal break-words\">claude: f9e8d7c \u306e\u30b3\u30df\u30c3\u30c8\u3092\u5b89\u5168\u306b\u30ea\u30d0\u30fc\u30c8\u3057\u307e\u3059\u3002<\/p>\n<p class=\"whitespace-normal break-words\">[git revert f9e8d7c &#8211;no-edit \u3092\u5b9f\u884c\u4e2d&#8230;]<\/p>\n<p class=\"whitespace-pre-wrap break-words\">\u2705 \u30ea\u30d0\u30fc\u30c8\u30b3\u30df\u30c3\u30c8\u3092\u4f5c\u6210\u3057\u307e\u3057\u305f\uff1a &#8220;Revert &#8220;feat: \u65b0\u3057\u3044\u6c7a\u6e08\u6a5f\u80fd\u3092\u8ffd\u52a0&#8221;&#8221;<\/p>\n<p class=\"whitespace-normal break-words\">\u3053\u308c\u306b\u3088\u308a\uff1a<\/p>\n<ul class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-disc space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\">\u554f\u984c\u306e\u3042\u308b\u5909\u66f4\u304c\u6253\u3061\u6d88\u3055\u308c\u307e\u3059<\/li>\n<li class=\"whitespace-normal break-words\">\u5c65\u6b74\u306f\u4fdd\u6301\u3055\u308c\u307e\u3059\uff08\u76e3\u67fb\u306b\u91cd\u8981\uff09<\/li>\n<li class=\"whitespace-normal break-words\">\u30c1\u30fc\u30e0\u30e1\u30f3\u30d0\u30fc\u3068\u306e\u540c\u671f\u304c\u5b89\u5168\u3067\u3059<\/li>\n<\/ul>\n<p class=\"whitespace-normal break-words\">\u672c\u756a\u74b0\u5883\u306b\u30d7\u30c3\u30b7\u30e5\u3057\u307e\u3059\u304b\uff1f<\/p>\n<p class=\"whitespace-normal break-words\">\u958b\u767a\u8005: \u304a\u9858\u3044\u3057\u307e\u3059<\/p>\n<p class=\"whitespace-normal break-words\">claude: \u7dca\u6025\u4fee\u6b63\u3092\u30d7\u30c3\u30b7\u30e5\u3057\u307e\u3059\u3002<\/p>\n<p class=\"whitespace-normal break-words\">[git push origin main \u3092\u5b9f\u884c\u4e2d&#8230;]<\/p>\n<p class=\"whitespace-normal break-words\">\u2705 \u30ea\u30d0\u30fc\u30c8\u3092\u672c\u756a\u74b0\u5883\u306b\u53cd\u6620\u3057\u307e\u3057\u305f<\/p>\n<p class=\"whitespace-normal break-words\">\u672c\u756a\u74b0\u5883\u306e\u78ba\u8a8d\u3092\u884c\u3063\u3066\u304f\u3060\u3055\u3044\uff1a<\/p>\n<ol class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-decimal space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\">\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u52d5\u4f5c\u78ba\u8a8d<\/li>\n<li class=\"whitespace-normal break-words\">\u6c7a\u6e08\u6a5f\u80fd\u304c\u7121\u52b9\u5316\u3055\u308c\u3066\u3044\u308b\u3053\u3068\u306e\u78ba\u8a8d<\/li>\n<li class=\"whitespace-normal break-words\">\u4ed6\u306e\u6a5f\u80fd\u3078\u306e\u5f71\u97ff\u304c\u306a\u3044\u3053\u3068\u306e\u78ba\u8a8d<\/li>\n<\/ol>\n<p class=\"whitespace-normal break-words\">\u4fee\u6b63\u7248\u306e\u518d\u5b9f\u88c5\u8a08\u753b\u3082\u7acb\u3066\u3066\u304a\u304d\u307e\u3059\u304b\uff1f<\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code>\r\n### \ud83d\udea8 \u7dca\u6025\u6642\u306e\u30db\u30c3\u30c8\u30d5\u30a3\u30c3\u30af\u30b9\u6226\u7565<\/code><\/pre>\n<\/div>\n<\/div>\n<p class=\"whitespace-normal break-words\">\u958b\u767a\u8005: \u672c\u756a\u3067\u91cd\u5927\u306a\u30d0\u30b0\u304c\u767a\u898b\u3055\u308c\u305f\u3001\u7dca\u6025\u3067\u4fee\u6b63\u3057\u305f\u3044<\/p>\n<p class=\"whitespace-pre-wrap break-words\">claude: \u7dca\u6025\u30d0\u30b0\u4fee\u6b63\uff08\u30db\u30c3\u30c8\u30d5\u30a3\u30c3\u30af\u30b9\uff09\u306e\u624b\u9806\u3092\u5b9f\u884c\u3057\u307e\u3059\u3002 Git Flow \u306b\u5f93\u3063\u305f\u5b89\u5168\u306a\u624b\u9806\u3067\u9032\u3081\u307e\u3059\u306d\u3002<\/p>\n<h2 class=\"text-xl font-bold text-text-100 mt-1 -mb-0.5\">\ud83d\udea8 \u30db\u30c3\u30c8\u30d5\u30a3\u30c3\u30af\u30b9\u624b\u9806<\/h2>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">1. \u73fe\u5728\u306e\u672c\u756a\u30d6\u30e9\u30f3\u30c1\u304b\u3089\u7dca\u6025\u4fee\u6b63\u30d6\u30e9\u30f3\u30c1\u3092\u4f5c\u6210<\/h3>\n<p class=\"whitespace-pre-wrap break-words\">[git checkout main] [git pull origin main] [git checkout -b hotfix\/critical-payment-bug]<\/p>\n<p class=\"whitespace-normal break-words\">\u2705 hotfix\/critical-payment-bug \u30d6\u30e9\u30f3\u30c1\u3092\u4f5c\u6210\u3057\u307e\u3057\u305f<\/p>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">2. \u30d0\u30b0\u306e\u8a73\u7d30\u3092\u6559\u3048\u3066\u304f\u3060\u3055\u3044<\/h3>\n<p class=\"whitespace-normal break-words\">\u958b\u767a\u8005: \u6c7a\u6e08\u5b8c\u4e86\u5f8c\u306b\u30e6\u30fc\u30b6\u30fc\u306b\u30e1\u30fc\u30eb\u901a\u77e5\u304c\u9001\u3089\u308c\u306a\u3044<\/p>\n<p class=\"whitespace-normal break-words\">claude: \u6c7a\u6e08\u30e1\u30fc\u30eb\u901a\u77e5\u306e\u30d0\u30b0\u3067\u3059\u306d\u3002\u95a2\u9023\u30d5\u30a1\u30a4\u30eb\u3092\u8abf\u67fb\u3057\u307e\u3059\u3002<\/p>\n<p class=\"whitespace-normal break-words\">[\u30d5\u30a1\u30a4\u30eb\u691c\u7d22\u4e2d&#8230;]<\/p>\n<p class=\"whitespace-normal break-words\">\u95a2\u9023\u30d5\u30a1\u30a4\u30eb\u3092\u767a\u898b\uff1a<\/p>\n<ul class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-disc space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\">src\/services\/paymentService.js<\/li>\n<li class=\"whitespace-normal break-words\">src\/services\/emailService.js<\/li>\n<li class=\"whitespace-normal break-words\">src\/controllers\/paymentController.js<\/li>\n<\/ul>\n<p class=\"whitespace-normal break-words\">\u554f\u984c\u3092\u5206\u6790\u4e2d&#8230;<\/p>\n<p class=\"whitespace-normal break-words\">[paymentController.js \u3092\u5206\u6790\u4e2d&#8230;]<\/p>\n<p class=\"whitespace-normal break-words\">\u539f\u56e0\u3092\u7279\u5b9a\u3057\u307e\u3057\u305f\uff1a<\/p>\n<ul class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-disc space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\">24\u884c\u76ee\uff1aawait sendPaymentEmail() \u306e\u547c\u3073\u51fa\u3057\u304ctry-catch\u5916<\/li>\n<li class=\"whitespace-normal break-words\">\u30a8\u30e9\u30fc\u304c\u767a\u751f\u3057\u3066\u3082\u30e1\u30a4\u30f3\u51e6\u7406\u304c\u7d9a\u884c\u3055\u308c\u308b<\/li>\n<\/ul>\n<p class=\"whitespace-normal break-words\">\u4fee\u6b63\u3092\u5b9f\u88c5\u3057\u307e\u3059\uff1a<\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"text-text-500 text-xs p-3.5 pb-0\">javascript<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code class=\"language-javascript\"><span class=\"token\">\/\/ \u4fee\u6b63\u524d\uff08\u554f\u984c\u306e\u3042\u308b\u30b3\u30fc\u30c9\uff09<\/span>\r\n<span class=\"token control-flow\">try<\/span> <span class=\"token\">{<\/span>\r\n  <span class=\"token\">const<\/span> payment <span class=\"token\">=<\/span> <span class=\"token control-flow\">await<\/span> <span class=\"token\">processPayment<\/span><span class=\"token\">(<\/span>paymentData<span class=\"token\">)<\/span><span class=\"token\">;<\/span>\r\n  res<span class=\"token\">.<\/span><span class=\"token method property-access\">json<\/span><span class=\"token\">(<\/span><span class=\"token\">{<\/span> <span class=\"token literal-property\">success<\/span><span class=\"token\">:<\/span> <span class=\"token\">true<\/span><span class=\"token\">,<\/span> payment <span class=\"token\">}<\/span><span class=\"token\">)<\/span><span class=\"token\">;<\/span>\r\n<span class=\"token\">}<\/span> <span class=\"token control-flow\">catch<\/span> <span class=\"token\">(<\/span>error<span class=\"token\">)<\/span> <span class=\"token\">{<\/span>\r\n  res<span class=\"token\">.<\/span><span class=\"token method property-access\">status<\/span><span class=\"token\">(<\/span><span class=\"token\">500<\/span><span class=\"token\">)<\/span><span class=\"token\">.<\/span><span class=\"token method property-access\">json<\/span><span class=\"token\">(<\/span><span class=\"token\">{<\/span> <span class=\"token literal-property\">error<\/span><span class=\"token\">:<\/span> error<span class=\"token\">.<\/span><span class=\"token property-access\">message<\/span> <span class=\"token\">}<\/span><span class=\"token\">)<\/span><span class=\"token\">;<\/span>\r\n<span class=\"token\">}<\/span>\r\n<span class=\"token control-flow\">await<\/span> <span class=\"token\">sendPaymentEmail<\/span><span class=\"token\">(<\/span>payment<span class=\"token\">.<\/span><span class=\"token property-access\">userId<\/span><span class=\"token\">,<\/span> payment<span class=\"token\">)<\/span><span class=\"token\">;<\/span> <span class=\"token\">\/\/ \u2190 \u3053\u3053\u304c\u554f\u984c<\/span>\r\n\r\n<span class=\"token\">\/\/ \u4fee\u6b63\u5f8c<\/span>\r\n<span class=\"token control-flow\">try<\/span> <span class=\"token\">{<\/span>\r\n  <span class=\"token\">const<\/span> payment <span class=\"token\">=<\/span> <span class=\"token control-flow\">await<\/span> <span class=\"token\">processPayment<\/span><span class=\"token\">(<\/span>paymentData<span class=\"token\">)<\/span><span class=\"token\">;<\/span>\r\n  <span class=\"token\">\/\/ \u30e1\u30fc\u30eb\u9001\u4fe1\u3092 try-catch \u5185\u306b\u79fb\u52d5<\/span>\r\n  <span class=\"token control-flow\">await<\/span> <span class=\"token\">sendPaymentEmail<\/span><span class=\"token\">(<\/span>payment<span class=\"token\">.<\/span><span class=\"token property-access\">userId<\/span><span class=\"token\">,<\/span> payment<span class=\"token\">)<\/span><span class=\"token\">;<\/span>\r\n  res<span class=\"token\">.<\/span><span class=\"token method property-access\">json<\/span><span class=\"token\">(<\/span><span class=\"token\">{<\/span> <span class=\"token literal-property\">success<\/span><span class=\"token\">:<\/span> <span class=\"token\">true<\/span><span class=\"token\">,<\/span> payment <span class=\"token\">}<\/span><span class=\"token\">)<\/span><span class=\"token\">;<\/span>\r\n<span class=\"token\">}<\/span> <span class=\"token control-flow\">catch<\/span> <span class=\"token\">(<\/span>error<span class=\"token\">)<\/span> <span class=\"token\">{<\/span>\r\n  <span class=\"token console\">console<\/span><span class=\"token\">.<\/span><span class=\"token method property-access\">error<\/span><span class=\"token\">(<\/span><span class=\"token\">'Payment processing error:'<\/span><span class=\"token\">,<\/span> error<span class=\"token\">)<\/span><span class=\"token\">;<\/span>\r\n  res<span class=\"token\">.<\/span><span class=\"token method property-access\">status<\/span><span class=\"token\">(<\/span><span class=\"token\">500<\/span><span class=\"token\">)<\/span><span class=\"token\">.<\/span><span class=\"token method property-access\">json<\/span><span class=\"token\">(<\/span><span class=\"token\">{<\/span> <span class=\"token literal-property\">error<\/span><span class=\"token\">:<\/span> error<span class=\"token\">.<\/span><span class=\"token property-access\">message<\/span> <span class=\"token\">}<\/span><span class=\"token\">)<\/span><span class=\"token\">;<\/span>\r\n<span class=\"token\">}<\/span><\/code><\/pre>\n<\/div>\n<\/div>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">3. \u4fee\u6b63\u3092\u30c6\u30b9\u30c8<\/h3>\n<p class=\"whitespace-normal break-words\">[npm test &#8212; &#8211;grep &#8220;payment&#8221; \u3092\u5b9f\u884c\u4e2d&#8230;]<\/p>\n<p class=\"whitespace-pre-wrap break-words\">\u65e2\u5b58\u30c6\u30b9\u30c8\u306f\u5168\u3066\u30d1\u30b9\u3002 \u65b0\u3057\u3044\u30c6\u30b9\u30c8\u30b1\u30fc\u30b9\u3092\u8ffd\u52a0\u3057\u307e\u3059\uff1a<\/p>\n<p class=\"whitespace-normal break-words\">[tests\/payment.test.js \u306b\u8ffd\u52a0\u4e2d&#8230;]<\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"text-text-500 text-xs p-3.5 pb-0\">javascript<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code class=\"language-javascript\"><span class=\"token\">describe<\/span><span class=\"token\">(<\/span><span class=\"token\">'Payment email notification'<\/span><span class=\"token\">,<\/span> <span class=\"token\">(<\/span><span class=\"token\">)<\/span> <span class=\"token arrow\">=&gt;<\/span> <span class=\"token\">{<\/span>\r\n  <span class=\"token\">it<\/span><span class=\"token\">(<\/span><span class=\"token\">'should send email after successful payment'<\/span><span class=\"token\">,<\/span> <span class=\"token\">async<\/span> <span class=\"token\">(<\/span><span class=\"token\">)<\/span> <span class=\"token arrow\">=&gt;<\/span> <span class=\"token\">{<\/span>\r\n    <span class=\"token\">const<\/span> mockPayment <span class=\"token\">=<\/span> <span class=\"token\">{<\/span> <span class=\"token literal-property\">userId<\/span><span class=\"token\">:<\/span> <span class=\"token\">'user123'<\/span><span class=\"token\">,<\/span> <span class=\"token literal-property\">amount<\/span><span class=\"token\">:<\/span> <span class=\"token\">1000<\/span> <span class=\"token\">}<\/span><span class=\"token\">;<\/span>\r\n    <span class=\"token\">const<\/span> mockEmailSent <span class=\"token\">=<\/span> jest<span class=\"token\">.<\/span><span class=\"token method property-access\">fn<\/span><span class=\"token\">(<\/span><span class=\"token\">)<\/span><span class=\"token\">;<\/span>\r\n    \r\n    emailService<span class=\"token\">.<\/span><span class=\"token property-access\">sendPaymentEmail<\/span> <span class=\"token\">=<\/span> mockEmailSent<span class=\"token\">;<\/span>\r\n    \r\n    <span class=\"token control-flow\">await<\/span> paymentController<span class=\"token\">.<\/span><span class=\"token method property-access\">processPayment<\/span><span class=\"token\">(<\/span>mockPayment<span class=\"token\">)<\/span><span class=\"token\">;<\/span>\r\n    \r\n    <span class=\"token\">expect<\/span><span class=\"token\">(<\/span>mockEmailSent<span class=\"token\">)<\/span><span class=\"token\">.<\/span><span class=\"token method property-access\">toHaveBeenCalledWith<\/span><span class=\"token\">(<\/span><span class=\"token\">'user123'<\/span><span class=\"token\">,<\/span> mockPayment<span class=\"token\">)<\/span><span class=\"token\">;<\/span>\r\n  <span class=\"token\">}<\/span><span class=\"token\">)<\/span><span class=\"token\">;<\/span>\r\n<span class=\"token\">}<\/span><span class=\"token\">)<\/span><span class=\"token\">;<\/span><\/code><\/pre>\n<\/div>\n<\/div>\n<p class=\"whitespace-normal break-words\">[npm test \u3092\u5b9f\u884c\u4e2d&#8230;]<\/p>\n<p class=\"whitespace-normal break-words\">\u2705 \u5168\u3066\u306e\u30c6\u30b9\u30c8\u304c\u30d1\u30b9\uff08\u65b0\u898f\u30c6\u30b9\u30c8\u542b\u3080\uff09<\/p>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">4. \u7dca\u6025\u4fee\u6b63\u3092\u30b3\u30df\u30c3\u30c8<\/h3>\n<p class=\"whitespace-pre-wrap break-words\">[git add .] [git commit -m &#8220;hotfix: \u6c7a\u6e08\u5b8c\u4e86\u30e1\u30fc\u30eb\u901a\u77e5\u304c\u9001\u4fe1\u3055\u308c\u306a\u3044\u30d0\u30b0\u3092\u4fee\u6b63<\/p>\n<ul class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-disc space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\">paymentController.js: \u30e1\u30fc\u30eb\u9001\u4fe1\u3092try-catch\u5185\u306b\u79fb\u52d5<\/li>\n<li class=\"whitespace-normal break-words\">\u9069\u5207\u306a\u30a8\u30e9\u30fc\u30cf\u30f3\u30c9\u30ea\u30f3\u30b0\u3092\u5b9f\u88c5<\/li>\n<li class=\"whitespace-normal break-words\">\u30c6\u30b9\u30c8\u30b1\u30fc\u30b9\u3092\u8ffd\u52a0&#8221;]<\/li>\n<\/ul>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">5. \u672c\u756a\u74b0\u5883\u3078\u306e\u7dca\u6025\u30c7\u30d7\u30ed\u30a4<\/h3>\n<p class=\"whitespace-normal break-words\">\u672c\u756a\u74b0\u5883\u306b\u30de\u30fc\u30b8\u3057\u307e\u3059\u304b\uff1f<\/p>\n<p class=\"whitespace-normal break-words\">\u958b\u767a\u8005: \u306f\u3044\u3001\u304a\u9858\u3044\u3057\u307e\u3059<\/p>\n<p class=\"whitespace-normal break-words\">claude: \u7dca\u6025\u4fee\u6b63\u3092\u672c\u756a\u74b0\u5883\u306b\u30c7\u30d7\u30ed\u30a4\u3057\u307e\u3059\u3002<\/p>\n<p class=\"whitespace-pre-wrap break-words\">[git checkout main] [git merge hotfix\/critical-payment-bug] [git push origin main]<\/p>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">6. \u958b\u767a\u30d6\u30e9\u30f3\u30c1\u306b\u3082\u53cd\u6620<\/h3>\n<p class=\"whitespace-pre-wrap break-words\">[git checkout develop] [git merge hotfix\/critical-payment-bug] [git push origin develop]<\/p>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">7. \u30db\u30c3\u30c8\u30d5\u30a3\u30c3\u30af\u30b9\u30d6\u30e9\u30f3\u30c1\u306e\u524a\u9664<\/h3>\n<p class=\"whitespace-pre-wrap break-words\">[git branch -d hotfix\/critical-payment-bug] [git push origin &#8211;delete hotfix\/critical-payment-bug]<\/p>\n<p class=\"whitespace-normal break-words\">\u2705 \u7dca\u6025\u4fee\u6b63\u304c\u5b8c\u4e86\u3057\u307e\u3057\u305f<\/p>\n<h2 class=\"text-xl font-bold text-text-100 mt-1 -mb-0.5\">\ud83d\udccb \u4fee\u6b63\u5b8c\u4e86\u30c1\u30a7\u30c3\u30af\u30ea\u30b9\u30c8<\/h2>\n<ul class=\"contains-task-list\">\n<li class=\"task-list-item\"><input checked=\"checked\" disabled=\"disabled\" type=\"checkbox\" \/> \u30d0\u30b0\u4fee\u6b63\u306e\u5b9f\u88c5<\/li>\n<li class=\"task-list-item\"><input checked=\"checked\" disabled=\"disabled\" type=\"checkbox\" \/> \u30c6\u30b9\u30c8\u30b1\u30fc\u30b9\u306e\u8ffd\u52a0<\/li>\n<li class=\"task-list-item\"><input checked=\"checked\" disabled=\"disabled\" type=\"checkbox\" \/> \u672c\u756a\u74b0\u5883\u3078\u306e\u53cd\u6620<\/li>\n<li class=\"task-list-item\"><input checked=\"checked\" disabled=\"disabled\" type=\"checkbox\" \/> \u958b\u767a\u30d6\u30e9\u30f3\u30c1\u3078\u306e\u53cd\u6620<\/li>\n<li class=\"task-list-item\"><input checked=\"checked\" disabled=\"disabled\" type=\"checkbox\" \/> \u30db\u30c3\u30c8\u30d5\u30a3\u30c3\u30af\u30b9\u30d6\u30e9\u30f3\u30c1\u306e\u524a\u9664<\/li>\n<\/ul>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">\ud83d\udcca \u4e8b\u5f8c\u5bfe\u5fdc<\/h3>\n<ol class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-decimal space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\"><strong>\u672c\u756a\u74b0\u5883\u3067\u306e\u52d5\u4f5c\u78ba\u8a8d<\/strong>\n<ul class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-disc space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\">\u6c7a\u6e08\u30c6\u30b9\u30c8\u306e\u5b9f\u884c<\/li>\n<li class=\"whitespace-normal break-words\">\u30e1\u30fc\u30eb\u901a\u77e5\u306e\u78ba\u8a8d<\/li>\n<\/ul>\n<\/li>\n<li class=\"whitespace-normal break-words\"><strong>\u76e3\u8996\u3068\u30ed\u30b0\u78ba\u8a8d<\/strong>\n<ul class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-disc space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\">\u30a8\u30e9\u30fc\u30ed\u30b0\u306e\u6e1b\u5c11\u78ba\u8a8d<\/li>\n<li class=\"whitespace-normal break-words\">\u30e1\u30fc\u30eb\u914d\u4fe1\u30ed\u30b0\u306e\u6b63\u5e38\u5316<\/li>\n<\/ul>\n<\/li>\n<li class=\"whitespace-normal break-words\"><strong>\u30dd\u30b9\u30c8\u30e2\u30fc\u30c6\u30e0\uff08\u632f\u308a\u8fd4\u308a\uff09<\/strong>\n<ul class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-disc space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\">\u306a\u305c\u30d0\u30b0\u304c\u767a\u751f\u3057\u305f\u304b<\/li>\n<li class=\"whitespace-normal break-words\">\u4e88\u9632\u7b56\u306e\u691c\u8a0e<\/li>\n<li class=\"whitespace-normal break-words\">\u30c6\u30b9\u30c8\u5f37\u5316\u306e\u65b9\u91dd<\/li>\n<\/ul>\n<\/li>\n<\/ol>\n<p class=\"whitespace-normal break-words\">\u5831\u544a\u66f8\u3092\u4f5c\u6210\u3057\u307e\u3059\u304b\uff1f<\/p>\n<p class=\"whitespace-normal break-words\">\u958b\u767a\u8005: \u306f\u3044\u3001\u7c21\u5358\u306a\u5831\u544a\u66f8\u3092\u304a\u9858\u3044\u3057\u307e\u3059<\/p>\n<p class=\"whitespace-normal break-words\">claude: \u30a4\u30f3\u30b7\u30c7\u30f3\u30c8\u5831\u544a\u66f8\u3092\u4f5c\u6210\u3057\u307e\u3059\u3002<\/p>\n<p class=\"whitespace-normal break-words\">[docs\/incidents\/2024-12-15-payment-email-bug.md \u3092\u4f5c\u6210\u4e2d&#8230;]<\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"text-text-500 text-xs p-3.5 pb-0\">markdown<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code class=\"language-markdown\"><span class=\"token\">#<\/span><span class=\"token\"> \u6c7a\u6e08\u30e1\u30fc\u30eb\u901a\u77e5\u30d0\u30b0 \u30a4\u30f3\u30b7\u30c7\u30f3\u30c8\u5831\u544a\u66f8<\/span>\r\n\r\n<span class=\"token\">##<\/span><span class=\"token\"> \ud83d\udcc5 \u57fa\u672c\u60c5\u5831<\/span>\r\n<span class=\"token\">-<\/span> <span class=\"token\">**<\/span><span class=\"token\">\u767a\u751f\u65e5\u6642<\/span><span class=\"token\">**<\/span>: 2024\u5e7412\u670815\u65e5 14:30 JST\r\n<span class=\"token\">-<\/span> <span class=\"token\">**<\/span><span class=\"token\">\u691c\u51fa\u65e5\u6642<\/span><span class=\"token\">**<\/span>: 2024\u5e7412\u670815\u65e5 15:45 JST\r\n<span class=\"token\">-<\/span> <span class=\"token\">**<\/span><span class=\"token\">\u89e3\u6c7a\u65e5\u6642<\/span><span class=\"token\">**<\/span>: 2024\u5e7412\u670815\u65e5 16:20 JST\r\n<span class=\"token\">-<\/span> <span class=\"token\">**<\/span><span class=\"token\">\u5f71\u97ff\u5ea6<\/span><span class=\"token\">**<\/span>: \u4e2d\uff08\u30e1\u30fc\u30eb\u901a\u77e5\u306e\u307f\u3001\u6c7a\u6e08\u51e6\u7406\u306f\u6b63\u5e38\uff09\r\n\r\n<span class=\"token\">##<\/span><span class=\"token\"> \ud83d\udc1b \u554f\u984c\u306e\u6982\u8981<\/span>\r\n\u6c7a\u6e08\u5b8c\u4e86\u5f8c\u306b\u30e6\u30fc\u30b6\u30fc\u3078\u306e\u30e1\u30fc\u30eb\u901a\u77e5\u304c\u9001\u4fe1\u3055\u308c\u306a\u3044\u30d0\u30b0\u304c\u767a\u751f\r\n\r\n<span class=\"token\">##<\/span><span class=\"token\"> \ud83d\udd0d \u6839\u672c\u539f\u56e0<\/span>\r\n<span class=\"token\">-<\/span> \u30e1\u30fc\u30eb\u9001\u4fe1\u51e6\u7406\u304c\u30a8\u30e9\u30fc\u30cf\u30f3\u30c9\u30ea\u30f3\u30b0\u7bc4\u56f2\u5916\u306b\u914d\u7f6e\r\n<span class=\"token\">-<\/span> \u51e6\u7406\u9806\u5e8f\u306e\u554f\u984c\u306b\u3088\u308a\u3001\u30a8\u30e9\u30fc\u6642\u306b\u30e1\u30fc\u30eb\u9001\u4fe1\u304c\u30b9\u30ad\u30c3\u30d7\r\n\r\n<span class=\"token\">##<\/span><span class=\"token\"> \ud83d\udee0\ufe0f \u89e3\u6c7a\u7b56<\/span>\r\n<span class=\"token\">-<\/span> \u30e1\u30fc\u30eb\u9001\u4fe1\u3092try-catch\u5185\u306b\u79fb\u52d5\r\n<span class=\"token\">-<\/span> \u9069\u5207\u306a\u30a8\u30e9\u30fc\u30cf\u30f3\u30c9\u30ea\u30f3\u30b0\u3092\u5b9f\u88c5\r\n<span class=\"token\">-<\/span> \u30c6\u30b9\u30c8\u30b1\u30fc\u30b9\u3092\u8ffd\u52a0\r\n\r\n<span class=\"token\">##<\/span><span class=\"token\"> \ud83d\udcc8 \u4e88\u9632\u7b56<\/span>\r\n<span class=\"token\">1.<\/span> \u30b3\u30fc\u30c9\u30ec\u30d3\u30e5\u30fc\u3067\u306e\u30a8\u30e9\u30fc\u30cf\u30f3\u30c9\u30ea\u30f3\u30b0\u78ba\u8a8d\u5f37\u5316\r\n<span class=\"token\">2.<\/span> \u5916\u90e8\u30b5\u30fc\u30d3\u30b9\u9023\u643a\u51e6\u7406\u306e\u30c6\u30b9\u30c8\u5145\u5b9f\r\n<span class=\"token\">3.<\/span> \u672c\u756a\u74b0\u5883\u3067\u306e\u30e1\u30fc\u30eb\u9001\u4fe1\u76e3\u8996\u30a2\u30e9\u30fc\u30c8\u8ffd\u52a0\r\n\r\n<span class=\"token\">##<\/span><span class=\"token\"> \ud83d\udc65 \u5bfe\u5fdc\u8005<\/span>\r\n<span class=\"token\">-<\/span> \u958b\u767a\u8005: [\u3042\u306a\u305f]\r\n<span class=\"token\">-<\/span> \u30ec\u30d3\u30e5\u30a2\u30fc: [\u30ec\u30d3\u30e5\u30a2\u30fc\u540d]\r\n<span class=\"token\">-<\/span> \u627f\u8a8d\u8005: [\u627f\u8a8d\u8005\u540d]<\/code><\/pre>\n<\/div>\n<\/div>\n<p class=\"whitespace-pre-wrap break-words\">\u2705 \u30a4\u30f3\u30b7\u30c7\u30f3\u30c8\u5831\u544a\u66f8\u3092\u4f5c\u6210\u3057\u307e\u3057\u305f \ud83d\udd04 \u4eca\u5f8c\u306e\u6539\u5584\u306b\u6d3b\u7528\u3057\u3066\u304f\u3060\u3055\u3044<\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code>\r\n\ud83d\udc3b\u200d\u2744\ufe0f\u300c\u3069\u3046\u3058\u3083\uff01\u7dca\u6025\u4e8b\u614b\u3078\u306e\u5bfe\u5fdc\u3082\u3001Claude Code\u304c\u3042\u308c\u3070\u5b89\u5fc3\u3058\u3083\u308d\u3046\uff1f\u300d\r\n\ud83e\uddf8\u300c\u3059\u3054\u3044\u30af\u30de\uff01\u3067\u3082\u3001\u3084\u3063\u3071\u308a\u6700\u521d\u304b\u3089\u30d0\u30b0\u3092\u4f5c\u3089\u306a\u3044\u306e\u304c\u4e00\u756a\u3060\u306d\u300d\r\n\ud83d\udc3b\u200d\u2744\ufe0f\u300c\u305d\u306e\u901a\u308a\u3058\u3083\uff01\u3060\u304b\u3089\u3053\u305d\u3001\u30c6\u30b9\u30c8\u99c6\u52d5\u958b\u767a\u3084\u30b3\u30fc\u30c9\u30ec\u30d3\u30e5\u30fc\u304c\u91cd\u8981\u306a\u306e\u3067\u3059\u305e\u301c\u300d\r\n\r\n## \ud83d\udca1 \u7b2c8\u7ae0\uff1a\u5b9f\u7528\u7684\u306aTips &amp; \u30c8\u30e9\u30d6\u30eb\u30b7\u30e5\u30fc\u30c6\u30a3\u30f3\u30b0\r\n\r\n### \ud83c\udfaf \u3088\u304f\u4f7f\u3046Claude Code\u30ef\u30f3\u30e9\u30a4\u30ca\u30fc\u96c6\r\n\r\n```bash\r\n# \u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u5206\u6790\u30fb\u628a\u63e1\u7cfb\r\nclaude \"\u3053\u306e\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3067\u6700\u3082\u91cd\u8981\u306a\u30d5\u30a1\u30a4\u30eb\u30925\u3064\u6559\u3048\u3066\"\r\nclaude \"\u4f7f\u7528\u3057\u3066\u3044\u308b\u6280\u8853\u30b9\u30bf\u30c3\u30af\u3068\u30d0\u30fc\u30b8\u30e7\u30f3\u3092\u6574\u7406\u3057\u3066\"\r\nclaude \"TODO \u30b3\u30e1\u30f3\u30c8\u3092\u5168\u3066\u63a2\u3057\u3066\u4e00\u89a7\u306b\u3057\u3066\"\r\nclaude \"\u30b3\u30fc\u30c9\u306e\u54c1\u8cea\u554f\u984c\u304c\u3042\u308c\u3070\u6307\u6458\u3057\u3066\"\r\n\r\n# Git\u64cd\u4f5c\u7cfb\r\nclaude \"\u672a\u30b3\u30df\u30c3\u30c8\u306e\u5909\u66f4\u3092\u78ba\u8a8d\u3057\u3066\u30b3\u30df\u30c3\u30c8\u3057\u3066\"\r\nclaude \"\u30b3\u30f3\u30d5\u30ea\u30af\u30c8\u3092\u89e3\u6c7a\u3057\u3066\u30de\u30fc\u30b8\u3057\u3066\"\r\nclaude \"\u4e0d\u8981\u306a\u30d6\u30e9\u30f3\u30c1\u3092\u6574\u7406\u3057\u3066\u524a\u9664\u3057\u3066\"\r\nclaude \"\u30ea\u30ea\u30fc\u30b9\u7528\u306e\u30bf\u30b0\u3092\u4f5c\u6210\u3057\u3066\"\r\n\r\n# \u30c6\u30b9\u30c8\u30fb\u54c1\u8cea\u7cfb\r\nclaude \"\u3053\u306e\u30d5\u30a1\u30a4\u30eb\u306e\u30c6\u30b9\u30c8\u30ab\u30d0\u30ec\u30c3\u30b8\u3092\u4e0a\u3052\u3066\"\r\nclaude \"\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u4e0a\u306e\u554f\u984c\u304c\u306a\u3044\u304b\u30c1\u30a7\u30c3\u30af\u3057\u3066\"\r\nclaude \"\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u6539\u5584\u306e\u63d0\u6848\u3092\u3057\u3066\"\r\nclaude \"\u30a2\u30af\u30bb\u30b7\u30d3\u30ea\u30c6\u30a3\u306e\u554f\u984c\u3092\u4fee\u6b63\u3057\u3066\"\r\n\r\n# \u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u7cfb\r\nclaude \"API\u4ed5\u69d8\u66f8\u3092\u66f4\u65b0\u3057\u3066\"\r\nclaude \"README\u306b\u74b0\u5883\u69cb\u7bc9\u624b\u9806\u3092\u8ffd\u52a0\u3057\u3066\"\r\nclaude \"\u30b3\u30fc\u30c9\u30b3\u30e1\u30f3\u30c8\u3092\u9069\u5207\u306b\u8ffd\u52a0\u3057\u3066\"\r\nclaude \"CHANGELOG \u3092\u6700\u65b0\u72b6\u614b\u306b\u66f4\u65b0\u3057\u3066\"<\/code><\/pre>\n<\/div>\n<\/div>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">\ud83d\udea8 \u30c8\u30e9\u30d6\u30eb\u30b7\u30e5\u30fc\u30c6\u30a3\u30f3\u30b0<\/h3>\n<p class=\"whitespace-normal break-words\"><strong>\u554f\u984c1: Claude Code\u304c\u8d77\u52d5\u3057\u306a\u3044<\/strong><\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code>\u30a8\u30e9\u30fc: claude: command not found\r\n\r\n\u89e3\u6c7a\u624b\u9806:\r\n1. Node.js \u306e\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u78ba\u8a8d\uff1anode --version\r\n2. Claude Code \u306e\u518d\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\uff1anpm install -g @anthropic-ai\/claude-code\r\n3. PATH \u306e\u78ba\u8a8d\uff1aecho $PATH\r\n4. \u6a29\u9650\u306e\u78ba\u8a8d\uff1asudo npm install -g @anthropic-ai\/claude-code<\/code><\/pre>\n<\/div>\n<\/div>\n<p class=\"whitespace-normal break-words\"><strong>\u554f\u984c2: GitHub\u3068\u306e\u8a8d\u8a3c\u30a8\u30e9\u30fc<\/strong><\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code>\u30a8\u30e9\u30fc: Authentication failed\r\n\r\n\u89e3\u6c7a\u624b\u9806:\r\n1. SSH\u9375\u306e\u78ba\u8a8d\uff1assh -T git@github.com\r\n2. \u30c8\u30fc\u30af\u30f3\u306e\u78ba\u8a8d\uff1agit config --list | grep credential\r\n3. \u8a8d\u8a3c\u306e\u518d\u8a2d\u5b9a\uff1aclaude --auth<\/code><\/pre>\n<\/div>\n<\/div>\n<p class=\"whitespace-normal break-words\"><strong>\u554f\u984c3: \u30b3\u30df\u30c3\u30c8\u30e1\u30c3\u30bb\u30fc\u30b8\u306b\u4e0d\u8981\u306a\u5e30\u5c5e\u8868\u793a<\/strong><\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code>\u554f\u984c: \"Generated with Claude Code\" \u304c\u81ea\u52d5\u8ffd\u52a0\u3055\u308c\u308b\r\n\r\n\u89e3\u6c7a\u7b56\uff08CLAUDE.md \u306b\u8ffd\u52a0\uff09\uff1a\r\n```markdown\r\n## \u30b3\u30df\u30c3\u30c8\u30e1\u30c3\u30bb\u30fc\u30b8\u30eb\u30fc\u30eb\r\n- \"Generated with Claude Code\" \u306a\u3069\u306e\u5e30\u5c5e\u8868\u793a\u306f\u542b\u3081\u306a\u3044\r\n- Conventional Commits \u5f62\u5f0f\u3092\u4f7f\u7528\r\n- \u65e5\u672c\u8a9e\u3067\u306e\u30b3\u30e1\u30f3\u30c8\u8a18\u8ff0\u3092\u63a8\u5968<\/code><\/pre>\n<\/div>\n<\/div>\n<h2 class=\"text-xl font-bold text-text-100 mt-1 -mb-0.5\">\ud83d\udcda \u7528\u8a9e\u89e3\u8aac\u96c6\uff08\u5c02\u9580\u7528\u8a9e\u304c\u308f\u304b\u3089\u306a\u3044\u65b9\u3078\uff09<\/h2>\n<p class=\"whitespace-pre-wrap break-words\">\ud83d\udc3b\u200d\u2744\ufe0f\u300c\u8a18\u4e8b\u3067\u4f7f\u3063\u305f\u5c02\u9580\u7528\u8a9e\u3092\u3001\u521d\u5fc3\u8005\u306b\u3082\u308f\u304b\u308b\u3088\u3046\u306b\u89e3\u8aac\u3059\u308b\u305e\u3044\uff01\u300d \ud83e\uddf8\u300c\u3053\u308c\u306f\u52a9\u304b\u308b\u30af\u30de\uff01\u300d<\/p>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">\ud83c\udf10 Web\u958b\u767a\u30fb\u30c7\u30d7\u30ed\u30a4\u95a2\u9023\u7528\u8a9e<\/h3>\n<p class=\"whitespace-normal break-words\"><strong>\ud83d\udccb \u57fa\u672c\u6982\u5ff5<\/strong><\/p>\n<ul class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-disc space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\"><strong>\u30c7\u30d7\u30ed\u30a4<\/strong>: \u4f5c\u3063\u305f\u30a2\u30d7\u30ea\u3092\u4e16\u754c\u4e2d\u306e\u4eba\u304c\u30a2\u30af\u30bb\u30b9\u3067\u304d\u308b\u3088\u3046\u306b\u30a4\u30f3\u30bf\u30fc\u30cd\u30c3\u30c8\u306b\u516c\u958b\u3059\u308b\u3053\u3068\uff08\u4f8b\uff1a\u53cb\u9054\u306b\u898b\u305b\u308b\u305f\u3081\u306b\u4f5c\u54c1\u3092\u5c55\u793a\u3059\u308b\u611f\u3058\uff09<\/li>\n<li class=\"whitespace-normal break-words\"><strong>\u30db\u30b9\u30c6\u30a3\u30f3\u30b0\u30b5\u30fc\u30d3\u30b9<\/strong>: \u30a2\u30d7\u30ea\u3092\u7f6e\u3044\u3066\u304a\u304f\u5834\u6240\u3092\u63d0\u4f9b\u3057\u3066\u304f\u308c\u308b\u30b5\u30fc\u30d3\u30b9\uff08\u4f8b\uff1a\u30ec\u30f3\u30bf\u30eb\u5009\u5eab\u307f\u305f\u3044\u306a\u3082\u306e\uff09<\/li>\n<li class=\"whitespace-normal break-words\"><strong>\u30c9\u30e1\u30a4\u30f3<\/strong>: \u30a4\u30f3\u30bf\u30fc\u30cd\u30c3\u30c8\u4e0a\u306e\u4f4f\u6240\uff08\u4f8b\uff1agoogle.com\u3001yahoo.co.jp \u306a\u3069\uff09<\/li>\n<li class=\"whitespace-normal break-words\"><strong>\u30ab\u30b9\u30bf\u30e0\u30c9\u30e1\u30a4\u30f3<\/strong>: \u81ea\u5206\u3067\u597d\u304d\u306a\u540d\u524d\u3092\u4ed8\u3051\u3089\u308c\u308b\u30a4\u30f3\u30bf\u30fc\u30cd\u30c3\u30c8\u4e0a\u306e\u4f4f\u6240\uff08\u4f8b\uff1amy-awesome-app.com\uff09<\/li>\n<li class=\"whitespace-normal break-words\"><strong>SSL\u8a3c\u660e\u66f8<\/strong>: \u30a6\u30a7\u30d6\u30b5\u30a4\u30c8\u3092\u6697\u53f7\u5316\u3057\u3066\u5b89\u5168\u306b\u3059\u308b\u8a3c\u660e\u66f8\uff08URL\u304c<a class=\"underline\" href=\"https:\/\/%E3%81%A7%E5%A7%8B%E3%81%BE%E3%82%8B%E3%82%84%E3%81%A4%EF%BC%89\">https:\/\/\u3067\u59cb\u307e\u308b\u3084\u3064\uff09<\/a><\/li>\n<\/ul>\n<p class=\"whitespace-normal break-words\"><strong>\ud83c\udfd7\ufe0f \u30c7\u30d7\u30ed\u30a4\u30b5\u30fc\u30d3\u30b9\u6bd4\u8f03<\/strong><\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code>\u521d\u5fc3\u8005\u5411\u3051\u9806\u4f4d:\r\n\ud83d\udcca GitHub Pages\r\n\u251c\u2500 \u7121\u6599\r\n\u251c\u2500 \u8a2d\u5b9a\u7c21\u5358\r\n\u2514\u2500 \u9759\u7684\u30b5\u30a4\u30c8\uff08HTML\u30d5\u30a1\u30a4\u30eb\u306a\u3069\uff09\u306e\u307f\r\n\r\n\ud83d\udcca Netlify  \r\n\u251c\u2500 \u7121\u6599\u30d7\u30e9\u30f3\u3042\u308a\r\n\u251c\u2500 \u81ea\u52d5\u30d3\u30eb\u30c9\u6a5f\u80fd\r\n\u251c\u2500 \u30d5\u30a9\u30fc\u30e0\u6a5f\u80fd\r\n\u2514\u2500 \u30ab\u30b9\u30bf\u30e0\u30c9\u30e1\u30a4\u30f3\u5bfe\u5fdc\r\n\r\n\ud83d\udcca AWS\/\u30af\u30e9\u30a6\u30c9\r\n\u251c\u2500 \u6709\u6599\uff08\u4f7f\u3063\u305f\u5206\u3060\u3051\uff09\r\n\u251c\u2500 \u8a2d\u5b9a\u8907\u96d1\r\n\u251c\u2500 \u9ad8\u5ea6\u306a\u6a5f\u80fd\r\n\u2514\u2500 \u4f01\u696d\u30ec\u30d9\u30eb\u306e\u904b\u7528<\/code><\/pre>\n<\/div>\n<\/div>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">\ud83d\udc33 Docker\u95a2\u9023\u7528\u8a9e<\/h3>\n<p class=\"whitespace-normal break-words\"><strong>Docker \u3063\u3066\u4f55\uff1f<\/strong><\/p>\n<ul class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-disc space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\"><strong>Docker<\/strong>: \u30a2\u30d7\u30ea\u3092\u300c\u7bb1\u300d\u306b\u5165\u308c\u3066\u3001\u3069\u306e\u30b3\u30f3\u30d4\u30e5\u30fc\u30bf\u30fc\u3067\u3082\u540c\u3058\u3088\u3046\u306b\u52d5\u304b\u305b\u308b\u6280\u8853<\/li>\n<li class=\"whitespace-normal break-words\"><strong>\u30b3\u30f3\u30c6\u30ca<\/strong>: \u30a2\u30d7\u30ea\u3068\u5fc5\u8981\u306a\u30d5\u30a1\u30a4\u30eb\u3092\u5168\u90e8\u307e\u3068\u3081\u305f\u300c\u304a\u5f01\u5f53\u7bb1\u300d\u307f\u305f\u3044\u306a\u3082\u306e<\/li>\n<li class=\"whitespace-normal break-words\"><strong>\u30a4\u30e1\u30fc\u30b8<\/strong>: \u30b3\u30f3\u30c6\u30ca\u306e\u300c\u8a2d\u8a08\u56f3\u300d\u3084\u300c\u578b\u300d<\/li>\n<li class=\"whitespace-normal break-words\"><strong>Dockerfile<\/strong>: \u30b3\u30f3\u30c6\u30ca\u306e\u4f5c\u308a\u65b9\u3092\u66f8\u3044\u305f\u30ec\u30b7\u30d4<\/li>\n<li class=\"whitespace-normal break-words\"><strong>Docker Compose<\/strong>: \u8907\u6570\u306e\u30b3\u30f3\u30c6\u30ca\u3092\u4e00\u7dd2\u306b\u7ba1\u7406\u3059\u308b\u8a2d\u5b9a\u30d5\u30a1\u30a4\u30eb<\/li>\n<\/ul>\n<p class=\"whitespace-normal break-words\"><strong>\ud83c\udfad \u4f8b\u3048\u3067\u7406\u89e3\u3059\u308bDocker<\/strong><\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code>\u666e\u901a\u306e\u30a2\u30d7\u30ea\u914d\u5e03:\r\n\u300c\u3053\u306e\u30a2\u30d7\u30ea\u3092\u52d5\u304b\u3059\u306b\u306f\u3001Node.js v18\u3068\u3001\u3053\u306e\u30e9\u30a4\u30d6\u30e9\u30ea\u3068\u3001\u3042\u306e\u8a2d\u5b9a\u304c\u5fc5\u8981\u3067\u3059\u300d\r\n\u2192 \u74b0\u5883\u306b\u3088\u3063\u3066\u52d5\u3044\u305f\u308a\u52d5\u304b\u306a\u304b\u3063\u305f\u308a\r\n\r\nDocker\u3092\u4f7f\u3063\u305f\u914d\u5e03:\r\n\u300c\u3053\u306e\u7bb1\uff08\u30b3\u30f3\u30c6\u30ca\uff09\u3092\u958b\u3051\u308b\u3060\u3051\u3067\u3001\u3069\u3053\u3067\u3082\u52d5\u304d\u307e\u3059\u300d\r\n\u2192 \u3069\u3093\u306a\u74b0\u5883\u3067\u3082\u78ba\u5b9f\u306b\u52d5\u304f<\/code><\/pre>\n<\/div>\n<\/div>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">\ud83d\udd27 \u30b5\u30fc\u30d0\u30fc\u30fb\u30a4\u30f3\u30d5\u30e9\u7528\u8a9e<\/h3>\n<p class=\"whitespace-normal break-words\"><strong>Nginx\uff08\u30a8\u30f3\u30b8\u30f3\u30a8\u30c3\u30af\u30b9\uff09<\/strong><\/p>\n<ul class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-disc space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\"><strong>Nginx<\/strong>: \u8d85\u9ad8\u901f\u306aWeb\u30b5\u30fc\u30d0\u30fc\uff08\u30d5\u30a1\u30a4\u30eb\u3092\u30a4\u30f3\u30bf\u30fc\u30cd\u30c3\u30c8\u306b\u914d\u4fe1\u3059\u308b\u5c02\u7528\u30bd\u30d5\u30c8\uff09<\/li>\n<li class=\"whitespace-normal break-words\"><strong>Web\u30b5\u30fc\u30d0\u30fc<\/strong>: \u8a2a\u554f\u8005\u306bWeb\u30da\u30fc\u30b8\u3092\u5c4a\u3051\u308b\u914d\u9054\u54e1\u307f\u305f\u3044\u306a\u3082\u306e<\/li>\n<li class=\"whitespace-normal break-words\"><strong>\u30ea\u30d0\u30fc\u30b9\u30d7\u30ed\u30ad\u30b7<\/strong>: \u8907\u6570\u306e\u30b5\u30fc\u30d0\u30fc\u306e\u524d\u306b\u7acb\u3063\u3066\u3001\u30ea\u30af\u30a8\u30b9\u30c8\u3092\u632f\u308a\u5206\u3051\u308b\u4ea4\u901a\u6574\u7406\u54e1<\/li>\n<\/ul>\n<p class=\"whitespace-normal break-words\"><strong>\ud83c\udfd7\ufe0f Web\u30b5\u30fc\u30d0\u30fc\u306e\u5f79\u5272<\/strong><\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code>\u30e6\u30fc\u30b6\u30fc \u2192 Nginx \u2192 \u3042\u306a\u305f\u306e\u30a2\u30d7\u30ea\r\n        \u2191\r\n    \u30fb\u30d5\u30a1\u30a4\u30eb\u914d\u4fe1\r\n    \u30fbSSL\u8a3c\u660e\u66f8\u7ba1\u7406  \r\n    \u30fb\u30a2\u30af\u30bb\u30b9\u9ad8\u901f\u5316\r\n    \u30fb\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3<\/code><\/pre>\n<\/div>\n<\/div>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">\ud83d\udd10 \u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u95a2\u9023\u7528\u8a9e<\/h3>\n<p class=\"whitespace-normal break-words\"><strong>\u8a8d\u8a3c\u30fb\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3<\/strong><\/p>\n<ul class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-disc space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\"><strong>JWT\uff08\u30b8\u30a7\u30a4\u30c0\u30d6\u30ea\u30e5\u30fc\u30c6\u30a3\u30fc\uff09<\/strong>: \u30e6\u30fc\u30b6\u30fc\u304c\u672c\u4eba\u3067\u3042\u308b\u3053\u3068\u3092\u8a3c\u660e\u3059\u308b\u300c\u96fb\u5b50\u8eab\u5206\u8a3c\u660e\u66f8\u300d<\/li>\n<li class=\"whitespace-normal break-words\"><strong>JWT \u30b7\u30fc\u30af\u30ec\u30c3\u30c8<\/strong>: JWT\u3092\u4f5c\u308b\u305f\u3081\u306e\u79d8\u5bc6\u306e\u6697\u53f7\u9375\uff08\u7d76\u5bfe\u306b\u4eba\u306b\u6559\u3048\u3061\u3083\u30c0\u30e1\u306a\u5408\u8a00\u8449\uff09<\/li>\n<li class=\"whitespace-normal break-words\"><strong>CORS\uff08\u30b3\u30fc\u30b9\uff09<\/strong>: \u7570\u306a\u308b\u30b5\u30a4\u30c8\u304b\u3089\u306e\u30a2\u30af\u30bb\u30b9\u3092\u5236\u5fa1\u3059\u308b\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u6a5f\u80fd<\/li>\n<li class=\"whitespace-normal break-words\"><strong>API<\/strong>: \u30a2\u30d7\u30ea\u540c\u58eb\u304c\u4f1a\u8a71\u3059\u308b\u305f\u3081\u306e\u7a93\u53e3\u30fb\u4ed5\u7d44\u307f<\/li>\n<\/ul>\n<p class=\"whitespace-normal break-words\"><strong>\ud83d\udd11 \u8a8d\u8a3c\u306e\u6d41\u308c<\/strong><\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code>1. \u30e6\u30fc\u30b6\u30fc\u304c\u30ed\u30b0\u30a4\u30f3\r\n2. \u30b5\u30fc\u30d0\u30fc\u304cJWT\u30c8\u30fc\u30af\u30f3\uff08\u8eab\u5206\u8a3c\uff09\u3092\u767a\u884c\r\n3. \u30e6\u30fc\u30b6\u30fc\u304c\u30ea\u30af\u30a8\u30b9\u30c8\u6642\u306b\u30c8\u30fc\u30af\u30f3\u3092\u63d0\u793a\r\n4. \u30b5\u30fc\u30d0\u30fc\u304c\u30c8\u30fc\u30af\u30f3\u3092\u78ba\u8a8d\r\n5. \u672c\u4eba\u78ba\u8a8dOK \u2192 \u30a2\u30af\u30bb\u30b9\u8a31\u53ef<\/code><\/pre>\n<\/div>\n<\/div>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">\u2601\ufe0f \u30af\u30e9\u30a6\u30c9\u30fbAWS\u7528\u8a9e<\/h3>\n<p class=\"whitespace-normal break-words\"><strong>AWS\uff08Amazon Web Services\uff09<\/strong><\/p>\n<ul class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-disc space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\"><strong>AWS<\/strong>: Amazon\u304c\u63d0\u4f9b\u3059\u308b\u30af\u30e9\u30a6\u30c9\u30b5\u30fc\u30d3\u30b9\uff08\u30a4\u30f3\u30bf\u30fc\u30cd\u30c3\u30c8\u4e0a\u306e\u30b3\u30f3\u30d4\u30e5\u30fc\u30bf\u30fc\u30ec\u30f3\u30bf\u30eb\uff09<\/li>\n<li class=\"whitespace-normal break-words\"><strong>ECS<\/strong>: Docker \u30b3\u30f3\u30c6\u30ca\u3092\u52d5\u304b\u3059\u305f\u3081\u306eAWS\u30b5\u30fc\u30d3\u30b9<\/li>\n<li class=\"whitespace-normal break-words\"><strong>ECR<\/strong>: Docker \u30a4\u30e1\u30fc\u30b8\u3092\u4fdd\u5b58\u3057\u3066\u304a\u304f\u5009\u5eab<\/li>\n<li class=\"whitespace-normal break-words\"><strong>Fargate<\/strong>: \u30b5\u30fc\u30d0\u30fc\u7ba1\u7406\u3092\u81ea\u52d5\u5316\u3057\u3066\u304f\u308c\u308b\u30b5\u30fc\u30d3\u30b9<\/li>\n<\/ul>\n<p class=\"whitespace-normal break-words\"><strong>\ud83c\udf29\ufe0f \u30af\u30e9\u30a6\u30c9\u306e\u30e1\u30ea\u30c3\u30c8<\/strong><\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code>\u5f93\u6765\u306e\u30b5\u30fc\u30d0\u30fc:\r\n\u251c\u2500 \u7269\u7406\u7684\u306a\u30b3\u30f3\u30d4\u30e5\u30fc\u30bf\u30fc\u3092\u8cfc\u5165\r\n\u251c\u2500 \u96fb\u6c17\u4ee3\u30fb\u51b7\u623f\u4ee3\u304c\u5fc5\u8981\r\n\u251c\u2500 \u6545\u969c\u3057\u305f\u3089\u4fee\u7406\u304c\u5927\u5909\r\n\u2514\u2500 \u521d\u671f\u8cbb\u7528\u304c\u9ad8\u3044\r\n\r\n\u30af\u30e9\u30a6\u30c9:\r\n\u251c\u2500 \u4f7f\u3063\u305f\u5206\u3060\u3051\u6599\u91d1\r\n\u251c\u2500 \u6545\u969c\u6642\u306f\u81ea\u52d5\u3067\u5225\u30b5\u30fc\u30d0\u30fc\u306b\u79fb\u884c\r\n\u251c\u2500 \u4e16\u754c\u4e2d\u306b\u30b5\u30fc\u30d0\u30fc\u304c\u3042\u308b\r\n\u2514\u2500 \u3059\u3050\u306b\u59cb\u3081\u3089\u308c\u308b<\/code><\/pre>\n<\/div>\n<\/div>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">\ud83d\udd04 CI\/CD\u30fb\u81ea\u52d5\u5316\u7528\u8a9e<\/h3>\n<p class=\"whitespace-normal break-words\"><strong>GitHub Actions \/ \u30d1\u30a4\u30d7\u30e9\u30a4\u30f3<\/strong><\/p>\n<ul class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-disc space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\"><strong>CI\/CD<\/strong>: \u30b3\u30fc\u30c9\u306e\u5909\u66f4\u3092\u81ea\u52d5\u3067\u30c6\u30b9\u30c8\u30fb\u30c7\u30d7\u30ed\u30a4\u3059\u308b\u4ed5\u7d44\u307f<\/li>\n<li class=\"whitespace-normal break-words\"><strong>GitHub Actions<\/strong>: GitHub\u304c\u63d0\u4f9b\u3059\u308b\u81ea\u52d5\u5316\u30b5\u30fc\u30d3\u30b9<\/li>\n<li class=\"whitespace-normal break-words\"><strong>\u30d1\u30a4\u30d7\u30e9\u30a4\u30f3<\/strong>: \u300c\u30b3\u30fc\u30c9\u5909\u66f4 \u2192 \u30c6\u30b9\u30c8 \u2192 \u30c7\u30d7\u30ed\u30a4\u300d\u306e\u81ea\u52d5\u5316\u3055\u308c\u305f\u6d41\u308c<\/li>\n<li class=\"whitespace-normal break-words\"><strong>\u30ef\u30fc\u30af\u30d5\u30ed\u30fc<\/strong>: \u81ea\u52d5\u5316\u306e\u624b\u9806\u66f8<\/li>\n<\/ul>\n<p class=\"whitespace-normal break-words\"><strong>\ud83d\udd04 \u81ea\u52d5\u5316\u306e\u6d41\u308c<\/strong><\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code>\u958b\u767a\u8005\u304c\u30b3\u30fc\u30c9\u3092\u30d7\u30c3\u30b7\u30e5\r\n      \u2193\r\nGitHub Actions\u304c\u81ea\u52d5\u8d77\u52d5\r\n      \u2193\r\n1. \u30b3\u30fc\u30c9\u3092\u30c6\u30b9\u30c8\r\n2. \u554f\u984c\u306a\u3051\u308c\u3070\u30d3\u30eb\u30c9\r\n3. \u672c\u756a\u74b0\u5883\u306b\u30c7\u30d7\u30ed\u30a4\r\n      \u2193\r\n\u4e16\u754c\u4e2d\u306e\u30e6\u30fc\u30b6\u30fc\u304c\u65b0\u6a5f\u80fd\u3092\u4f7f\u3048\u308b<\/code><\/pre>\n<\/div>\n<\/div>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">\ud83c\udfaf \u74b0\u5883\u30fb\u8a2d\u5b9a\u7528\u8a9e<\/h3>\n<p class=\"whitespace-normal break-words\"><strong>\u74b0\u5883\u5909\u6570\u30fb\u8a2d\u5b9a<\/strong><\/p>\n<ul class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-disc space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\"><strong>\u74b0\u5883\u5909\u6570<\/strong>: \u30a2\u30d7\u30ea\u306e\u8a2d\u5b9a\u3092\u5916\u304b\u3089\u5909\u66f4\u3067\u304d\u308b\u4ed5\u7d44\u307f\uff08\u4f8b\uff1a\u958b\u767a\u7528\u3068\u672c\u756a\u7528\u3067\u8a2d\u5b9a\u3092\u5909\u3048\u308b\uff09<\/li>\n<li class=\"whitespace-normal break-words\"><strong>\u672c\u756a\u74b0\u5883<\/strong>: \u5b9f\u969b\u306b\u30e6\u30fc\u30b6\u30fc\u304c\u4f7f\u3046\u74b0\u5883<\/li>\n<li class=\"whitespace-normal break-words\"><strong>\u958b\u767a\u74b0\u5883<\/strong>: \u30d7\u30ed\u30b0\u30e9\u30de\u30fc\u304c\u4f5c\u696d\u3059\u308b\u74b0\u5883<\/li>\n<li class=\"whitespace-normal break-words\"><strong>\u30b9\u30c6\u30fc\u30b8\u30f3\u30b0\u74b0\u5883<\/strong>: \u672c\u756a\u524d\u306e\u30c6\u30b9\u30c8\u74b0\u5883<\/li>\n<\/ul>\n<p class=\"whitespace-normal break-words\"><strong>\ud83c\udfed \u74b0\u5883\u306e\u4f7f\u3044\u5206\u3051<\/strong><\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code>\u958b\u767a\u74b0\u5883\uff08Development\uff09\r\n\u251c\u2500 \u30d7\u30ed\u30b0\u30e9\u30de\u30fc\u304c\u4f5c\u696d\r\n\u251c\u2500 \u30d0\u30b0\u304c\u3042\u3063\u3066\u3082OK\r\n\u2514\u2500 \u81ea\u7531\u306b\u5b9f\u9a13\u3067\u304d\u308b\r\n\r\n\u30b9\u30c6\u30fc\u30b8\u30f3\u30b0\u74b0\u5883\uff08Staging\uff09  \r\n\u251c\u2500 \u672c\u756a\u524d\u306e\u6700\u7d42\u78ba\u8a8d\r\n\u251c\u2500 \u672c\u756a\u3068\u540c\u3058\u69cb\u6210\r\n\u2514\u2500 \u6700\u7d42\u30c6\u30b9\u30c8\u3092\u5b9f\u884c\r\n\r\n\u672c\u756a\u74b0\u5883\uff08Production\uff09\r\n\u251c\u2500 \u5b9f\u969b\u306e\u30e6\u30fc\u30b6\u30fc\u304c\u5229\u7528\r\n\u251c\u2500 \u7d76\u5bfe\u306b\u30d0\u30b0\u304c\u3042\u3063\u3066\u306f\u30c0\u30e1\r\n\u2514\u2500 \u614e\u91cd\u306b\u904b\u7528<\/code><\/pre>\n<\/div>\n<\/div>\n<h2 class=\"text-xl font-bold text-text-100 mt-1 -mb-0.5\">\ud83d\uddfa\ufe0f \u5168\u4f53\u69cb\u9020\u30de\u30c3\u30d7<\/h2>\n<p class=\"whitespace-normal break-words\">\ud83d\udc3b\u200d\u2744\ufe0f\u300c\u8a18\u4e8b\u5168\u4f53\u306e\u69cb\u9020\u3092\u56f3\u3067\u8868\u3057\u3066\u307f\u305f\u305e\u3044\uff01\u8ff7\u5b50\u306b\u306a\u3089\u306a\u3044\u3088\u3046\u306b\u306a\u300d<\/p>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">\ud83d\udcc8 \u6280\u8853\u30ec\u30d9\u30eb\u5225\u5b66\u7fd2\u30de\u30c3\u30d7<\/h3>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code>\ud83c\udfaf \u521d\u5fc3\u8005\u30ec\u30d9\u30eb\r\n\u251c\u2500\u2500 GitHub\u30a2\u30ab\u30a6\u30f3\u30c8\u4f5c\u6210\r\n\u251c\u2500\u2500 \u57fa\u672c\u7684\u306aGit\u64cd\u4f5c\r\n\u251c\u2500\u2500 Claude Code\u5c0e\u5165\r\n\u251c\u2500\u2500 GitHub Pages\uff08\u7c21\u5358\u30c7\u30d7\u30ed\u30a4\uff09\r\n\u2514\u2500\u2500 \ud83d\udcda\u7528\u8a9e: \u30ea\u30dd\u30b8\u30c8\u30ea\u3001\u30b3\u30df\u30c3\u30c8\u3001\u30d7\u30c3\u30b7\u30e5\u3001\u30c9\u30e1\u30a4\u30f3\r\n\r\n\ud83c\udfaf \u4e2d\u7d1a\u8005\u30ec\u30d9\u30eb  \r\n\u251c\u2500\u2500 \u30d6\u30e9\u30f3\u30c1\u904b\u7528\r\n\u251c\u2500\u2500 \u30d7\u30eb\u30ea\u30af\u30a8\u30b9\u30c8\r\n\u251c\u2500\u2500 Netlify\uff08\u9ad8\u6a5f\u80fd\u30c7\u30d7\u30ed\u30a4\uff09\r\n\u251c\u2500\u2500 \u74b0\u5883\u5909\u6570\r\n\u2514\u2500\u2500 \ud83d\udcda\u7528\u8a9e: CI\/CD\u3001SSL\u3001API\u3001CORS\r\n\r\n\ud83c\udfaf \u4e0a\u7d1a\u8005\u30ec\u30d9\u30eb\r\n\u251c\u2500\u2500 Docker \u30b3\u30f3\u30c6\u30ca\u5316\r\n\u251c\u2500\u2500 AWS \u30af\u30e9\u30a6\u30c9\u30c7\u30d7\u30ed\u30a4\r\n\u251c\u2500\u2500 \u672c\u683c\u7684\u306aCI\/CD\r\n\u251c\u2500\u2500 \u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u5bfe\u7b56\r\n\u2514\u2500\u2500 \ud83d\udcda\u7528\u8a9e: \u30b3\u30f3\u30c6\u30ca\u3001JWT\u3001ECS\u3001\u30d1\u30a4\u30d7\u30e9\u30a4\u30f3<\/code><\/pre>\n<\/div>\n<\/div>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">\ud83c\udfd7\ufe0f \u30b7\u30b9\u30c6\u30e0\u5168\u4f53\u69cb\u9020\u56f3<\/h3>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code>\u3042\u306a\u305f\u306ePC\uff08\u958b\u767a\u74b0\u5883\uff09\r\n\u251c\u2500\u2500 \ud83d\udcdd \u30b3\u30fc\u30c9\u3092\u66f8\u304f\r\n\u251c\u2500\u2500 \ud83e\uddea \u30c6\u30b9\u30c8\u3059\u308b\r\n\u251c\u2500\u2500 \ud83d\udcc1 Git \u3067\u7ba1\u7406\r\n\u2514\u2500\u2500 \u2601\ufe0f GitHub \u306b\u30d7\u30c3\u30b7\u30e5\r\n        \u2193\r\nGitHub\uff08\u30b3\u30fc\u30c9\u7ba1\u7406\uff09\r\n\u251c\u2500\u2500 \ud83d\udccb Issue \u3067\u4f5c\u696d\u7ba1\u7406\r\n\u251c\u2500\u2500 \ud83d\udd04 Pull Request \u3067\u30ec\u30d3\u30e5\u30fc\r\n\u251c\u2500\u2500 \ud83e\udd16 Actions \u3067\u81ea\u52d5\u5316\r\n\u2514\u2500\u2500 \ud83d\ude80 \u81ea\u52d5\u30c7\u30d7\u30ed\u30a4\u5b9f\u884c\r\n        \u2193\r\n\u30c7\u30d7\u30ed\u30a4\u5148\uff08\u672c\u756a\u74b0\u5883\uff09\r\n\u251c\u2500\u2500 \ud83c\udd93 GitHub Pages\uff08\u521d\u5fc3\u8005\u5411\u3051\uff09\r\n\u251c\u2500\u2500 \u26a1 Netlify\uff08\u4e2d\u7d1a\u8005\u5411\u3051\uff09\r\n\u251c\u2500\u2500 \ud83d\udc33 Docker\uff08\u4e0a\u7d1a\u8005\u5411\u3051\uff09\r\n\u2514\u2500\u2500 \u2601\ufe0f AWS\uff08\u4f01\u696d\u30ec\u30d9\u30eb\uff09\r\n        \u2193\r\n\ud83c\udf0d \u4e16\u754c\u4e2d\u306e\u30e6\u30fc\u30b6\u30fc\u304c\u30a2\u30af\u30bb\u30b9<\/code><\/pre>\n<\/div>\n<\/div>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">\ud83d\udd04 \u958b\u767a\u30d5\u30ed\u30fc\u306e\u5168\u4f53\u50cf<\/h3>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code>\ud83d\udcc5 \u671d\u306e\u4f5c\u696d\u958b\u59cb\r\n\u251c\u2500\u2500 Claude Code \u3067\u72b6\u6cc1\u78ba\u8a8d\r\n\u251c\u2500\u2500 \u65b0\u6a5f\u80fd\u30d6\u30e9\u30f3\u30c1\u3092\u4f5c\u6210\r\n\u251c\u2500\u2500 \ud83d\udee0\ufe0f \u958b\u767a\u4f5c\u696d\r\n\u2502   \u251c\u2500\u2500 \u30b3\u30fc\u30c7\u30a3\u30f3\u30b0\r\n\u2502   \u251c\u2500\u2500 \u30c6\u30b9\u30c8\u4f5c\u6210\r\n\u2502   \u2514\u2500\u2500 \u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u66f4\u65b0\r\n\u251c\u2500\u2500 \ud83d\udcdd \u30b3\u30df\u30c3\u30c8 &amp; \u30d7\u30c3\u30b7\u30e5\r\n\u251c\u2500\u2500 \ud83d\udd04 \u30d7\u30eb\u30ea\u30af\u30a8\u30b9\u30c8\u4f5c\u6210\r\n\u251c\u2500\u2500 \ud83d\udc65 \u30b3\u30fc\u30c9\u30ec\u30d3\u30e5\u30fc\r\n\u251c\u2500\u2500 \u2705 \u30de\u30fc\u30b8\u3057\u3066\u672c\u756a\u53cd\u6620\r\n\u2514\u2500\u2500 \ud83c\udf19 \u4e00\u65e5\u306e\u4f5c\u696d\u307e\u3068\u3081<\/code><\/pre>\n<\/div>\n<\/div>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">\ud83d\udee0\ufe0f \u4f7f\u7528\u6280\u8853\u306e\u5f79\u5272\u5206\u62c5<\/h3>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code>\u958b\u767a\u30d5\u30a7\u30fc\u30ba\r\n\u251c\u2500\u2500 \ud83d\udcbb \u30b3\u30fc\u30c9\u4f5c\u6210: Claude Code + \u3042\u306a\u305f\r\n\u251c\u2500\u2500 \ud83d\udcc1 \u30d0\u30fc\u30b8\u30e7\u30f3\u7ba1\u7406: Git + GitHub\r\n\u251c\u2500\u2500 \ud83e\uddea \u30c6\u30b9\u30c8: \u81ea\u52d5\u30c6\u30b9\u30c8 + Claude Code\r\n\u2514\u2500\u2500 \ud83d\udcda \u30c9\u30ad\u30e5\u30e1\u30f3\u30c8: Markdown + Claude Code\r\n\r\n\u30c7\u30d7\u30ed\u30a4\u30d5\u30a7\u30fc\u30ba  \r\n\u251c\u2500\u2500 \ud83c\udf10 \u7c21\u5358\u516c\u958b: GitHub Pages\r\n\u251c\u2500\u2500 \u26a1 \u9ad8\u6a5f\u80fd\u516c\u958b: Netlify\r\n\u251c\u2500\u2500 \ud83d\udc33 \u30b3\u30f3\u30c6\u30ca\u5316: Docker + Nginx\r\n\u2514\u2500\u2500 \u2601\ufe0f \u4f01\u696d\u30ec\u30d9\u30eb: AWS + ECS\r\n\r\n\u904b\u7528\u30d5\u30a7\u30fc\u30ba\r\n\u251c\u2500\u2500 \ud83d\udd0d \u76e3\u8996: \u30ed\u30b0 + \u30a2\u30e9\u30fc\u30c8\r\n\u251c\u2500\u2500 \ud83d\udd04 \u66f4\u65b0: CI\/CD \u30d1\u30a4\u30d7\u30e9\u30a4\u30f3\r\n\u251c\u2500\u2500 \ud83d\udee1\ufe0f \u30bb\u30ad\u30e5\u30ea\u30c6\u30a3: JWT + CORS + SSL\r\n\u2514\u2500\u2500 \ud83d\udcca \u5206\u6790: \u30a2\u30af\u30bb\u30b9\u89e3\u6790<\/code><\/pre>\n<\/div>\n<\/div>\n<p class=\"whitespace-pre-wrap break-words\">\ud83d\udc3b\u200d\u2744\ufe0f\u300c\u3069\u3046\u3058\u3083\uff01\u3053\u308c\u3067\u5c02\u9580\u7528\u8a9e\u3082\u5168\u4f53\u306e\u6d41\u308c\u3082\u7406\u89e3\u3067\u304d\u308b\u306f\u305a\u3058\u3083\u300d \ud83e\uddf8\u300c\u3059\u3054\u304f\u308f\u304b\u308a\u3084\u3059\u304f\u306a\u3063\u305f\u30af\u30de\uff01\u5c02\u9580\u7528\u8a9e\u304c\u8eab\u8fd1\u306b\u611f\u3058\u3089\u308c\u308b\u3088\u300d \ud83d\udc3b\u200d\u2744\ufe0f\u300c\u5c02\u9580\u7528\u8a9e\u306f\u6700\u521d\u306f\u96e3\u3057\u304f\u611f\u3058\u308b\u304c\u3001\u4e00\u3064\u305a\u3064\u899a\u3048\u3066\u3044\u3051\u3070\u5fc5\u305a\u7406\u89e3\u3067\u304d\u308b\u3088\u3046\u306b\u306a\u308b\u305e\u3044\uff01\u300d<\/p>\n<h2 class=\"text-xl font-bold text-text-100 mt-1 -mb-0.5\">\ud83c\udf08 \u307e\u3068\u3081\uff1aAI\u6642\u4ee3\u306e\u958b\u767a\u8005\u3068\u3057\u3066<\/h2>\n<p class=\"whitespace-pre-wrap break-words\">\ud83d\udc3b\u200d\u2744\ufe0f\u300c\u9577\u3044\u8a18\u4e8b\u306b\u306a\u3063\u305f\u304c\u3001\u6700\u5f8c\u307e\u3067\u8aad\u3093\u3067\u304f\u308c\u3066\u3042\u308a\u304c\u3068\u3046\u306a\u306e\u3058\u3083\uff01\u300d \ud83e\uddf8\u300c\u3059\u3054\u304f\u52c9\u5f37\u306b\u306a\u3063\u305f\u30af\u30de\uff01\u3067\u3082\u899a\u3048\u308b\u3053\u3068\u304c\u305f\u304f\u3055\u3093\u3042\u308b\u306d\u300d \ud83d\udc3b\u200d\u2744\ufe0f\u300c\u4e00\u5ea6\u306b\u5168\u90e8\u899a\u3048\u308b\u5fc5\u8981\u306f\u306a\u3044\u305e\u3044\u3002\u5b9f\u969b\u306b\u4f7f\u3044\u306a\u304c\u3089\u3001\u5c11\u3057\u305a\u3064\u30de\u30b9\u30bf\u30fc\u3057\u3066\u3044\u3051\u3070\u3044\u3044\u306e\u3058\u3083\u300d<\/p>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">\ud83c\udfaf \u6bb5\u968e\u5225\u5b66\u7fd2\u30ed\u30fc\u30c9\u30de\u30c3\u30d7<\/h3>\n<p class=\"whitespace-normal break-words\"><strong>\ud83d\udfe2 \u521d\u7d1a\u8005\uff081-2\u9031\u9593\u76ee\u6a19\uff09<\/strong><\/p>\n<ul class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-disc space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\">GitHub\u30a2\u30ab\u30a6\u30f3\u30c8\u4f5c\u6210<\/li>\n<li class=\"whitespace-normal break-words\">\u57fa\u672c\u7684\u306aGit\u64cd\u4f5c\uff08add, commit, push\uff09<\/li>\n<li class=\"whitespace-normal break-words\">Claude Code\u306e\u5c0e\u5165\u3068\u57fa\u672c\u4f7f\u7528<\/li>\n<li class=\"whitespace-normal break-words\">\u500b\u4eba\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3067\u306e\u7df4\u7fd2<\/li>\n<\/ul>\n<p class=\"whitespace-normal break-words\"><strong>\ud83d\udfe1 \u4e2d\u7d1a\u8005\uff081-2\u30f6\u6708\u76ee\u6a19\uff09<\/strong><\/p>\n<ul class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-disc space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\">\u30d6\u30e9\u30f3\u30c1\u904b\u7528\u306e\u7406\u89e3<\/li>\n<li class=\"whitespace-normal break-words\">\u30d7\u30eb\u30ea\u30af\u30a8\u30b9\u30c8\u3068\u30b3\u30fc\u30c9\u30ec\u30d3\u30e5\u30fc<\/li>\n<li class=\"whitespace-normal break-words\">CI\/CD \u306e\u57fa\u672c\uff08GitHub Actions\uff09<\/li>\n<li class=\"whitespace-normal break-words\">\u30c1\u30fc\u30e0\u958b\u767a\u3078\u306e\u53c2\u52a0<\/li>\n<\/ul>\n<p class=\"whitespace-normal break-words\"><strong>\ud83d\udd34 \u4e0a\u7d1a\u8005\uff083-6\u30f6\u6708\u76ee\u6a19\uff09<\/strong><\/p>\n<ul class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-disc space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\">\u8907\u96d1\u306a\u30de\u30fc\u30b8\u6226\u7565<\/li>\n<li class=\"whitespace-normal break-words\">\u30ab\u30b9\u30bf\u30e0\u30ef\u30fc\u30af\u30d5\u30ed\u30fc\u306e\u69cb\u7bc9<\/li>\n<li class=\"whitespace-normal break-words\">\u672c\u683c\u7684\u306a\u30c7\u30d7\u30ed\u30a4\u904b\u7528<\/li>\n<li class=\"whitespace-normal break-words\">\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u3068\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u6700\u9069\u5316<\/li>\n<\/ul>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">\ud83d\udc8e \u6700\u5f8c\u306e\u30a2\u30c9\u30d0\u30a4\u30b9<\/h3>\n<p class=\"whitespace-normal break-words\">Claude Code\u3068GitHub\u306e\u9023\u643a\u306f\u3001\u5358\u306a\u308b\u30c4\u30fc\u30eb\u306e\u7d44\u307f\u5408\u308f\u305b\u3092\u8d85\u3048\u3066\u3001\u958b\u767a\u8005\u306e\u50cd\u304d\u65b9\u3092\u6839\u672c\u304b\u3089\u5909\u3048\u308b\u53ef\u80fd\u6027\u3092\u79d8\u3081\u3066\u304a\u308b\u306e\u3058\u3083\u3002\u308f\u3057\u305f\u3061\u306f\u3082\u306f\u3084\u3001\u3059\u3079\u3066\u306e\u30b3\u30fc\u30c9\u3092\u4e00\u304b\u3089\u66f8\u304f\u5fc5\u8981\u306f\u306a\u3044\u3002\u4ee3\u308f\u308a\u306b\u3001AI\u30a8\u30fc\u30b8\u30a7\u30f3\u30c8\u3092\u52b9\u679c\u7684\u306b\u6307\u63ee\u3057\u3001\u3088\u308a\u9ad8\u6b21\u5143\u306e\u8a2d\u8a08\u3084\u5224\u65ad\u306b\u96c6\u4e2d\u3067\u304d\u308b\u3088\u3046\u306b\u306a\u3063\u305f\u306e\u3067\u3059\u305e\uff01<\/p>\n<p class=\"whitespace-pre-wrap break-words\">\ud83d\udc3b\u200d\u2744\ufe0f\u300c\u304a\u4e3b\u3082\u3001\u3053\u306eAI\u9769\u547d\u306e\u6ce2\u306b\u4e57\u308a\u9045\u308c\u306a\u3044\u3088\u3046\u3001\u4eca\u65e5\u304b\u3089\u8a66\u3057\u3066\u307f\u308b\u3053\u3068\u3092\u304a\u3059\u3059\u3081\u3059\u308b\u306e\u3058\u3083\u300d \ud83e\uddf8\u300c\u3057\u308d\u304f\u307e\u3055\u3093\u306e\u304a\u304b\u3052\u3067\u3001\u306a\u3093\u3060\u304b\u3084\u3063\u3066\u307f\u305f\u304f\u306a\u3063\u305f\u30af\u30de\uff01\u300d \ud83d\udc3b\u200d\u2744\ufe0f\u300c\u305d\u308c\u306f\u826f\u304b\u3063\u305f\u306e\u3058\u3083\uff01\u6700\u521d\u306f\u5c0f\u3055\u306a\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u304b\u3089\u59cb\u3081\u3066\u3001\u5f90\u3005\u306b\u6163\u308c\u3066\u3044\u304f\u306e\u304c\u30b3\u30c4\u3067\u3059\u305e\u301c\u2728\u300d<\/p>\n<p class=\"whitespace-normal break-words\">\u305f\u3060\u3057\u3001AI\u30c4\u30fc\u30eb\u306f\u9b54\u6cd5\u306e\u6756\u3067\u306f\u306a\u3044\u3053\u3068\u3092\u5fd8\u308c\u305a\u306b\u3002\u9069\u5207\u306a\u554f\u984c\u8a2d\u5b9a\u3068\u3001\u4eba\u9593\u306b\u3088\u308b\u5224\u65ad\u304c\u3001\u3053\u308c\u3089\u306e\u30c4\u30fc\u30eb\u306e\u771f\u4fa1\u3092\u5f15\u304d\u51fa\u3059\u9375\u3068\u306a\u308b\u306e\u3058\u3083\u3002\u3055\u3042\u3001\u304a\u4e3b\u3082AI\u6642\u4ee3\u306e\u958b\u767a\u8005\u3068\u3057\u3066\u3001\u65b0\u3057\u3044\u5192\u967a\u3092\u59cb\u3081\u3066\u307f\u306a\u3044\u304b\u306e\uff1f\ud83c\udf1f<\/p>\n<p class=\"whitespace-normal break-words\"><strong>\u6700\u5f8c\u306b\u4e00\u8a00<\/strong>: \u6280\u8853\u306f\u65e5\u9032\u6708\u6b69\u3058\u3083\u3002\u4eca\u65e5\u5b66\u3093\u3060\u3053\u3068\u3082\u3001\u660e\u65e5\u306b\u306f\u3082\u3063\u3068\u826f\u3044\u65b9\u6cd5\u304c\u898b\u3064\u304b\u308b\u304b\u3082\u3057\u308c\u3093\u3002\u5e38\u306b\u5b66\u3073\u7d9a\u3051\u308b\u59ff\u52e2\u3092\u5fd8\u308c\u305a\u306b\u3001\u697d\u3057\u304f\u958b\u767a\u3057\u3066\u3044\u3053\u3046\u3058\u3083\u306a\u3044\u304b\uff01\uff8a\uff6f\uff8a\uff70 \ud83d\udc3b\u200d\u2744\ufe0f\u2728: \u304a\u306f\u3088\u3046\uff01\u4eca\u65e5\u306f\u30e6\u30fc\u30b6\u30fc\u30ed\u30b0\u30a4\u30f3\u6a5f\u80fd\u3092\u4f5c\u308b\u4e88\u5b9a\u306a\u3093\u3060<\/p>\n<p class=\"whitespace-pre-wrap break-words\">claude: \u304a\u306f\u3088\u3046\u3054\u3056\u3044\u307e\u3059\uff01\u30e6\u30fc\u30b6\u30fc\u30ed\u30b0\u30a4\u30f3\u6a5f\u80fd\u306e\u958b\u767a\u3067\u3059\u306d\u3002 \u307e\u305a\u73fe\u5728\u306e\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u72b6\u6cc1\u3092\u78ba\u8a8d\u3057\u3066\u304b\u3089\u3001\u4f5c\u696d\u8a08\u753b\u3092\u7acb\u3066\u307e\u3057\u3087\u3046\u3002<\/p>\n<p class=\"whitespace-normal break-words\">[\u30d5\u30a1\u30a4\u30eb\u69cb\u9020\u3092\u5206\u6790\u4e2d&#8230;]<\/p>\n<p class=\"whitespace-pre-wrap break-words\">\u73fe\u5728\u306e\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306f Express.js \u30d9\u30fc\u30b9\u306e Web API \u306e\u3088\u3046\u3067\u3059\u306d\u3002 \u8a8d\u8a3c\u95a2\u9023\u306e\u30d5\u30a1\u30a4\u30eb\u306f\u307e\u3060\u306a\u3044\u3088\u3046\u3067\u3059\u3002<\/p>\n<p class=\"whitespace-normal break-words\">\u4f5c\u696d\u8a08\u753b\u3092\u63d0\u6848\u3057\u307e\u3059\uff1a<\/p>\n<ol class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-decimal space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\">feature\/user-auth \u30d6\u30e9\u30f3\u30c1\u3092\u4f5c\u6210<\/li>\n<li class=\"whitespace-normal break-words\">\u8a8d\u8a3c\u30df\u30c9\u30eb\u30a6\u30a7\u30a2\u306e\u5b9f\u88c5<\/li>\n<li class=\"whitespace-normal break-words\">\u30e6\u30fc\u30b6\u30fc\u767b\u9332\u30fb\u30ed\u30b0\u30a4\u30f3\u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u30c8\u306e\u4f5c\u6210<\/li>\n<li class=\"whitespace-normal break-words\">JWT \u30c8\u30fc\u30af\u30f3\u51e6\u7406\u306e\u5b9f\u88c5<\/li>\n<li class=\"whitespace-normal break-words\">\u30c6\u30b9\u30c8\u30b3\u30fc\u30c9\u306e\u4f5c\u6210<\/li>\n<\/ol>\n<p class=\"whitespace-normal break-words\">\u3053\u306e\u8a08\u753b\u3067\u3088\u308d\u3057\u3044\u3067\u3057\u3087\u3046\u304b\uff1f<\/p>\n<p class=\"whitespace-normal break-words\">\u958b\u767a\u8005: \u3044\u3044\u306d\uff01\u307e\u305a\u306f\u30d6\u30e9\u30f3\u30c1\u3092\u4f5c\u3063\u3066\u3082\u3089\u3048\u308b\uff1f<\/p>\n<p class=\"whitespace-normal break-words\">claude: \u627f\u77e5\u3057\u307e\u3057\u305f\uff01feature\/user-auth \u30d6\u30e9\u30f3\u30c1\u3092\u4f5c\u6210\u3057\u307e\u3059\u3002<\/p>\n<p class=\"whitespace-normal break-words\">[git checkout -b feature\/user-auth \u3092\u5b9f\u884c]<\/p>\n<p class=\"whitespace-pre-wrap break-words\">\u30d6\u30e9\u30f3\u30c1\u3092\u4f5c\u6210\u3057\u307e\u3057\u305f\u3002\u73fe\u5728 feature\/user-auth \u30d6\u30e9\u30f3\u30c1\u306b\u3044\u307e\u3059\u3002 \u6b21\u306b\u8a8d\u8a3c\u30df\u30c9\u30eb\u30a6\u30a7\u30a2\u304b\u3089\u59cb\u3081\u307e\u3057\u3087\u3046\u304b\uff1f<\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code>\r\n#### \ud83d\udee0\ufe0f **\u5b9f\u88c5\u30d5\u30a7\u30fc\u30ba**<\/code><\/pre>\n<\/div>\n<\/div>\n<p class=\"whitespace-normal break-words\">\u958b\u767a\u8005: \u8a8d\u8a3c\u30df\u30c9\u30eb\u30a6\u30a7\u30a2\u3092\u4f5c\u3063\u3066<\/p>\n<p class=\"whitespace-pre-wrap break-words\">claude: \u30e6\u30fc\u30b6\u30fc\u8a8d\u8a3c\u306e\u30df\u30c9\u30eb\u30a6\u30a7\u30a2\u3092\u4f5c\u6210\u3057\u307e\u3059\u306d\u3002 JWT \u30c8\u30fc\u30af\u30f3\u30d9\u30fc\u30b9\u306e\u8a8d\u8a3c\u3092\u5b9f\u88c5\u3057\u307e\u3059\u3002<\/p>\n<p class=\"whitespace-normal break-words\">[middleware\/auth.js \u3092\u4f5c\u6210\u4e2d&#8230;]<\/p>\n<p class=\"whitespace-normal break-words\">\u8a8d\u8a3c\u30df\u30c9\u30eb\u30a6\u30a7\u30a2\u3092\u4f5c\u6210\u3057\u307e\u3057\u305f\u3002\u4e3b\u306a\u6a5f\u80fd\uff1a<\/p>\n<ul class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-disc space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\">JWT \u30c8\u30fc\u30af\u30f3\u306e\u691c\u8a3c<\/li>\n<li class=\"whitespace-normal break-words\">\u30e6\u30fc\u30b6\u30fc\u60c5\u5831\u306e req.user \u3078\u306e\u8ffd\u52a0<\/li>\n<li class=\"whitespace-normal break-words\">\u30a8\u30e9\u30fc\u30cf\u30f3\u30c9\u30ea\u30f3\u30b0<\/li>\n<\/ul>\n<p class=\"whitespace-normal break-words\">\u6b21\u306b\u30e6\u30fc\u30b6\u30fc\u767b\u9332\u30fb\u30ed\u30b0\u30a4\u30f3\u306e\u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u30c8\u3092\u4f5c\u6210\u3057\u307e\u3059\u304b\uff1f<\/p>\n<p class=\"whitespace-normal break-words\">\u958b\u767a\u8005: \u3046\u3093\u3001\u3067\u3082\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u9762\u3067\u6ce8\u610f\u70b9\u306f\u3042\u308b\uff1f<\/p>\n<p class=\"whitespace-normal break-words\">claude: \u826f\u3044\u8cea\u554f\u3067\u3059\u306d\uff01\u4ee5\u4e0b\u306e\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u5bfe\u7b56\u3092\u5b9f\u88c5\u306b\u542b\u3081\u3066\u3044\u307e\u3059\uff1a<\/p>\n<ol class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-decimal space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\"><strong>\u30d1\u30b9\u30ef\u30fc\u30c9\u30cf\u30c3\u30b7\u30e5\u5316<\/strong>: bcrypt \u3092\u4f7f\u7528<\/li>\n<li class=\"whitespace-normal break-words\"><strong>JWT \u30b7\u30fc\u30af\u30ec\u30c3\u30c8<\/strong>: \u74b0\u5883\u5909\u6570\u304b\u3089\u53d6\u5f97<\/li>\n<li class=\"whitespace-normal break-words\"><strong>\u30ec\u30fc\u30c8\u5236\u9650<\/strong>: express-rate-limit \u3067\u653b\u6483\u9632\u6b62<\/li>\n<li class=\"whitespace-normal break-words\"><strong>\u5165\u529b\u691c\u8a3c<\/strong>: joi \u3067\u30d0\u30ea\u30c7\u30fc\u30b7\u30e7\u30f3<\/li>\n<li class=\"whitespace-normal break-words\"><strong>CORS \u8a2d\u5b9a<\/strong>: \u9069\u5207\u306a\u30aa\u30ea\u30b8\u30f3\u5236\u9650<\/li>\n<\/ol>\n<p class=\"whitespace-normal break-words\">\u3053\u308c\u3089\u3092\u542b\u3081\u305f\u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u30c8\u3092\u4f5c\u6210\u3057\u307e\u3057\u3087\u3046\u3002<\/p>\n<p class=\"whitespace-normal break-words\">[routes\/auth.js \u3092\u4f5c\u6210\u4e2d&#8230;]<\/p>\n<p class=\"whitespace-normal break-words\">\u8a8d\u8a3c\u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u30c8\u304c\u5b8c\u6210\u3057\u307e\u3057\u305f\uff1a<\/p>\n<ul class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-disc space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\">POST \/auth\/register (\u30e6\u30fc\u30b6\u30fc\u767b\u9332)<\/li>\n<li class=\"whitespace-normal break-words\">POST \/auth\/login (\u30ed\u30b0\u30a4\u30f3)<\/li>\n<li class=\"whitespace-normal break-words\">GET \/auth\/profile (\u30d7\u30ed\u30d5\u30a3\u30fc\u30eb\u53d6\u5f97)<\/li>\n<\/ul>\n<p class=\"whitespace-normal break-words\">\u958b\u767a\u8005: \u30c6\u30b9\u30c8\u3082\u66f8\u3044\u3066\u3082\u3089\u3048\u308b\uff1f<\/p>\n<p class=\"whitespace-normal break-words\">claude: \u3082\u3061\u308d\u3093\u3067\u3059\uff01\u30c6\u30b9\u30c8\u99c6\u52d5\u958b\u767a\u306e\u624b\u6cd5\u3067\u3001\u5305\u62ec\u7684\u306a\u30c6\u30b9\u30c8\u3092\u4f5c\u6210\u3057\u307e\u3059\u3002<\/p>\n<p class=\"whitespace-normal break-words\">[tests\/auth.test.js \u3092\u4f5c\u6210\u4e2d&#8230;]<\/p>\n<p class=\"whitespace-normal break-words\">\u4ee5\u4e0b\u306e\u30c6\u30b9\u30c8\u30b1\u30fc\u30b9\u3092\u4f5c\u6210\u3057\u307e\u3057\u305f\uff1a \u2705 \u30e6\u30fc\u30b6\u30fc\u767b\u9332\u306e\u6210\u529f\u30b1\u30fc\u30b9 \u2705 \u91cd\u8907\u30e6\u30fc\u30b6\u30fc\u767b\u9332\u306e\u5931\u6557\u30b1\u30fc\u30b9<br \/>\n\u2705 \u30ed\u30b0\u30a4\u30f3\u306e\u6210\u529f\u30fb\u5931\u6557\u30b1\u30fc\u30b9 \u2705 JWT \u30c8\u30fc\u30af\u30f3\u306e\u691c\u8a3c\u30c6\u30b9\u30c8 \u2705 \u7121\u52b9\u306a\u30c8\u30fc\u30af\u30f3\u3067\u306e\u30a2\u30af\u30bb\u30b9\u30c6\u30b9\u30c8<\/p>\n<p class=\"whitespace-normal break-words\">\u30c6\u30b9\u30c8\u3092\u5b9f\u884c\u3057\u307e\u3059\u304b\uff1f<\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code>\r\n#### \ud83d\udd0d **\u30c6\u30b9\u30c8\u3068\u30c7\u30d0\u30c3\u30b0**<\/code><\/pre>\n<\/div>\n<\/div>\n<p class=\"whitespace-normal break-words\">\u958b\u767a\u8005: \u30c6\u30b9\u30c8\u3092\u5b9f\u884c\u3057\u3066\u307f\u3066<\/p>\n<p class=\"whitespace-normal break-words\">claude: \u30c6\u30b9\u30c8\u3092\u5b9f\u884c\u3057\u307e\u3059\u3002<\/p>\n<p class=\"whitespace-normal break-words\">[npm test \u3092\u5b9f\u884c\u4e2d&#8230;]<\/p>\n<p class=\"whitespace-pre-wrap break-words\">\u30c6\u30b9\u30c8\u7d50\u679c\uff1a \u2705 auth.test.js: 8 passing \u274c 1 failing<\/p>\n<p class=\"whitespace-normal break-words\">\u5931\u6557\u3057\u305f\u30c6\u30b9\u30c8:<\/p>\n<ul class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-disc space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\">&#8220;should return 401 for invalid token&#8221;<\/li>\n<\/ul>\n<p class=\"whitespace-normal break-words\">\u30a8\u30e9\u30fc\u5185\u5bb9\u3092\u8abf\u67fb\u4e2d&#8230;<\/p>\n<p class=\"whitespace-pre-wrap break-words\">\u554f\u984c\u3092\u767a\u898b\u3057\u307e\u3057\u305f\uff1aJWT \u306e\u6709\u52b9\u671f\u9650\u8a2d\u5b9a\u306b\u8aa4\u308a\u304c\u3042\u308a\u307e\u3057\u305f\u3002 \u4fee\u6b63\u3092\u884c\u3044\u307e\u3059\u3002<\/p>\n<p class=\"whitespace-normal break-words\">[middleware\/auth.js \u3092\u4fee\u6b63\u4e2d&#8230;]<\/p>\n<p class=\"whitespace-normal break-words\">\u4fee\u6b63\u5b8c\u4e86\u3057\u307e\u3057\u305f\u3002\u518d\u5ea6\u30c6\u30b9\u30c8\u3092\u5b9f\u884c\u3057\u307e\u3059\u3002<\/p>\n<p class=\"whitespace-normal break-words\">[npm test \u3092\u5b9f\u884c\u4e2d&#8230;]<\/p>\n<p class=\"whitespace-pre-wrap break-words\">\u2705 \u5168\u3066\u306e\u30c6\u30b9\u30c8\u304c\u30d1\u30b9\u3057\u307e\u3057\u305f\uff01 \u30c6\u30b9\u30c8\u30ab\u30d0\u30ec\u30c3\u30b8: 95%<\/p>\n<p class=\"whitespace-normal break-words\">\u958b\u767a\u8005: \u7d20\u6674\u3089\u3057\u3044\uff01\u30b3\u30df\u30c3\u30c8\u3057\u3088\u3046<\/p>\n<p class=\"whitespace-normal break-words\">claude: \u5b9f\u88c5\u5185\u5bb9\u3092\u307e\u3068\u3081\u3066\u30b3\u30df\u30c3\u30c8\u3057\u307e\u3059\u306d\u3002<\/p>\n<p class=\"whitespace-normal break-words\">[\u5909\u66f4\u5185\u5bb9\u3092\u5206\u6790\u4e2d&#8230;]<\/p>\n<p class=\"whitespace-normal break-words\">\u4ee5\u4e0b\u306e\u5909\u66f4\u3092\u30b3\u30df\u30c3\u30c8\u3057\u307e\u3059\uff1a<\/p>\n<ul class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-disc space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\">\u65b0\u898f\u30d5\u30a1\u30a4\u30eb: middleware\/auth.js<\/li>\n<li class=\"whitespace-normal break-words\">\u65b0\u898f\u30d5\u30a1\u30a4\u30eb: routes\/auth.js<\/li>\n<li class=\"whitespace-normal break-words\">\u65b0\u898f\u30d5\u30a1\u30a4\u30eb: tests\/auth.test.js<\/li>\n<li class=\"whitespace-normal break-words\">\u66f4\u65b0\u30d5\u30a1\u30a4\u30eb: package.json (\u65b0\u3057\u3044\u4f9d\u5b58\u95a2\u4fc2)<\/li>\n<li class=\"whitespace-normal break-words\">\u66f4\u65b0\u30d5\u30a1\u30a4\u30eb: app.js (\u30eb\u30fc\u30c8\u8ffd\u52a0)<\/li>\n<\/ul>\n<p class=\"whitespace-pre-wrap break-words\">Conventional Commits \u306b\u5f93\u3063\u305f\u30b3\u30df\u30c3\u30c8\u30e1\u30c3\u30bb\u30fc\u30b8\uff1a &#8220;feat(auth): \u30e6\u30fc\u30b6\u30fc\u8a8d\u8a3c\u6a5f\u80fd\u3092\u5b9f\u88c5<\/p>\n<ul class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-disc space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\">JWT \u30d9\u30fc\u30b9\u306e\u8a8d\u8a3c\u30df\u30c9\u30eb\u30a6\u30a7\u30a2\u3092\u8ffd\u52a0<\/li>\n<li class=\"whitespace-normal break-words\">\u30e6\u30fc\u30b6\u30fc\u767b\u9332\u30fb\u30ed\u30b0\u30a4\u30f3\u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u30c8\u3092\u4f5c\u6210<\/li>\n<li class=\"whitespace-normal break-words\">\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u5bfe\u7b56\uff08\u30d1\u30b9\u30ef\u30fc\u30c9\u30cf\u30c3\u30b7\u30e5\u5316\u3001\u30ec\u30fc\u30c8\u5236\u9650\uff09\u3092\u5b9f\u88c5<\/li>\n<li class=\"whitespace-normal break-words\">\u5305\u62ec\u7684\u306a\u30c6\u30b9\u30c8\u30b1\u30fc\u30b9\u3092\u8ffd\u52a0\uff08\u30ab\u30d0\u30ec\u30c3\u30b895%\uff09&#8221;<\/li>\n<\/ul>\n<p class=\"whitespace-normal break-words\">\u30b3\u30df\u30c3\u30c8\u3092\u5b9f\u884c\u3057\u3066\u3082\u3088\u308d\u3057\u3044\u3067\u3059\u304b\uff1f<\/p>\n<p class=\"whitespace-normal break-words\">\u958b\u767a\u8005: OK\uff01<\/p>\n<p class=\"whitespace-normal break-words\">claude: [git add . &amp;&amp; git commit -m &#8220;&#8230;&#8221;] \u3092\u5b9f\u884c<\/p>\n<p class=\"whitespace-pre-wrap break-words\">\u30b3\u30df\u30c3\u30c8\u304c\u5b8c\u4e86\u3057\u307e\u3057\u305f\uff01 commit hash: a1b2c3d4<\/p>\n<p class=\"whitespace-pre-wrap break-words\">\u6b21\u306b main \u30d6\u30e9\u30f3\u30c1\u306b\u30de\u30fc\u30b8\u3057\u307e\u3059\u304b\uff1f \u305d\u308c\u3068\u3082 Pull Request \u3092\u4f5c\u6210\u3057\u307e\u3059\u304b\uff1f<\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code>\r\n#### \ud83d\udd04 **\u30d7\u30eb\u30ea\u30af\u30a8\u30b9\u30c8\u3068\u30de\u30fc\u30b8**<\/code><\/pre>\n<\/div>\n<\/div>\n<p class=\"whitespace-normal break-words\">\u958b\u767a\u8005: \u30d7\u30eb\u30ea\u30af\u30a8\u30b9\u30c8\u3092\u4f5c\u6210\u3057\u3066\u3001\u30ec\u30d3\u30e5\u30fc\u3057\u3066\u3082\u3089\u3044\u305f\u3044<\/p>\n<p class=\"whitespace-normal break-words\">claude: GitHub \u306b\u30d7\u30eb\u30ea\u30af\u30a8\u30b9\u30c8\u3092\u4f5c\u6210\u3057\u307e\u3059\u306d\u3002<\/p>\n<p class=\"whitespace-pre-wrap break-words\">[git push origin feature\/user-auth \u3092\u5b9f\u884c] [GitHub API \u3092\u4f7f\u7528\u3057\u3066\u30d7\u30eb\u30ea\u30af\u30a8\u30b9\u30c8\u3092\u4f5c\u6210\u4e2d&#8230;]<\/p>\n<p class=\"whitespace-normal break-words\">\u30d7\u30eb\u30ea\u30af\u30a8\u30b9\u30c8\u3092\u4f5c\u6210\u3057\u307e\u3057\u305f\uff1a \ud83d\udcdd \u30bf\u30a4\u30c8\u30eb: &#8220;feat: \u30e6\u30fc\u30b6\u30fc\u8a8d\u8a3c\u6a5f\u80fd\u306e\u5b9f\u88c5&#8221; \ud83d\udd17 URL: <a class=\"underline\" href=\"https:\/\/github.com\/username\/project\/pull\/42\">https:\/\/github.com\/username\/project\/pull\/42<\/a><\/p>\n<p class=\"whitespace-normal break-words\">PR \u306e\u5185\u5bb9\uff1a<\/p>\n<h2 class=\"text-xl font-bold text-text-100 mt-1 -mb-0.5\">\u6982\u8981<\/h2>\n<p class=\"whitespace-normal break-words\">\u30e6\u30fc\u30b6\u30fc\u8a8d\u8a3c\u6a5f\u80fd\u3092\u5b9f\u88c5\u3057\u307e\u3057\u305f\u3002JWT \u30d9\u30fc\u30b9\u306e\u5b89\u5168\u306a\u8a8d\u8a3c\u30b7\u30b9\u30c6\u30e0\u3067\u3059\u3002<\/p>\n<h2 class=\"text-xl font-bold text-text-100 mt-1 -mb-0.5\">\u5909\u66f4\u5185\u5bb9<\/h2>\n<ul class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-disc space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\">\u2728 \u30e6\u30fc\u30b6\u30fc\u767b\u9332\u30fb\u30ed\u30b0\u30a4\u30f3\u6a5f\u80fd<\/li>\n<li class=\"whitespace-normal break-words\">\ud83d\udd12 JWT \u30d9\u30fc\u30b9\u306e\u8a8d\u8a3c\u30df\u30c9\u30eb\u30a6\u30a7\u30a2<\/li>\n<li class=\"whitespace-normal break-words\">\ud83d\udee1\ufe0f \u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u5bfe\u7b56\u306e\u5b9f\u88c5<\/li>\n<li class=\"whitespace-normal break-words\">\u2705 \u5305\u62ec\u7684\u306a\u30c6\u30b9\u30c8\u30b1\u30fc\u30b9\uff08\u30ab\u30d0\u30ec\u30c3\u30b895%\uff09<\/li>\n<\/ul>\n<h2 class=\"text-xl font-bold text-text-100 mt-1 -mb-0.5\">\u30c6\u30b9\u30c8<\/h2>\n<ul class=\"contains-task-list\">\n<li class=\"task-list-item\"><input checked=\"checked\" disabled=\"disabled\" type=\"checkbox\" \/> \u30e6\u30cb\u30c3\u30c8\u30c6\u30b9\u30c8: \u5168\u3066\u30d1\u30b9<\/li>\n<li class=\"task-list-item\"><input checked=\"checked\" disabled=\"disabled\" type=\"checkbox\" \/> \u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u30c6\u30b9\u30c8: \u30d1\u30b9<\/li>\n<li class=\"task-list-item\"><input checked=\"checked\" disabled=\"disabled\" type=\"checkbox\" \/> \u624b\u52d5\u30c6\u30b9\u30c8: \u52d5\u4f5c\u78ba\u8a8d\u6e08\u307f<\/li>\n<\/ul>\n<h2 class=\"text-xl font-bold text-text-100 mt-1 -mb-0.5\">\u30ec\u30d3\u30e5\u30fc\u30dd\u30a4\u30f3\u30c8<\/h2>\n<ol class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-decimal space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\">\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u5b9f\u88c5\u306e\u59a5\u5f53\u6027<\/li>\n<li class=\"whitespace-normal break-words\">\u30a8\u30e9\u30fc\u30cf\u30f3\u30c9\u30ea\u30f3\u30b0\u306e\u9069\u5207\u6027<\/li>\n<li class=\"whitespace-normal break-words\">\u30c6\u30b9\u30c8\u30b1\u30fc\u30b9\u306e\u7db2\u7f85\u6027<\/li>\n<\/ol>\n<p class=\"whitespace-normal break-words\">\u30c1\u30fc\u30e0\u30e1\u30f3\u30d0\u30fc\u306b\u30ec\u30d3\u30e5\u30fc\u3092\u4f9d\u983c\u3057\u307e\u3059\u304b\uff1f<\/p>\n<p class=\"whitespace-normal break-words\">\u958b\u767a\u8005: \u30ec\u30d3\u30e5\u30a2\u30fc\u306b\u7530\u4e2d\u3055\u3093\u3068\u4f50\u85e4\u3055\u3093\u3092\u6307\u5b9a\u3057\u3066<\/p>\n<p class=\"whitespace-normal break-words\">claude: \u627f\u77e5\u3057\u307e\u3057\u305f\u3002\u7530\u4e2d\u3055\u3093\uff08@tanaka\uff09\u3068\u4f50\u85e4\u3055\u3093\uff08@sato\uff09\u3092\u30ec\u30d3\u30e5\u30a2\u30fc\u306b\u6307\u5b9a\u3057\u307e\u3059\u3002<\/p>\n<p class=\"whitespace-normal break-words\">[GitHub API \u3067\u30ec\u30d3\u30e5\u30a2\u30fc\u3092\u6307\u5b9a\u4e2d&#8230;]<\/p>\n<p class=\"whitespace-pre-wrap break-words\">\u30ec\u30d3\u30e5\u30a2\u30fc\u3092\u6307\u5b9a\u3057\u307e\u3057\u305f\u3002 \u901a\u77e5\u304c\u9001\u4fe1\u3055\u308c\u3001\u30ec\u30d3\u30e5\u30fc\u30d7\u30ed\u30bb\u30b9\u304c\u958b\u59cb\u3055\u308c\u307e\u3059\u3002<\/p>\n<p class=\"whitespace-normal break-words\">\u30ec\u30d3\u30e5\u30fc\u7d50\u679c\u3092\u5f85\u3064\u9593\u306b\u3001\u6b21\u306e\u30bf\u30b9\u30af\u306b\u53d6\u308a\u304b\u304b\u308a\u307e\u3059\u304b\uff1f<\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code>\r\n#### \ud83c\udf19 **\u4e00\u65e5\u306e\u7d42\u308f\u308a**<\/code><\/pre>\n<\/div>\n<\/div>\n<p class=\"whitespace-normal break-words\">\u958b\u767a\u8005: \u4eca\u65e5\u306e\u4f5c\u696d\u3092\u307e\u3068\u3081\u3066\u3001\u9032\u6357\u3092\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u306b\u66f4\u65b0\u3057\u3066<\/p>\n<p class=\"whitespace-normal break-words\">claude: \u672c\u65e5\u306e\u4f5c\u696d\u5185\u5bb9\u3092\u307e\u3068\u3081\u307e\u3059\u306d\u3002<\/p>\n<h2 class=\"text-xl font-bold text-text-100 mt-1 -mb-0.5\">\ud83d\udcc5 2024\u5e7412\u670815\u65e5 \u4f5c\u696d\u5831\u544a<\/h2>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">\u2705 \u5b8c\u4e86\u3057\u305f\u30bf\u30b9\u30af<\/h3>\n<ol class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-decimal space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\"><strong>\u30e6\u30fc\u30b6\u30fc\u8a8d\u8a3c\u6a5f\u80fd\u306e\u5b9f\u88c5<\/strong>\n<ul class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-disc space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\">JWT \u30d9\u30fc\u30b9\u306e\u8a8d\u8a3c\u30b7\u30b9\u30c6\u30e0<\/li>\n<li class=\"whitespace-normal break-words\">\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u5bfe\u7b56\u3092\u542b\u3080\u5305\u62ec\u7684\u306a\u5b9f\u88c5<\/li>\n<li class=\"whitespace-normal break-words\">\u30c6\u30b9\u30c8\u30ab\u30d0\u30ec\u30c3\u30b8 95% \u9054\u6210<\/li>\n<\/ul>\n<\/li>\n<\/ol>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">\ud83d\udcca \u4f5c\u6210\u3057\u305f\u30d5\u30a1\u30a4\u30eb<\/h3>\n<ul class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-disc space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">middleware\/auth.js<\/code> &#8211; \u8a8d\u8a3c\u30df\u30c9\u30eb\u30a6\u30a7\u30a2<\/li>\n<li class=\"whitespace-normal break-words\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">routes\/auth.js<\/code> &#8211; \u8a8d\u8a3c\u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u30c8<\/li>\n<li class=\"whitespace-normal break-words\"><code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">tests\/auth.test.js<\/code> &#8211; \u30c6\u30b9\u30c8\u30b3\u30fc\u30c9<\/li>\n<\/ul>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">\ud83d\udd04 GitHub \u4f5c\u696d<\/h3>\n<ul class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-disc space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\">\u30d6\u30e9\u30f3\u30c1: <code class=\"bg-text-200\/5 border border-0.5 border-border-300 text-danger-000 whitespace-pre-wrap rounded-[0.4rem] px-1 py-px text-[0.9rem]\">feature\/user-auth<\/code> \u4f5c\u6210<\/li>\n<li class=\"whitespace-normal break-words\">\u30b3\u30df\u30c3\u30c8: a1b2c3d4 &#8220;feat(auth): \u30e6\u30fc\u30b6\u30fc\u8a8d\u8a3c\u6a5f\u80fd\u3092\u5b9f\u88c5&#8221;<\/li>\n<li class=\"whitespace-normal break-words\">\u30d7\u30eb\u30ea\u30af\u30a8\u30b9\u30c8: #42 \u4f5c\u6210\uff08\u30ec\u30d3\u30e5\u30fc\u5f85\u3061\uff09<\/li>\n<\/ul>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">\ud83d\udcc8 \u6b21\u56de\u4e88\u5b9a<\/h3>\n<ul class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-disc space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\">\u30ec\u30d3\u30e5\u30fc\u30d5\u30a3\u30fc\u30c9\u30d0\u30c3\u30af\u306e\u5bfe\u5fdc<\/li>\n<li class=\"whitespace-normal break-words\">\u30d1\u30b9\u30ef\u30fc\u30c9\u30ea\u30bb\u30c3\u30c8\u6a5f\u80fd\u306e\u5b9f\u88c5<\/li>\n<li class=\"whitespace-normal break-words\">\u4e8c\u6bb5\u968e\u8a8d\u8a3c\u306e\u691c\u8a0e<\/li>\n<\/ul>\n<p class=\"whitespace-normal break-words\">CHANGELOG.md \u3092\u66f4\u65b0\u3057\u307e\u3059\u304b\uff1f<\/p>\n<p class=\"whitespace-normal break-words\">\u958b\u767a\u8005: \u304a\u9858\u3044\u3057\u307e\u3059<\/p>\n<p class=\"whitespace-normal break-words\">claude: [CHANGELOG.md \u3092\u66f4\u65b0\u4e2d&#8230;]<\/p>\n<p class=\"whitespace-normal break-words\">CHANGELOG.md \u3092\u66f4\u65b0\u3057\u307e\u3057\u305f\uff1a<\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"text-text-500 text-xs p-3.5 pb-0\">markdown<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code class=\"language-markdown\"><span class=\"token\">##<\/span><span class=\"token\"> [Unreleased]<\/span>\r\n\r\n<span class=\"token\">###<\/span><span class=\"token\"> Added<\/span>\r\n<span class=\"token\">-<\/span> \u30e6\u30fc\u30b6\u30fc\u8a8d\u8a3c\u6a5f\u80fd\uff08JWT \u30d9\u30fc\u30b9\uff09\r\n<span class=\"token\">-<\/span> \u8a8d\u8a3c\u30df\u30c9\u30eb\u30a6\u30a7\u30a2\r\n<span class=\"token\">-<\/span> \u30e6\u30fc\u30b6\u30fc\u767b\u9332\u30fb\u30ed\u30b0\u30a4\u30f3\u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u30c8\r\n<span class=\"token\">-<\/span> \u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u5bfe\u7b56\uff08\u30d1\u30b9\u30ef\u30fc\u30c9\u30cf\u30c3\u30b7\u30e5\u5316\u3001\u30ec\u30fc\u30c8\u5236\u9650\uff09\r\n\r\n<span class=\"token\">###<\/span><span class=\"token\"> Security<\/span>\r\n<span class=\"token\">-<\/span> JWT \u30c8\u30fc\u30af\u30f3\u30d9\u30fc\u30b9\u306e\u8a8d\u8a3c\u30b7\u30b9\u30c6\u30e0\r\n<span class=\"token\">-<\/span> bcrypt \u306b\u3088\u308b\u30d1\u30b9\u30ef\u30fc\u30c9\u30cf\u30c3\u30b7\u30e5\u5316\r\n<span class=\"token\">-<\/span> express-rate-limit \u306b\u3088\u308b\u653b\u6483\u9632\u6b62<\/code><\/pre>\n<\/div>\n<\/div>\n<p class=\"whitespace-pre-wrap break-words\">\u304a\u75b2\u308c\u3055\u307e\u3067\u3057\u305f\uff01\u4eca\u65e5\u3082\u7d20\u6674\u3089\u3057\u3044\u9032\u6357\u3067\u3059\u306d\u3002 \u660e\u65e5\u306e\u30bf\u30b9\u30af\u3067\u4f55\u304b\u3054\u8cea\u554f\u304c\u3042\u308c\u3070\u3001\u3044\u3064\u3067\u3082\u304a\u58f0\u304c\u3051\u304f\u3060\u3055\u3044\u3002<\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code>\r\n\ud83d\udc3b\u200d\u2744\ufe0f\u300c\u3069\u3046\u3058\u3083\uff01\u5b9f\u969b\u306e\u958b\u767a\u73fe\u5834\u3067\u306e\u4f1a\u8a71\u306e\u30a4\u30e1\u30fc\u30b8\u304c\u63b4\u3081\u305f\u304b\u306e\uff1f\u300d\r\n\ud83e\uddf8\u300c\u3059\u3054\u3044\u30af\u30de\uff01\u307e\u308b\u3067\u512a\u79c0\u306a\u540c\u50da\u304c\u3044\u308b\u307f\u305f\u3044\u3060\u306d\u300d\r\n\ud83d\udc3b\u200d\u2744\ufe0f\u300c\u305d\u3046\u306a\u306e\u3058\u3083\uff01Claude Code\u306f\u5358\u306a\u308b\u30c4\u30fc\u30eb\u3067\u306f\u306a\u304f\u3001\u958b\u767a\u30d1\u30fc\u30c8\u30ca\u30fc\u3068\u3057\u3066\u6d3b\u7528\u3059\u308b\u306e\u304c\u30b3\u30c4\u3067\u3059\u305e\u301c\u300d\r\n\r\n## \ud83d\ude80 \u7b2c6\u7ae0\uff1a\u30c7\u30d7\u30ed\u30a4\uff08\u516c\u958b\uff09\u306e\u5b9f\u8df5\u30ac\u30a4\u30c9\r\n\r\n\ud83d\udc3b\u200d\u2744\ufe0f\u300c\u3055\u3066\u3001\u4f5c\u3063\u305f\u30a2\u30d7\u30ea\u3092\u4e16\u754c\u306b\u516c\u958b\u3059\u308b\u300e\u30c7\u30d7\u30ed\u30a4\u300f\u306b\u3064\u3044\u3066\u3001\u308f\u304b\u308a\u3084\u3059\u304f\u89e3\u8aac\u3059\u308b\u305e\u3044\uff01\u300d\r\n\ud83e\uddf8\u300c\u30c7\u30d7\u30ed\u30a4\u3063\u3066\u96e3\u3057\u305d\u3046\u30af\u30de...\u300d\r\n\ud83d\udc3b\u200d\u2744\ufe0f\u300c\u5fc3\u914d\u3054\u7121\u7528\u3058\u3083\uff01Claude Code\u304c\u3042\u308c\u3070\u3001\u65e5\u672c\u8a9e\u3067\u6307\u793a\u3059\u308b\u3060\u3051\u3067\u81ea\u52d5\u5316\u3067\u304d\u308b\u306e\u3058\u3083\u300d\r\n\r\n### \ud83c\udf10 GitHub Pages \u3067\u306e\u7c21\u5358\u30c7\u30d7\u30ed\u30a4\r\n\r\n**GitHub Pages \u3068\u306f\uff1f**\r\nGitHub \u304c\u63d0\u4f9b\u3059\u308b\u7121\u6599\u306e\u30db\u30b9\u30c6\u30a3\u30f3\u30b0\u30b5\u30fc\u30d3\u30b9\u3058\u3083\u3002\u9759\u7684\u30b5\u30a4\u30c8\uff08HTML, CSS, JavaScript\uff09\u3092\u7c21\u5358\u306b\u516c\u958b\u3067\u304d\u308b\u305e\u3044\uff01\r\n\r\n**Claude Code \u3067\u306e\u81ea\u52d5\u30c7\u30d7\u30ed\u30a4\u8a2d\u5b9a**<\/code><\/pre>\n<\/div>\n<\/div>\n<p class=\"whitespace-normal break-words\">\u958b\u767a\u8005: \u3053\u306eReact\u30a2\u30d7\u30ea\u3092GitHub Pages\u3067\u516c\u958b\u3057\u305f\u3044<\/p>\n<p class=\"whitespace-pre-wrap break-words\">claude: GitHub Pages \u3067\u306e\u30c7\u30d7\u30ed\u30a4\u3092\u8a2d\u5b9a\u3057\u307e\u3059\u306d\u3002 \u307e\u305a\u73fe\u5728\u306e\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u69cb\u6210\u3092\u78ba\u8a8d\u3057\u307e\u3059\u3002<\/p>\n<p class=\"whitespace-normal break-words\">[package.json \u3092\u5206\u6790\u4e2d&#8230;]<\/p>\n<p class=\"whitespace-normal break-words\">React \u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u3067\u3059\u306d\u3002\u4ee5\u4e0b\u306e\u624b\u9806\u3067\u30c7\u30d7\u30ed\u30a4\u8a2d\u5b9a\u3092\u884c\u3044\u307e\u3059\uff1a<\/p>\n<ol class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-decimal space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\">gh-pages \u30d1\u30c3\u30b1\u30fc\u30b8\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb<\/li>\n<li class=\"whitespace-normal break-words\">package.json \u306b\u30c7\u30d7\u30ed\u30a4\u30b9\u30af\u30ea\u30d7\u30c8\u3092\u8ffd\u52a0<\/li>\n<li class=\"whitespace-normal break-words\">\u30d3\u30eb\u30c9\u3068\u30c7\u30d7\u30ed\u30a4\u306e\u81ea\u52d5\u5316<\/li>\n<li class=\"whitespace-normal break-words\">GitHub \u30ea\u30dd\u30b8\u30c8\u30ea\u8a2d\u5b9a\u306e\u66f4\u65b0<\/li>\n<\/ol>\n<p class=\"whitespace-normal break-words\">\u5b9f\u884c\u3057\u3066\u3082\u3088\u308d\u3057\u3044\u3067\u3059\u304b\uff1f<\/p>\n<p class=\"whitespace-normal break-words\">\u958b\u767a\u8005: \u304a\u9858\u3044\u3057\u307e\u3059<\/p>\n<p class=\"whitespace-normal break-words\">claude: \u30c7\u30d7\u30ed\u30a4\u8a2d\u5b9a\u3092\u958b\u59cb\u3057\u307e\u3059\u3002<\/p>\n<p class=\"whitespace-normal break-words\">[npm install &#8211;save-dev gh-pages \u3092\u5b9f\u884c\u4e2d&#8230;]<\/p>\n<p class=\"whitespace-normal break-words\">package.json \u3092\u66f4\u65b0\u3057\u3066\u3044\u307e\u3059\uff1a<\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"text-text-500 text-xs p-3.5 pb-0\">json<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code class=\"language-json\"><span class=\"token\">{<\/span>\r\n  <span class=\"token\">\"homepage\"<\/span><span class=\"token\">:<\/span> <span class=\"token\">\"https:\/\/username.github.io\/my-react-app\"<\/span><span class=\"token\">,<\/span>\r\n  <span class=\"token\">\"scripts\"<\/span><span class=\"token\">:<\/span> <span class=\"token\">{<\/span>\r\n    <span class=\"token\">\"predeploy\"<\/span><span class=\"token\">:<\/span> <span class=\"token\">\"npm run build\"<\/span><span class=\"token\">,<\/span>\r\n    <span class=\"token\">\"deploy\"<\/span><span class=\"token\">:<\/span> <span class=\"token\">\"gh-pages -d build\"<\/span>\r\n  <span class=\"token\">}<\/span>\r\n<span class=\"token\">}<\/span><\/code><\/pre>\n<\/div>\n<\/div>\n<p class=\"whitespace-normal break-words\">\u30d3\u30eb\u30c9\u3068\u30c7\u30d7\u30ed\u30a4\u3092\u5b9f\u884c\u3057\u307e\u3059\uff1a<\/p>\n<p class=\"whitespace-normal break-words\">[npm run deploy \u3092\u5b9f\u884c\u4e2d&#8230;]<\/p>\n<p class=\"whitespace-pre-wrap break-words\">\u2705 \u30d3\u30eb\u30c9\u5b8c\u4e86 \u2705 gh-pages \u30d6\u30e9\u30f3\u30c1\u306b\u53cd\u6620 \u2705 GitHub Pages \u306b\u516c\u958b\u5b8c\u4e86<\/p>\n<p class=\"whitespace-normal break-words\">\ud83c\udf10 \u30b5\u30a4\u30c8URL: <a class=\"underline\" href=\"https:\/\/username.github.io\/my-react-app\">https:\/\/username.github.io\/my-react-app<\/a><\/p>\n<p class=\"whitespace-normal break-words\">\u901a\u5e385-10\u5206\u3067\u516c\u958b\u3055\u308c\u307e\u3059\u3002<\/p>\n<p class=\"whitespace-normal break-words\">GitHub \u30ea\u30dd\u30b8\u30c8\u30ea\u306e Settings &gt; Pages \u3082\u78ba\u8a8d\u3057\u3066\u304a\u304d\u307e\u3059\u306d\u3002<\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code>\r\n**\u30c7\u30d7\u30ed\u30a4\u3067\u8d77\u3053\u308a\u304c\u3061\u306a\u554f\u984c\u3068\u89e3\u6c7a\u6cd5**<\/code><\/pre>\n<\/div>\n<\/div>\n<p class=\"whitespace-normal break-words\">\u958b\u767a\u8005: \u30b5\u30a4\u30c8\u306f\u8868\u793a\u3055\u308c\u308b\u3051\u3069\u3001\u30da\u30fc\u30b8\u9077\u79fb\u3067404\u30a8\u30e9\u30fc\u304c\u51fa\u308b<\/p>\n<p class=\"whitespace-pre-wrap break-words\">claude: \u305d\u308c\u306f SPA\uff08Single Page Application\uff09\u7279\u6709\u306e\u554f\u984c\u3067\u3059\u306d\u3002 GitHub Pages \u306f\u30eb\u30fc\u30c6\u30a3\u30f3\u30b0\u306b\u5bfe\u5fdc\u3057\u3066\u3044\u306a\u3044\u305f\u3081\u767a\u751f\u3057\u307e\u3059\u3002<\/p>\n<p class=\"whitespace-normal break-words\">\u89e3\u6c7a\u7b56\u3092\u5b9f\u88c5\u3057\u307e\u3059\uff1a<\/p>\n<ol class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-decimal space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\">public\/404.html \u3092\u4f5c\u6210\u3057\u3066\u30ea\u30c0\u30a4\u30ec\u30af\u30c8\u51e6\u7406\u3092\u8ffd\u52a0<\/li>\n<li class=\"whitespace-normal break-words\">index.html \u306b JavaScript \u30ea\u30c0\u30a4\u30ec\u30af\u30c8\u3092\u8a2d\u5b9a<\/li>\n<li class=\"whitespace-normal break-words\">React Router \u306e\u8a2d\u5b9a\u3092\u8abf\u6574<\/li>\n<\/ol>\n<p class=\"whitespace-normal break-words\">[public\/404.html \u3092\u4f5c\u6210\u4e2d&#8230;]<\/p>\n<p class=\"whitespace-normal break-words\">404.html \u306b\u30ea\u30c0\u30a4\u30ec\u30af\u30c8\u30b9\u30af\u30ea\u30d7\u30c8\u3092\u8ffd\u52a0\u3057\u307e\u3057\u305f\uff1a<\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"text-text-500 text-xs p-3.5 pb-0\">html<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code class=\"language-html\"><span class=\"token\">&lt;!<\/span><span class=\"token doctype-tag\">DOCTYPE<\/span> <span class=\"token name\">html<\/span><span class=\"token\">&gt;<\/span>\r\n<span class=\"token\">&lt;<\/span><span class=\"token\">html<\/span><span class=\"token\">&gt;<\/span>\r\n<span class=\"token\">&lt;<\/span><span class=\"token\">head<\/span><span class=\"token\">&gt;<\/span>\r\n  <span class=\"token\">&lt;<\/span><span class=\"token\">script<\/span> <span class=\"token\">type<\/span><span class=\"token\">=<\/span><span class=\"token\">\"<\/span><span class=\"token\">text\/javascript<\/span><span class=\"token\">\"<\/span><span class=\"token\">&gt;<\/span>\r\n    <span class=\"token script language-javascript\">\/\/ GitHub Pages SPA \u5bfe\u5fdc<\/span>\r\n    <span class=\"token script language-javascript\">var<\/span><span class=\"token script language-javascript\"> pathSegmentsToKeep <\/span><span class=\"token script language-javascript\">=<\/span> <span class=\"token script language-javascript\">1<\/span><span class=\"token script language-javascript\">;<\/span>\r\n    <span class=\"token script language-javascript\">var<\/span><span class=\"token script language-javascript\"> l <\/span><span class=\"token script language-javascript\">=<\/span> <span class=\"token script language-javascript dom\">window<\/span><span class=\"token script language-javascript\">.<\/span><span class=\"token script language-javascript property-access\">location<\/span><span class=\"token script language-javascript\">;<\/span>\r\n<span class=\"token script language-javascript\">    l<\/span><span class=\"token script language-javascript\">.<\/span><span class=\"token script language-javascript method property-access\">replace<\/span><span class=\"token script language-javascript\">(<\/span>\r\n<span class=\"token script language-javascript\">      l<\/span><span class=\"token script language-javascript\">.<\/span><span class=\"token script language-javascript property-access\">protocol<\/span> <span class=\"token script language-javascript\">+<\/span> <span class=\"token script language-javascript\">'\/\/'<\/span> <span class=\"token script language-javascript\">+<\/span><span class=\"token script language-javascript\"> l<\/span><span class=\"token script language-javascript\">.<\/span><span class=\"token script language-javascript property-access\">hostname<\/span> <span class=\"token script language-javascript\">+<\/span> <span class=\"token script language-javascript\">(<\/span><span class=\"token script language-javascript\">l<\/span><span class=\"token script language-javascript\">.<\/span><span class=\"token script language-javascript property-access\">port<\/span> <span class=\"token script language-javascript\">?<\/span> <span class=\"token script language-javascript\">':'<\/span> <span class=\"token script language-javascript\">+<\/span><span class=\"token script language-javascript\"> l<\/span><span class=\"token script language-javascript\">.<\/span><span class=\"token script language-javascript property-access\">port<\/span> <span class=\"token script language-javascript\">:<\/span> <span class=\"token script language-javascript\">''<\/span><span class=\"token script language-javascript\">)<\/span> <span class=\"token script language-javascript\">+<\/span>\r\n<span class=\"token script language-javascript\">      l<\/span><span class=\"token script language-javascript\">.<\/span><span class=\"token script language-javascript property-access\">pathname<\/span><span class=\"token script language-javascript\">.<\/span><span class=\"token script language-javascript method property-access\">split<\/span><span class=\"token script language-javascript\">(<\/span><span class=\"token script language-javascript\">'\/'<\/span><span class=\"token script language-javascript\">)<\/span><span class=\"token script language-javascript\">.<\/span><span class=\"token script language-javascript method property-access\">slice<\/span><span class=\"token script language-javascript\">(<\/span><span class=\"token script language-javascript\">0<\/span><span class=\"token script language-javascript\">,<\/span> <span class=\"token script language-javascript\">1<\/span> <span class=\"token script language-javascript\">+<\/span><span class=\"token script language-javascript\"> pathSegmentsToToKeep<\/span><span class=\"token script language-javascript\">)<\/span><span class=\"token script language-javascript\">.<\/span><span class=\"token script language-javascript method property-access\">join<\/span><span class=\"token script language-javascript\">(<\/span><span class=\"token script language-javascript\">'\/'<\/span><span class=\"token script language-javascript\">)<\/span> <span class=\"token script language-javascript\">+<\/span> \r\n      <span class=\"token script language-javascript\">'\/?\/'<\/span> <span class=\"token script language-javascript\">+<\/span><span class=\"token script language-javascript\"> l<\/span><span class=\"token script language-javascript\">.<\/span><span class=\"token script language-javascript property-access\">pathname<\/span><span class=\"token script language-javascript\">.<\/span><span class=\"token script language-javascript method property-access\">slice<\/span><span class=\"token script language-javascript\">(<\/span><span class=\"token script language-javascript\">1<\/span><span class=\"token script language-javascript\">)<\/span><span class=\"token script language-javascript\">.<\/span><span class=\"token script language-javascript method property-access\">split<\/span><span class=\"token script language-javascript\">(<\/span><span class=\"token script language-javascript\">'\/'<\/span><span class=\"token script language-javascript\">)<\/span><span class=\"token script language-javascript\">.<\/span><span class=\"token script language-javascript method property-access\">slice<\/span><span class=\"token script language-javascript\">(<\/span><span class=\"token script language-javascript\">pathSegmentsToKeep<\/span><span class=\"token script language-javascript\">)<\/span><span class=\"token script language-javascript\">.<\/span><span class=\"token script language-javascript method property-access\">join<\/span><span class=\"token script language-javascript\">(<\/span><span class=\"token script language-javascript\">'\/'<\/span><span class=\"token script language-javascript\">)<\/span><span class=\"token script language-javascript\">.<\/span><span class=\"token script language-javascript method property-access\">replace<\/span><span class=\"token script language-javascript\">(<\/span><span class=\"token script language-javascript regex-delimiter\">\/<\/span><span class=\"token script language-javascript regex-source language-regex\">&amp;<\/span><span class=\"token script language-javascript regex-delimiter\">\/<\/span><span class=\"token script language-javascript regex-flags\">g<\/span><span class=\"token script language-javascript\">,<\/span> <span class=\"token script language-javascript\">'~and~'<\/span><span class=\"token script language-javascript\">)<\/span> <span class=\"token script language-javascript\">+<\/span>\r\n      <span class=\"token script language-javascript\">(<\/span><span class=\"token script language-javascript\">l<\/span><span class=\"token script language-javascript\">.<\/span><span class=\"token script language-javascript property-access\">search<\/span> <span class=\"token script language-javascript\">?<\/span> <span class=\"token script language-javascript\">'&amp;'<\/span> <span class=\"token script language-javascript\">+<\/span><span class=\"token script language-javascript\"> l<\/span><span class=\"token script language-javascript\">.<\/span><span class=\"token script language-javascript property-access\">search<\/span><span class=\"token script language-javascript\">.<\/span><span class=\"token script language-javascript method property-access\">slice<\/span><span class=\"token script language-javascript\">(<\/span><span class=\"token script language-javascript\">1<\/span><span class=\"token script language-javascript\">)<\/span><span class=\"token script language-javascript\">.<\/span><span class=\"token script language-javascript method property-access\">replace<\/span><span class=\"token script language-javascript\">(<\/span><span class=\"token script language-javascript regex-delimiter\">\/<\/span><span class=\"token script language-javascript regex-source language-regex\">&amp;<\/span><span class=\"token script language-javascript regex-delimiter\">\/<\/span><span class=\"token script language-javascript regex-flags\">g<\/span><span class=\"token script language-javascript\">,<\/span> <span class=\"token script language-javascript\">'~and~'<\/span><span class=\"token script language-javascript\">)<\/span> <span class=\"token script language-javascript\">:<\/span> <span class=\"token script language-javascript\">''<\/span><span class=\"token script language-javascript\">)<\/span> <span class=\"token script language-javascript\">+<\/span>\r\n<span class=\"token script language-javascript\">      l<\/span><span class=\"token script language-javascript\">.<\/span><span class=\"token script language-javascript property-access\">hash<\/span>\r\n    <span class=\"token script language-javascript\">)<\/span><span class=\"token script language-javascript\">;<\/span>\r\n  <span class=\"token\">&lt;\/<\/span><span class=\"token\">script<\/span><span class=\"token\">&gt;<\/span>\r\n<span class=\"token\">&lt;\/<\/span><span class=\"token\">head<\/span><span class=\"token\">&gt;<\/span>\r\n<span class=\"token\">&lt;\/<\/span><span class=\"token\">html<\/span><span class=\"token\">&gt;<\/span><\/code><\/pre>\n<\/div>\n<\/div>\n<p class=\"whitespace-normal break-words\">\u518d\u30c7\u30d7\u30ed\u30a4\u3057\u307e\u3059\uff1a<\/p>\n<p class=\"whitespace-normal break-words\">[npm run deploy \u3092\u5b9f\u884c\u4e2d&#8230;]<\/p>\n<p class=\"whitespace-pre-wrap break-words\">\u2705 \u4fee\u6b63\u7248\u304c\u30c7\u30d7\u30ed\u30a4\u3055\u308c\u307e\u3057\u305f \u30da\u30fc\u30b8\u9077\u79fb\u306e\u554f\u984c\u304c\u89e3\u6c7a\u3055\u308c\u3066\u3044\u308b\u306f\u305a\u3067\u3059\u3002<\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code>\r\n### \ud83d\udce6 Netlify \u3067\u306e\u9ad8\u5ea6\u306a\u30c7\u30d7\u30ed\u30a4\r\n\r\n**Netlify \u3068\u306f\uff1f**\r\n\u3088\u308a\u9ad8\u6a5f\u80fd\u306a\u7121\u6599\u30db\u30b9\u30c6\u30a3\u30f3\u30b0\u30b5\u30fc\u30d3\u30b9\u3058\u3083\u3002\u81ea\u52d5\u30d3\u30eb\u30c9\u3001\u30d5\u30a9\u30fc\u30e0\u51e6\u7406\u3001\u30b5\u30fc\u30d0\u30fc\u30ec\u30b9\u95a2\u6570\u306a\u3069\u304c\u4f7f\u3048\u308b\u305e\u3044\uff01<\/code><\/pre>\n<\/div>\n<\/div>\n<p class=\"whitespace-normal break-words\">\u958b\u767a\u8005: GitHub Pages\u3088\u308a\u9ad8\u6a5f\u80fd\u306aNetlify\u3092\u4f7f\u3063\u3066\u307f\u305f\u3044<\/p>\n<p class=\"whitespace-pre-wrap break-words\">claude: Netlify \u306f\u7d20\u6674\u3089\u3057\u3044\u9078\u629e\u3067\u3059\uff01\u81ea\u52d5\u30d3\u30eb\u30c9\u3001\u74b0\u5883\u5909\u6570\u3001\u30d5\u30a9\u30fc\u30e0\u51e6\u7406\u306a\u3069 GitHub Pages \u306b\u306f\u306a\u3044\u9ad8\u6a5f\u80fd\u304c\u4f7f\u3048\u307e\u3059\u3002<\/p>\n<p class=\"whitespace-normal break-words\">\u8a2d\u5b9a\u65b9\u6cd5\u3092\u65e5\u672c\u8a9e\u3067\u8aac\u660e\u3057\u306a\u304c\u3089\u9032\u3081\u307e\u3059\u306d\uff1a<\/p>\n<h2 class=\"text-xl font-bold text-text-100 mt-1 -mb-0.5\">\ud83d\udccb Netlify \u30c7\u30d7\u30ed\u30a4\u306e\u624b\u9806<\/h2>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">1. netlify.toml \u8a2d\u5b9a\u30d5\u30a1\u30a4\u30eb\u306e\u4f5c\u6210<\/h3>\n<p class=\"whitespace-normal break-words\">[netlify.toml \u3092\u4f5c\u6210\u4e2d&#8230;]<\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"text-text-500 text-xs p-3.5 pb-0\">toml<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code class=\"language-toml\"><span class=\"token\">[<\/span><span class=\"token table\">build<\/span><span class=\"token\">]<\/span>\r\n  <span class=\"token\"># \u30d3\u30eb\u30c9\u30b3\u30de\u30f3\u30c9\uff08npm run build \u3092\u5b9f\u884c\uff09<\/span>\r\n  <span class=\"token key\">command<\/span> <span class=\"token\">=<\/span> <span class=\"token\">\"npm run build\"<\/span>\r\n  <span class=\"token\"># \u516c\u958b\u3059\u308b\u30d5\u30a9\u30eb\u30c0\uff08React \u306e\u5834\u5408\u306f build \u30d5\u30a9\u30eb\u30c0\uff09<\/span>\r\n  <span class=\"token key\">publish<\/span> <span class=\"token\">=<\/span> <span class=\"token\">\"build\"<\/span>\r\n\r\n<span class=\"token\">[<\/span><span class=\"token table\">build.environment<\/span><span class=\"token\">]<\/span>\r\n  <span class=\"token\"># Node.js \u306e\u30d0\u30fc\u30b8\u30e7\u30f3\u3092\u6307\u5b9a<\/span>\r\n  <span class=\"token key\">NODE_VERSION<\/span> <span class=\"token\">=<\/span> <span class=\"token\">\"18\"<\/span>\r\n\r\n<span class=\"token\">[<\/span><span class=\"token\">[<\/span><span class=\"token table\">redirects<\/span><span class=\"token\">]<\/span><span class=\"token\">]<\/span>\r\n  <span class=\"token\"># SPA \u5bfe\u5fdc\uff1a\u5168\u3066\u306e\u30ea\u30af\u30a8\u30b9\u30c8\u3092 index.html \u306b\u30ea\u30c0\u30a4\u30ec\u30af\u30c8<\/span>\r\n  <span class=\"token key\">from<\/span> <span class=\"token\">=<\/span> <span class=\"token\">\"\/*\"<\/span>\r\n  <span class=\"token key\">to<\/span> <span class=\"token\">=<\/span> <span class=\"token\">\"\/index.html\"<\/span>\r\n  <span class=\"token key\">status<\/span> <span class=\"token\">=<\/span> <span class=\"token\">200<\/span>\r\n\r\n<span class=\"token\">[<\/span><span class=\"token table\">context.production.environment<\/span><span class=\"token\">]<\/span>\r\n  <span class=\"token\"># \u672c\u756a\u74b0\u5883\u5c02\u7528\u306e\u74b0\u5883\u5909\u6570<\/span>\r\n  <span class=\"token key\">REACT_APP_API_URL<\/span> <span class=\"token\">=<\/span> <span class=\"token\">\"https:\/\/api.myapp.com\"<\/span>\r\n\r\n<span class=\"token\">[<\/span><span class=\"token table\">context.deploy-preview.environment<\/span><span class=\"token\">]<\/span>\r\n  <span class=\"token\"># \u30d7\u30ec\u30d3\u30e5\u30fc\u74b0\u5883\u7528\u306e\u74b0\u5883\u5909\u6570<\/span>\r\n  <span class=\"token key\">REACT_APP_API_URL<\/span> <span class=\"token\">=<\/span> <span class=\"token\">\"https:\/\/staging-api.myapp.com\"<\/span><\/code><\/pre>\n<\/div>\n<\/div>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">2. \u74b0\u5883\u5909\u6570\u306e\u8a2d\u5b9a\u4f8b<\/h3>\n<p class=\"whitespace-normal break-words\">\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306b .env.example \u3082\u4f5c\u6210\u3057\u3066\u304a\u304d\u307e\u3059\uff1a<\/p>\n<p class=\"whitespace-normal break-words\">[.env.example \u3092\u4f5c\u6210\u4e2d&#8230;]<\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"text-text-500 text-xs p-3.5 pb-0\">bash<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code class=\"language-bash\"><span class=\"token\"># API \u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u30c8<\/span>\r\n<span class=\"token assign-left\">REACT_APP_API_URL<\/span><span class=\"token\">=<\/span>https:\/\/localhost:3001\r\n\r\n<span class=\"token\"># Firebase \u8a2d\u5b9a\uff08\u4f8b\uff09<\/span>\r\n<span class=\"token assign-left\">REACT_APP_FIREBASE_API_KEY<\/span><span class=\"token\">=<\/span>your-api-key\r\n<span class=\"token assign-left\">REACT_APP_FIREBASE_AUTH_DOMAIN<\/span><span class=\"token\">=<\/span>your-domain.firebaseapp.com\r\n\r\n<span class=\"token\"># Google Analytics\uff08\u4f8b\uff09<\/span>\r\n<span class=\"token assign-left\">REACT_APP_GA_TRACKING_ID<\/span><span class=\"token\">=<\/span>GA-XXXXXXXXX-X<\/code><\/pre>\n<\/div>\n<\/div>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">3. GitHub \u30ea\u30dd\u30b8\u30c8\u30ea\u3068\u306e\u9023\u643a<\/h3>\n<ol class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-decimal space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\">Netlify \u30a2\u30ab\u30a6\u30f3\u30c8\u4f5c\u6210\uff08GitHub \u3067\u30ed\u30b0\u30a4\u30f3\u53ef\u80fd\uff09<\/li>\n<li class=\"whitespace-normal break-words\">\u300cNew site from Git\u300d\u3092\u30af\u30ea\u30c3\u30af<\/li>\n<li class=\"whitespace-normal break-words\">GitHub \u30ea\u30dd\u30b8\u30c8\u30ea\u3092\u9078\u629e<\/li>\n<li class=\"whitespace-normal break-words\">\u30d3\u30eb\u30c9\u8a2d\u5b9a\uff08netlify.toml \u304c\u3042\u308c\u3070\u81ea\u52d5\u691c\u51fa\uff09<\/li>\n<li class=\"whitespace-normal break-words\">\u300cDeploy site\u300d\u3092\u30af\u30ea\u30c3\u30af<\/li>\n<\/ol>\n<p class=\"whitespace-normal break-words\">\u5b8c\u4e86\u3059\u308b\u3068\u3001\u4ee5\u4e0b\u306e\u3088\u3046\u306a URL \u304c\u767a\u884c\u3055\u308c\u307e\u3059\uff1a \ud83c\udf10 <a class=\"underline\" href=\"https:\/\/amazing-app-name.netlify.app\">https:\/\/amazing-app-name.netlify.app<\/a><\/p>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">4. \u30ab\u30b9\u30bf\u30e0\u30c9\u30e1\u30a4\u30f3\u306e\u8a2d\u5b9a\uff08\u30aa\u30d7\u30b7\u30e7\u30f3\uff09<\/h3>\n<p class=\"whitespace-normal break-words\">\u72ec\u81ea\u30c9\u30e1\u30a4\u30f3\u3092\u4f7f\u3044\u305f\u3044\u5834\u5408\uff1a<\/p>\n<ol class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-decimal space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\">Domain settings \u2192 Add custom domain<\/li>\n<li class=\"whitespace-normal break-words\">DNS \u8a2d\u5b9a\u3067CNAME\u30ec\u30b3\u30fc\u30c9\u3092\u8ffd\u52a0<\/li>\n<li class=\"whitespace-normal break-words\">SSL\u8a3c\u660e\u66f8\u306e\u81ea\u52d5\u767a\u884c\uff08Let&#8217;s Encrypt\uff09<\/li>\n<\/ol>\n<p class=\"whitespace-normal break-words\">\u30b3\u30df\u30c3\u30c8\u3057\u3066\u8a2d\u5b9a\u3092\u53cd\u6620\u3055\u305b\u307e\u3059\u304b\uff1f<\/p>\n<p class=\"whitespace-normal break-words\">\u958b\u767a\u8005: \u306f\u3044\u3001\u304a\u9858\u3044\u3057\u307e\u3059<\/p>\n<p class=\"whitespace-normal break-words\">claude: netlify.toml \u3068 .env.example \u3092\u30b3\u30df\u30c3\u30c8\u3057\u307e\u3059\u3002<\/p>\n<p class=\"whitespace-pre-wrap break-words\">[git add netlify.toml .env.example] [git commit -m &#8220;feat(deploy): Netlify \u30c7\u30d7\u30ed\u30a4\u8a2d\u5b9a\u3092\u8ffd\u52a0&#8221;] [git push origin main]<\/p>\n<p class=\"whitespace-normal break-words\">\u2705 \u8a2d\u5b9a\u3092\u30d7\u30c3\u30b7\u30e5\u3057\u307e\u3057\u305f<\/p>\n<p class=\"whitespace-pre-wrap break-words\">Netlify \u5074\u3067 GitHub \u30ea\u30dd\u30b8\u30c8\u30ea\u3092\u9023\u643a\u3059\u308b\u3068\u3001 \u4eca\u5f8c\u306f main \u30d6\u30e9\u30f3\u30c1\u306b\u30d7\u30c3\u30b7\u30e5\u3059\u308b\u305f\u3073\u306b\u81ea\u52d5\u30c7\u30d7\u30ed\u30a4\u3055\u308c\u307e\u3059\u3002<\/p>\n<p class=\"whitespace-pre-wrap break-words\">\u30d7\u30ec\u30d3\u30e5\u30fc\u30c7\u30d7\u30ed\u30a4\u6a5f\u80fd\u306b\u3088\u308a\u3001Pull Request \u3054\u3068\u306b \u4e00\u6642\u7684\u306a\u30d7\u30ec\u30d3\u30e5\u30fc\u30b5\u30a4\u30c8\u3082\u81ea\u52d5\u751f\u6210\u3055\u308c\u307e\u3059\u3088\uff01<\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code>\r\n### \ud83d\udc33 Docker \u3092\u4f7f\u3063\u305f\u672c\u683c\u30c7\u30d7\u30ed\u30a4\r\n\r\n**Docker \u3063\u3066\u4f55\u3058\u3083\uff1f**\r\nDocker \u306f\u3001\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u3092\u300c\u30b3\u30f3\u30c6\u30ca\u300d\u3068\u3044\u3046\u7bb1\u306b\u5165\u308c\u3066\u3001\u3069\u3093\u306a\u74b0\u5883\u3067\u3082\u540c\u3058\u3088\u3046\u306b\u52d5\u304b\u305b\u308b\u6280\u8853\u3058\u3083\u3002\u300c\u3069\u3053\u3067\u3082\u52d5\u304f\u9b54\u6cd5\u306e\u7bb1\u300d\u307f\u305f\u3044\u306a\u3082\u306e\u3067\u3059\u305e\uff01<\/code><\/pre>\n<\/div>\n<\/div>\n<p class=\"whitespace-normal break-words\">\u958b\u767a\u8005: Docker\u3092\u4f7f\u3063\u3066\u30a2\u30d7\u30ea\u3092\u30b3\u30f3\u30c6\u30ca\u5316\u3057\u305f\u3044<\/p>\n<p class=\"whitespace-pre-wrap break-words\">claude: Docker \u3092\u4f7f\u3063\u305f\u30b3\u30f3\u30c6\u30ca\u5316\u3092\u884c\u3044\u307e\u3059\u306d\u3002 \u672c\u683c\u7684\u306a\u672c\u756a\u74b0\u5883\u30c7\u30d7\u30ed\u30a4\u306b\u5411\u3051\u305f\u8a2d\u5b9a\u3092\u3057\u307e\u3059\u3002<\/p>\n<h2 class=\"text-xl font-bold text-text-100 mt-1 -mb-0.5\">\ud83d\udce6 Docker \u8a2d\u5b9a\u306e\u4f5c\u6210<\/h2>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">1. Dockerfile \u306e\u4f5c\u6210<\/h3>\n<p class=\"whitespace-normal break-words\">[Dockerfile \u3092\u4f5c\u6210\u4e2d&#8230;]<\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"text-text-500 text-xs p-3.5 pb-0\">dockerfile<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code class=\"language-dockerfile\"><span class=\"token\"># Node.js \u306e\u516c\u5f0f\u30a4\u30e1\u30fc\u30b8\u3092\u4f7f\u7528\uff08\u8efd\u91cf\u7248\u306eAlpineLinux\uff09<\/span>\r\n<span class=\"token instruction\">FROM<\/span><span class=\"token instruction\"> node:18-alpine<\/span>\r\n\r\n<span class=\"token\"># \u4f5c\u696d\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u3092\u8a2d\u5b9a<\/span>\r\n<span class=\"token instruction\">WORKDIR<\/span><span class=\"token instruction\"> \/app<\/span>\r\n\r\n<span class=\"token\"># package.json \u3068 package-lock.json \u3092\u30b3\u30d4\u30fc<\/span>\r\n<span class=\"token\"># \uff08\u4f9d\u5b58\u95a2\u4fc2\u306e\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3092\u30ad\u30e3\u30c3\u30b7\u30e5\u52b9\u7387\u5316\uff09<\/span>\r\n<span class=\"token instruction\">COPY<\/span><span class=\"token instruction\"> package*.json .\/<\/span>\r\n\r\n<span class=\"token\"># \u4f9d\u5b58\u95a2\u4fc2\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb<\/span>\r\n<span class=\"token instruction\">RUN<\/span><span class=\"token instruction\"> npm ci --only=production<\/span>\r\n\r\n<span class=\"token\"># \u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u30bd\u30fc\u30b9\u30b3\u30fc\u30c9\u3092\u30b3\u30d4\u30fc<\/span>\r\n<span class=\"token instruction\">COPY<\/span><span class=\"token instruction\"> . .<\/span>\r\n\r\n<span class=\"token\"># \u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u3092\u30d3\u30eb\u30c9<\/span>\r\n<span class=\"token instruction\">RUN<\/span><span class=\"token instruction\"> npm run build<\/span>\r\n\r\n<span class=\"token\"># \u672c\u756a\u7528\u306e\u8efd\u91cfWeb\u30b5\u30fc\u30d0\u30fc\uff08Nginx\uff09\u3092\u4f7f\u7528<\/span>\r\n<span class=\"token instruction\">FROM<\/span><span class=\"token instruction\"> nginx:alpine<\/span>\r\n\r\n<span class=\"token\"># \u30d3\u30eb\u30c9\u6e08\u307f\u30a2\u30d7\u30ea\u3092Nginx\u306e\u516c\u958b\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u306b\u30b3\u30d4\u30fc<\/span>\r\n<span class=\"token instruction\">COPY<\/span> <span class=\"token instruction options\">--from<\/span><span class=\"token instruction options\">=<\/span><span class=\"token instruction options\">0<\/span><span class=\"token instruction\"> \/app\/build \/usr\/share\/nginx\/html<\/span>\r\n\r\n<span class=\"token\"># Nginx \u306e\u8a2d\u5b9a\u30d5\u30a1\u30a4\u30eb\u3092\u30b3\u30d4\u30fc<\/span>\r\n<span class=\"token instruction\">COPY<\/span><span class=\"token instruction\"> nginx.conf \/etc\/nginx\/nginx.conf<\/span>\r\n\r\n<span class=\"token\"># \u30dd\u30fc\u30c880\u3092\u516c\u958b<\/span>\r\n<span class=\"token instruction\">EXPOSE<\/span><span class=\"token instruction\"> 80<\/span>\r\n\r\n<span class=\"token\"># Nginx \u3092\u8d77\u52d5<\/span>\r\n<span class=\"token instruction\">CMD<\/span><span class=\"token instruction\"> [<\/span><span class=\"token instruction\">\"nginx\"<\/span><span class=\"token instruction\">, <\/span><span class=\"token instruction\">\"-g\"<\/span><span class=\"token instruction\">, <\/span><span class=\"token instruction\">\"daemon off;\"<\/span><span class=\"token instruction\">]<\/span><\/code><\/pre>\n<\/div>\n<\/div>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">2. Nginx \u8a2d\u5b9a\u30d5\u30a1\u30a4\u30eb<\/h3>\n<p class=\"whitespace-normal break-words\">[nginx.conf \u3092\u4f5c\u6210\u4e2d&#8230;]<\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"text-text-500 text-xs p-3.5 pb-0\">nginx<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code class=\"language-nginx\"><span class=\"token directive\">events<\/span> <span class=\"token\">{<\/span>\r\n    <span class=\"token directive\">worker_connections<\/span> <span class=\"token directive\">1024<\/span><span class=\"token\">;<\/span>\r\n<span class=\"token\">}<\/span>\r\n\r\n<span class=\"token directive\">http<\/span> <span class=\"token\">{<\/span>\r\n    <span class=\"token directive\">include<\/span><span class=\"token directive\">       \/etc\/nginx\/mime.types<\/span><span class=\"token\">;<\/span>\r\n    <span class=\"token directive\">default_type<\/span><span class=\"token directive\">  application\/octet-stream<\/span><span class=\"token\">;<\/span>\r\n\r\n    <span class=\"token\"># gzip \u5727\u7e2e\u3092\u6709\u52b9\u5316\uff08\u9ad8\u901f\u5316\uff09<\/span>\r\n    <span class=\"token directive\">gzip<\/span> <span class=\"token directive\">on<\/span><span class=\"token\">;<\/span>\r\n    <span class=\"token directive\">gzip_types<\/span><span class=\"token directive\"> text\/plain text\/css application\/json application\/javascript<\/span><span class=\"token\">;<\/span>\r\n\r\n    <span class=\"token directive\">server<\/span> <span class=\"token\">{<\/span>\r\n        <span class=\"token directive\">listen<\/span> <span class=\"token directive\">80<\/span><span class=\"token\">;<\/span>\r\n        <span class=\"token directive\">server_name<\/span><span class=\"token directive\"> localhost<\/span><span class=\"token\">;<\/span>\r\n\r\n        <span class=\"token\"># SPA\u306e\u30eb\u30fc\u30c6\u30a3\u30f3\u30b0\u5bfe\u5fdc<\/span>\r\n        <span class=\"token directive\">location<\/span><span class=\"token directive\"> \/<\/span> <span class=\"token\">{<\/span>\r\n            <span class=\"token directive\">root<\/span><span class=\"token directive\"> \/usr\/share\/nginx\/html<\/span><span class=\"token\">;<\/span>\r\n            <span class=\"token directive\">index<\/span><span class=\"token directive\"> index.html index.htm<\/span><span class=\"token\">;<\/span>\r\n            <span class=\"token directive\">try_files<\/span> <span class=\"token directive\">$uri<\/span> <span class=\"token directive\">$uri<\/span><span class=\"token directive\">\/ \/index.html<\/span><span class=\"token\">;<\/span>\r\n        <span class=\"token\">}<\/span>\r\n\r\n        <span class=\"token\"># \u9759\u7684\u30d5\u30a1\u30a4\u30eb\u306e\u30ad\u30e3\u30c3\u30b7\u30e5\u8a2d\u5b9a<\/span>\r\n        <span class=\"token directive\">location<\/span><span class=\"token directive\"> ~* \\.(js|css|png|jpg|jpeg|gif|ico|svg)$<\/span> <span class=\"token\">{<\/span>\r\n            <span class=\"token directive\">expires<\/span> <span class=\"token directive\">1y<\/span><span class=\"token\">;<\/span>\r\n            <span class=\"token directive\">add_header<\/span><span class=\"token directive\"> Cache-Control <\/span><span class=\"token directive\">\"public, immutable\"<\/span><span class=\"token\">;<\/span>\r\n        <span class=\"token\">}<\/span>\r\n    <span class=\"token\">}<\/span>\r\n<span class=\"token\">}<\/span><\/code><\/pre>\n<\/div>\n<\/div>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">3. Docker Compose \u30d5\u30a1\u30a4\u30eb\uff08\u958b\u767a\u7528\uff09<\/h3>\n<p class=\"whitespace-normal break-words\">[docker-compose.yml \u3092\u4f5c\u6210\u4e2d&#8230;]<\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"text-text-500 text-xs p-3.5 pb-0\">yaml<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code class=\"language-yaml\"><span class=\"token key\">version<\/span><span class=\"token\">:<\/span> <span class=\"token\">'3.8'<\/span>\r\n\r\n<span class=\"token key\">services<\/span><span class=\"token\">:<\/span>\r\n  <span class=\"token\"># \u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\uff08React \u30a2\u30d7\u30ea\uff09<\/span>\r\n  <span class=\"token key\">frontend<\/span><span class=\"token\">:<\/span>\r\n    <span class=\"token key\">build<\/span><span class=\"token\">:<\/span> .\r\n    <span class=\"token key\">ports<\/span><span class=\"token\">:<\/span>\r\n      <span class=\"token\">-<\/span> <span class=\"token\">\"3000:80\"<\/span>\r\n    <span class=\"token key\">environment<\/span><span class=\"token\">:<\/span>\r\n      <span class=\"token\">-<\/span> REACT_APP_API_URL=http<span class=\"token\">:<\/span>\/\/localhost<span class=\"token\">:<\/span><span class=\"token\">3001<\/span>\r\n    <span class=\"token key\">depends_on<\/span><span class=\"token\">:<\/span>\r\n      <span class=\"token\">-<\/span> backend\r\n\r\n  <span class=\"token\"># \u30d0\u30c3\u30af\u30a8\u30f3\u30c9\uff08Node.js API\uff09<\/span>\r\n  <span class=\"token key\">backend<\/span><span class=\"token\">:<\/span>\r\n    <span class=\"token key\">build<\/span><span class=\"token\">:<\/span> .\/backend\r\n    <span class=\"token key\">ports<\/span><span class=\"token\">:<\/span>\r\n      <span class=\"token\">-<\/span> <span class=\"token\">\"3001:3001\"<\/span>\r\n    <span class=\"token key\">environment<\/span><span class=\"token\">:<\/span>\r\n      <span class=\"token\">-<\/span> NODE_ENV=development\r\n      <span class=\"token\">-<\/span> DB_HOST=database\r\n      <span class=\"token\">-<\/span> DB_PORT=5432\r\n      <span class=\"token\">-<\/span> DB_NAME=myapp\r\n      <span class=\"token\">-<\/span> DB_USER=postgres\r\n      <span class=\"token\">-<\/span> DB_PASSWORD=password\r\n    <span class=\"token key\">depends_on<\/span><span class=\"token\">:<\/span>\r\n      <span class=\"token\">-<\/span> database\r\n\r\n  <span class=\"token\"># \u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\uff08PostgreSQL\uff09<\/span>\r\n  <span class=\"token key\">database<\/span><span class=\"token\">:<\/span>\r\n    <span class=\"token key\">image<\/span><span class=\"token\">:<\/span> postgres<span class=\"token\">:<\/span>15<span class=\"token\">-<\/span>alpine\r\n    <span class=\"token key\">environment<\/span><span class=\"token\">:<\/span>\r\n      <span class=\"token\">-<\/span> POSTGRES_DB=myapp\r\n      <span class=\"token\">-<\/span> POSTGRES_USER=postgres\r\n      <span class=\"token\">-<\/span> POSTGRES_PASSWORD=password\r\n    <span class=\"token key\">volumes<\/span><span class=\"token\">:<\/span>\r\n      <span class=\"token\">-<\/span> postgres_data<span class=\"token\">:<\/span>\/var\/lib\/postgresql\/data\r\n    <span class=\"token key\">ports<\/span><span class=\"token\">:<\/span>\r\n      <span class=\"token\">-<\/span> <span class=\"token\">\"5432:5432\"<\/span>\r\n\r\n<span class=\"token key\">volumes<\/span><span class=\"token\">:<\/span>\r\n  postgres_data<span class=\"token\">:<\/span><\/code><\/pre>\n<\/div>\n<\/div>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">4. .dockerignore \u30d5\u30a1\u30a4\u30eb<\/h3>\n<p class=\"whitespace-normal break-words\">[.dockerignore \u3092\u4f5c\u6210\u4e2d&#8230;]<\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code>node_modules\r\nnpm-debug.log\r\nbuild\r\n.git\r\n.gitignore\r\nREADME.md\r\n.env\r\n.nyc_output\r\ncoverage\r\n.coverage<\/code><\/pre>\n<\/div>\n<\/div>\n<p class=\"whitespace-normal break-words\">Docker \u74b0\u5883\u3092\u30c6\u30b9\u30c8\u3057\u307e\u3059\u304b\uff1f<\/p>\n<p class=\"whitespace-normal break-words\">\u958b\u767a\u8005: \u30c6\u30b9\u30c8\u3057\u3066\u307f\u3066<\/p>\n<p class=\"whitespace-normal break-words\">claude: Docker \u74b0\u5883\u3092\u30c6\u30b9\u30c8\u3057\u307e\u3059\u3002<\/p>\n<p class=\"whitespace-normal break-words\">[docker build -t my-react-app . \u3092\u5b9f\u884c\u4e2d&#8230;]<\/p>\n<p class=\"whitespace-normal break-words\">\ud83d\udce6 Docker \u30a4\u30e1\u30fc\u30b8\u3092\u30d3\u30eb\u30c9\u4e2d&#8230; \u2705 \u30d3\u30eb\u30c9\u5b8c\u4e86\uff1amy-react-app:latest<\/p>\n<p class=\"whitespace-normal break-words\">[docker run -p 3000:80 my-react-app \u3092\u5b9f\u884c\u4e2d&#8230;]<\/p>\n<p class=\"whitespace-normal break-words\">\ud83d\ude80 \u30b3\u30f3\u30c6\u30ca\u3092\u8d77\u52d5\u3057\u307e\u3057\u305f \ud83c\udf10 \u30a2\u30af\u30bb\u30b9\u5148\uff1a<a class=\"underline\" href=\"http:\/\/localhost:3000\">http:\/\/localhost:3000<\/a><\/p>\n<p class=\"whitespace-pre-wrap break-words\">\u52d5\u4f5c\u78ba\u8a8d\u4e2d&#8230; \u2705 \u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u304c\u6b63\u5e38\u306b\u52d5\u4f5c\u3057\u3066\u3044\u307e\u3059 \u2705 SPA\u30eb\u30fc\u30c6\u30a3\u30f3\u30b0\u3082\u6b63\u5e38\u306b\u6a5f\u80fd\u3057\u3066\u3044\u307e\u3059 \u2705 \u9759\u7684\u30d5\u30a1\u30a4\u30eb\u306e\u914d\u4fe1\u3082\u554f\u984c\u3042\u308a\u307e\u305b\u3093<\/p>\n<p class=\"whitespace-normal break-words\">\u672c\u756a\u74b0\u5883\u30c7\u30d7\u30ed\u30a4\u7528\u306e\u30b3\u30de\u30f3\u30c9\u3082\u4f5c\u6210\u3057\u3066\u304a\u304d\u307e\u3059\u306d\uff1a<\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"text-text-500 text-xs p-3.5 pb-0\">bash<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code class=\"language-bash\"><span class=\"token\"># \u30a4\u30e1\u30fc\u30b8\u3092\u30d3\u30eb\u30c9<\/span>\r\n<span class=\"token\">docker<\/span> build -t my-react-app:v1.0.0 <span class=\"token\">.<\/span>\r\n\r\n<span class=\"token\"># \u30ec\u30b8\u30b9\u30c8\u30ea\u306b\u30d7\u30c3\u30b7\u30e5\uff08\u4f8b\uff1aDocker Hub\uff09<\/span>\r\n<span class=\"token\">docker<\/span> tag my-react-app:v1.0.0 username\/my-react-app:v1.0.0\r\n<span class=\"token\">docker<\/span> push username\/my-react-app:v1.0.0\r\n\r\n<span class=\"token\"># \u672c\u756a\u30b5\u30fc\u30d0\u30fc\u3067\u306e\u8d77\u52d5<\/span>\r\n<span class=\"token\">docker<\/span> run -d --name my-app -p <span class=\"token\">80<\/span>:80 username\/my-react-app:v1.0.0<\/code><\/pre>\n<\/div>\n<\/div>\n<p class=\"whitespace-normal break-words\">\u8a2d\u5b9a\u3092\u30b3\u30df\u30c3\u30c8\u3057\u307e\u3059\u304b\uff1f<\/p>\n<p class=\"whitespace-normal break-words\">\u958b\u767a\u8005: \u306f\u3044<\/p>\n<p class=\"whitespace-normal break-words\">claude: Docker \u8a2d\u5b9a\u3092\u30b3\u30df\u30c3\u30c8\u3057\u307e\u3059\u3002<\/p>\n<p class=\"whitespace-pre-wrap break-words\">[git add Dockerfile nginx.conf docker-compose.yml .dockerignore] [git commit -m &#8220;feat(docker): Docker \u30b3\u30f3\u30c6\u30ca\u5316\u8a2d\u5b9a\u3092\u8ffd\u52a0<\/p>\n<ul class=\"[&amp;:not(:last-child)_ul]:pb-1 [&amp;:not(:last-child)_ol]:pb-1 list-disc space-y-1.5 pl-7\">\n<li class=\"whitespace-normal break-words\">\u30de\u30eb\u30c1\u30b9\u30c6\u30fc\u30b8\u30d3\u30eb\u30c9\u3067\u8efd\u91cf\u5316<\/li>\n<li class=\"whitespace-normal break-words\">Nginx \u3067\u306e\u9ad8\u901f\u914d\u4fe1<\/li>\n<li class=\"whitespace-normal break-words\">SPA \u30eb\u30fc\u30c6\u30a3\u30f3\u30b0\u5bfe\u5fdc<\/li>\n<li class=\"whitespace-normal break-words\">\u958b\u767a\u7528 docker-compose \u8a2d\u5b9a&#8221;] [git push origin main]<\/li>\n<\/ul>\n<p class=\"whitespace-normal break-words\">\u2705 Docker \u8a2d\u5b9a\u3092\u30d7\u30c3\u30b7\u30e5\u3057\u307e\u3057\u305f<\/p>\n<p class=\"whitespace-pre-wrap break-words\">\u3053\u308c\u3067\u672c\u683c\u7684\u306a\u672c\u756a\u74b0\u5883\u30c7\u30d7\u30ed\u30a4\u306e\u6e96\u5099\u304c\u6574\u3044\u307e\u3057\u305f\uff01 AWS\u3001Google Cloud\u3001Azure \u306a\u3069\u306e\u5404\u7a2e\u30af\u30e9\u30a6\u30c9\u30b5\u30fc\u30d3\u30b9\u3067\u3082 \u3053\u306e\u30b3\u30f3\u30c6\u30ca\u3092\u305d\u306e\u307e\u307e\u30c7\u30d7\u30ed\u30a4\u3067\u304d\u307e\u3059\u3002<\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code>\r\n### \u2601\ufe0f \u30af\u30e9\u30a6\u30c9\u30b5\u30fc\u30d3\u30b9\u3067\u306e\u30c7\u30d7\u30ed\u30a4\r\n\r\n**AWS \u3067\u306e\u672c\u683c\u904b\u7528**<\/code><\/pre>\n<\/div>\n<\/div>\n<p class=\"whitespace-normal break-words\">\u958b\u767a\u8005: AWS\u3067\u30b9\u30b1\u30fc\u30e9\u30d6\u30eb\u306b\u30c7\u30d7\u30ed\u30a4\u3057\u305f\u3044<\/p>\n<p class=\"whitespace-pre-wrap break-words\">claude: AWS \u3067\u306e\u672c\u683c\u7684\u306a\u30c7\u30d7\u30ed\u30a4\u8a2d\u5b9a\u3092\u884c\u3044\u307e\u3059\u306d\u3002 ECS (Elastic Container Service) \u3092\u4f7f\u3063\u305f\u69cb\u6210\u3092\u63d0\u6848\u3057\u307e\u3059\u3002<\/p>\n<h2 class=\"text-xl font-bold text-text-100 mt-1 -mb-0.5\">\ud83c\udf29\ufe0f AWS ECS \u30c7\u30d7\u30ed\u30a4\u8a2d\u5b9a<\/h2>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">1. \u30bf\u30b9\u30af\u5b9a\u7fa9\u30d5\u30a1\u30a4\u30eb<\/h3>\n<p class=\"whitespace-normal break-words\">[aws-task-definition.json \u3092\u4f5c\u6210\u4e2d&#8230;]<\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"text-text-500 text-xs p-3.5 pb-0\">json<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code class=\"language-json\"><span class=\"token\">{<\/span>\r\n  <span class=\"token\">\"family\"<\/span><span class=\"token\">:<\/span> <span class=\"token\">\"my-react-app\"<\/span><span class=\"token\">,<\/span>\r\n  <span class=\"token\">\"networkMode\"<\/span><span class=\"token\">:<\/span> <span class=\"token\">\"awsvpc\"<\/span><span class=\"token\">,<\/span>\r\n  <span class=\"token\">\"requiresCompatibilities\"<\/span><span class=\"token\">:<\/span> <span class=\"token\">[<\/span><span class=\"token\">\"FARGATE\"<\/span><span class=\"token\">]<\/span><span class=\"token\">,<\/span>\r\n  <span class=\"token\">\"cpu\"<\/span><span class=\"token\">:<\/span> <span class=\"token\">\"256\"<\/span><span class=\"token\">,<\/span>\r\n  <span class=\"token\">\"memory\"<\/span><span class=\"token\">:<\/span> <span class=\"token\">\"512\"<\/span><span class=\"token\">,<\/span>\r\n  <span class=\"token\">\"executionRoleArn\"<\/span><span class=\"token\">:<\/span> <span class=\"token\">\"arn:aws:iam::ACCOUNT:role\/ecsTaskExecutionRole\"<\/span><span class=\"token\">,<\/span>\r\n  <span class=\"token\">\"containerDefinitions\"<\/span><span class=\"token\">:<\/span> <span class=\"token\">[<\/span>\r\n    <span class=\"token\">{<\/span>\r\n      <span class=\"token\">\"name\"<\/span><span class=\"token\">:<\/span> <span class=\"token\">\"my-react-app\"<\/span><span class=\"token\">,<\/span>\r\n      <span class=\"token\">\"image\"<\/span><span class=\"token\">:<\/span> <span class=\"token\">\"my-react-app:latest\"<\/span><span class=\"token\">,<\/span>\r\n      <span class=\"token\">\"portMappings\"<\/span><span class=\"token\">:<\/span> <span class=\"token\">[<\/span>\r\n        <span class=\"token\">{<\/span>\r\n          <span class=\"token\">\"containerPort\"<\/span><span class=\"token\">:<\/span> <span class=\"token\">80<\/span><span class=\"token\">,<\/span>\r\n          <span class=\"token\">\"protocol\"<\/span><span class=\"token\">:<\/span> <span class=\"token\">\"tcp\"<\/span>\r\n        <span class=\"token\">}<\/span>\r\n      <span class=\"token\">]<\/span><span class=\"token\">,<\/span>\r\n      <span class=\"token\">\"environment\"<\/span><span class=\"token\">:<\/span> <span class=\"token\">[<\/span>\r\n        <span class=\"token\">{<\/span>\r\n          <span class=\"token\">\"name\"<\/span><span class=\"token\">:<\/span> <span class=\"token\">\"NODE_ENV\"<\/span><span class=\"token\">,<\/span>\r\n          <span class=\"token\">\"value\"<\/span><span class=\"token\">:<\/span> <span class=\"token\">\"production\"<\/span>\r\n        <span class=\"token\">}<\/span>\r\n      <span class=\"token\">]<\/span><span class=\"token\">,<\/span>\r\n      <span class=\"token\">\"logConfiguration\"<\/span><span class=\"token\">:<\/span> <span class=\"token\">{<\/span>\r\n        <span class=\"token\">\"logDriver\"<\/span><span class=\"token\">:<\/span> <span class=\"token\">\"awslogs\"<\/span><span class=\"token\">,<\/span>\r\n        <span class=\"token\">\"options\"<\/span><span class=\"token\">:<\/span> <span class=\"token\">{<\/span>\r\n          <span class=\"token\">\"awslogs-group\"<\/span><span class=\"token\">:<\/span> <span class=\"token\">\"\/ecs\/my-react-app\"<\/span><span class=\"token\">,<\/span>\r\n          <span class=\"token\">\"awslogs-region\"<\/span><span class=\"token\">:<\/span> <span class=\"token\">\"ap-northeast-1\"<\/span><span class=\"token\">,<\/span>\r\n          <span class=\"token\">\"awslogs-stream-prefix\"<\/span><span class=\"token\">:<\/span> <span class=\"token\">\"ecs\"<\/span>\r\n        <span class=\"token\">}<\/span>\r\n      <span class=\"token\">}<\/span>\r\n    <span class=\"token\">}<\/span>\r\n  <span class=\"token\">]<\/span>\r\n<span class=\"token\">}<\/span><\/code><\/pre>\n<\/div>\n<\/div>\n<h3 class=\"text-lg font-bold text-text-100 mt-1 -mb-1.5\">2. GitHub Actions \u3067\u306e\u81ea\u52d5\u30c7\u30d7\u30ed\u30a4<\/h3>\n<p class=\"whitespace-normal break-words\">[.github\/workflows\/deploy-aws.yml \u3092\u4f5c\u6210\u4e2d&#8230;]<\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"text-text-500 text-xs p-3.5 pb-0\">yaml<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code class=\"language-yaml\"><span class=\"token scalar\"><span class=\"token key\">name<\/span><span class=\"token\">:<\/span> Deploy to AWS ECS\r\n<\/span>\r\n<span class=\"token scalar\"><span class=\"token key\">on<\/span><span class=\"token\">:<\/span>\r\n<\/span><span class=\"token scalar\">  <span class=\"token key\">push<\/span><span class=\"token\">:<\/span>\r\n<\/span><span class=\"token scalar\">    <span class=\"token key\">branches<\/span><span class=\"token\">:<\/span> <span class=\"token\">[<\/span> main <span class=\"token\">]<\/span>\r\n<\/span>\r\n<span class=\"token scalar\"><span class=\"token key\">jobs<\/span><span class=\"token\">:<\/span>\r\n<\/span><span class=\"token scalar\">  <span class=\"token key\">deploy<\/span><span class=\"token\">:<\/span>\r\n<\/span><span class=\"token scalar\">    <span class=\"token key\">runs-on<\/span><span class=\"token\">:<\/span> ubuntu<span class=\"token\">-<\/span>latest\r\n<\/span>    \r\n<span class=\"token scalar\">    <span class=\"token key\">steps<\/span><span class=\"token\">:<\/span>\r\n<\/span><span class=\"token scalar\">    <span class=\"token\">-<\/span> <span class=\"token key\">name<\/span><span class=\"token\">:<\/span> Checkout code\r\n<\/span><span class=\"token scalar\">      <span class=\"token key\">uses<\/span><span class=\"token\">:<\/span> actions\/checkout@v4\r\n<\/span>\r\n<span class=\"token scalar\">    <span class=\"token\">-<\/span> <span class=\"token key\">name<\/span><span class=\"token\">:<\/span> Configure AWS credentials\r\n<\/span><span class=\"token scalar\">      <span class=\"token key\">uses<\/span><span class=\"token\">:<\/span> aws<span class=\"token\">-<\/span>actions\/configure<span class=\"token\">-<\/span>aws<span class=\"token\">-<\/span>credentials@v2\r\n<\/span><span class=\"token scalar\">      <span class=\"token key\">with<\/span><span class=\"token\">:<\/span>\r\n<\/span><span class=\"token scalar\">        <span class=\"token key\">aws-access-key-id<\/span><span class=\"token\">:<\/span> $<span class=\"token\">{<\/span><span class=\"token\">{<\/span> secrets.AWS_ACCESS_KEY_ID <span class=\"token\">}<\/span><span class=\"token\">}<\/span>\r\n<\/span><span class=\"token scalar\">        <span class=\"token key\">aws-secret-access-key<\/span><span class=\"token\">:<\/span> $<span class=\"token\">{<\/span><span class=\"token\">{<\/span> secrets.AWS_SECRET_ACCESS_KEY <span class=\"token\">}<\/span><span class=\"token\">}<\/span>\r\n<\/span><span class=\"token scalar\">        <span class=\"token key\">aws-region<\/span><span class=\"token\">:<\/span> ap<span class=\"token\">-<\/span>northeast<span class=\"token\">-<\/span><span class=\"token\">1<\/span>\r\n<\/span>\r\n<span class=\"token scalar\">    <span class=\"token\">-<\/span> <span class=\"token key\">name<\/span><span class=\"token\">:<\/span> Login to Amazon ECR\r\n<\/span><span class=\"token scalar\">      <span class=\"token key\">uses<\/span><span class=\"token\">:<\/span> aws<span class=\"token\">-<\/span>actions\/amazon<span class=\"token\">-<\/span>ecr<span class=\"token\">-<\/span>login@v1\r\n<\/span>\r\n<span class=\"token scalar\">    <span class=\"token\">-<\/span> <span class=\"token key\">name<\/span><span class=\"token\">:<\/span> Build and push Docker image\r\n<\/span><span class=\"token scalar\">      <span class=\"token key\">run<\/span><span class=\"token\">:<\/span> <span class=\"token\">|<\/span>\r\n<\/span><span class=\"token scalar\">        docker build -t my-react-app .\r\n<\/span><span class=\"token scalar\">        docker tag my-react-app:latest $ECR_REGISTRY\/my-react-app:latest\r\n<\/span><span class=\"token scalar\">        docker push $ECR_REGISTRY\/my-react-app:latest\r\n<\/span>\r\n<span class=\"token scalar\">    <span class=\"token\">-<\/span> <span class=\"token key\">name<\/span><span class=\"token\">:<\/span> Deploy to ECS\r\n<\/span><span class=\"token scalar\">      <span class=\"token key\">run<\/span><span class=\"token\">:<\/span> <span class=\"token\">|<\/span>\r\n<\/span><span class=\"token scalar\">        aws ecs update-service \\\r\n<\/span><span class=\"token scalar\">          --cluster my-cluster \\\r\n<\/span><span class=\"token scalar\">          --service my-react-app-service \\\r\n<\/span><span class=\"token scalar\">          --force-new-deployment<\/span><\/code><\/pre>\n<\/div>\n<\/div>\n<p class=\"whitespace-normal break-words\">\u3053\u308c\u3067\u672c\u683c\u7684\u306a\u30b9\u30b1\u30fc\u30e9\u30d6\u30eb\u30c7\u30d7\u30ed\u30a4\u304c\u53ef\u80fd\u306b\u306a\u308a\u307e\u3059\uff01<\/p>\n<div class=\"relative group\/copy rounded-lg\">\n<div class=\"sticky opacity-0 group-hover\/copy:opacity-100 top-2 py-2 h-12 w-0 float-right\">\n<div class=\"absolute right-0 h-8 px-2 items-center inline-flex\">\n<div class=\"relative\"><\/div>\n<\/div>\n<\/div>\n<div class=\"\">\n<pre class=\"code-block__code !my-0 !rounded-lg !text-sm !leading-relaxed\"><code>\r\n\ud83d\udc3b\u200d\u2744\ufe0f\u300c\u3075\u3045\u3001\u3053\u308c\u3067\u5b8c\u74a7\u306a\u5b8c\u5168\u7248\u306b\u306a\u3063\u305f\u305e\u3044\uff01\u300d\r\n\ud83e\uddf8\u300c\u3059\u3054\u3044\uff01Netlify \u304b\u3089 Docker\u3001AWS\u307e\u3067\u5e45\u5e83\u304f\u30ab\u30d0\u30fc\u3055\u308c\u3066\u308b\u30af\u30de\uff01\u300d\r\n\ud83d\udc3b\u200d\u2744\ufe0f\u300c\u30c7\u30d7\u30ed\u30a4\u306e\u96e3\u6613\u5ea6\u5225\u306b\u6bb5\u968e\u3092\u5206\u3051\u3066\u3001\u521d\u5fc3\u8005\u304b\u3089\u4e0a\u7d1a\u8005\u307e\u3067\u5bfe\u5fdc\u3067\u304d\u308b\u3088\u3046\u306b\u3057\u305f\u306e\u3058\u3083\u2728\u300d<\/code><\/pre>\n<\/div>\n<\/div>\n","protected":false},"excerpt":{"rendered":"<p>\u308f\u3057\u306f\u4eca\u65e5\u3001\u304a\u4e3b\u3089\u306b\u7279\u5225\u306a\u8a71\u3092\u3057\u3088\u3046\u3068\u601d\u3046\u306e\u3058\u3083\u3002GitHub\u3068\u306f\u4f55\u305e\u3084\uff1f\u304b\u3089\u59cb\u307e\u3063\u3066\u3001Claude Code\u306e\u5b9f\u8df5\u7684\u306a\u4f7f\u3044\u65b9\u307e\u3067\u3001\u624b\u53d6\u308a\u8db3\u53d6\u308a\u6559\u3048\u3066\u3044\u304f\u3067\u3059\u305e\u301c\uff01\u7279\u306b\u300c\u5b9f\u969b\u306b\u3069\u3046\u3084\u3063\u3066\u4f7f\u3046\u306e\uff1f\u300d\u3068\u3044\u3046\u7591\u554f\u306b\u30d0\u30c3\u30c1\u30ea\u7b54\u3048 [&hellip;]<\/p>\n","protected":false},"author":2,"featured_media":15385,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_acf_changed":false,"footnotes":""},"categories":[6],"tags":[],"class_list":["post-16066","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-aiandotherworlds"],"acf":[],"_links":{"self":[{"href":"https:\/\/jyakusyadansei.com\/index.php?rest_route=\/wp\/v2\/posts\/16066","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/jyakusyadansei.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/jyakusyadansei.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/jyakusyadansei.com\/index.php?rest_route=\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"https:\/\/jyakusyadansei.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=16066"}],"version-history":[{"count":2,"href":"https:\/\/jyakusyadansei.com\/index.php?rest_route=\/wp\/v2\/posts\/16066\/revisions"}],"predecessor-version":[{"id":16068,"href":"https:\/\/jyakusyadansei.com\/index.php?rest_route=\/wp\/v2\/posts\/16066\/revisions\/16068"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/jyakusyadansei.com\/index.php?rest_route=\/wp\/v2\/media\/15385"}],"wp:attachment":[{"href":"https:\/\/jyakusyadansei.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=16066"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/jyakusyadansei.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=16066"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/jyakusyadansei.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=16066"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}