{"id":104,"date":"2026-03-29T02:11:27","date_gmt":"2026-03-28T18:11:27","guid":{"rendered":"https:\/\/word.ronrin.cn\/?p=104"},"modified":"2026-03-29T02:11:27","modified_gmt":"2026-03-28T18:11:27","slug":"104","status":"publish","type":"post","link":"https:\/\/word.ronrin.cn\/index.php\/2026\/03\/29\/104\/","title":{"rendered":""},"content":{"rendered":"\n<h1 class=\"wp-block-heading\">\u73b0\u4ee3\u5316\u5168\u6808\u7535\u5546\u7f51\u7ad9\uff08\u542b\u7528\u6237\u7cfb\u7edf\uff09\u6280\u672f\u6808\u89c4\u5212<\/h1>\n\n\n\n<p>\u8fd9\u662f\u4e00\u5957<strong>2026 \u5e74\u4e3b\u6d41\u3001\u9ad8\u6027\u80fd\u3001\u53ef\u843d\u5730\u3001\u4f01\u4e1a\u7ea7<\/strong>\u7684\u7535\u5546\u6280\u672f\u65b9\u6848\uff0c\u8986\u76d6\u524d\u7aef\u3001\u540e\u7aef\u3001\u6570\u636e\u5e93\u3001\u7f13\u5b58\u3001\u6d88\u606f\u961f\u5217\u3001\u90e8\u7f72\u3001\u5b89\u5168\u3001\u76d1\u63a7\u5168\u94fe\u8def\uff0c\u652f\u6301<strong>\u9ad8\u5e76\u53d1\u3001\u79d2\u6740\u3001\u7528\u6237\u4e2d\u5fc3\u3001\u8ba2\u5355\u3001\u652f\u4ed8\u3001\u5546\u54c1<\/strong>\u7b49\u6838\u5fc3\u7535\u5546\u573a\u666f\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">\u4e00\u3001\u6574\u4f53\u67b6\u6784\u5b9a\u4f4d<\/h2>\n\n\n\n<p>\u91c7\u7528 <strong>\u524d\u540e\u7aef\u5206\u79bb + \u5fae\u670d\u52a1 \/ \u6a21\u5757\u5316 + \u4e91\u539f\u751f<\/strong> \u67b6\u6784<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u524d\u7aef\uff1aSPA \u5355\u9875\u5e94\u7528 + \u79fb\u52a8\u7aef\u9002\u914d<\/li>\n\n\n\n<li>\u540e\u7aef\uff1a\u6a21\u5757\u5316\u670d\u52a1\uff08\u53ef\u5e73\u6ed1\u5347\u7ea7\u5fae\u670d\u52a1\uff09<\/li>\n\n\n\n<li>\u6570\u636e\uff1a\u8bfb\u5199\u5206\u79bb + \u7f13\u5b58 + \u641c\u7d22\u5f15\u64ce<\/li>\n\n\n\n<li>\u90e8\u7f72\uff1a\u5bb9\u5668\u5316 + \u81ea\u52a8\u5316 CI\/CD<\/li>\n<\/ul>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity\"\/>\n\n\n\n<h2 class=\"wp-block-heading\">\u4e8c\u3001\u6838\u5fc3\u6280\u672f\u6808\u603b\u89c8<\/h2>\n\n\n\n<h3 class=\"wp-block-heading\">1. \u524d\u7aef\uff08\u6700\u65b0\u3001\u751f\u6001\u6700\u5b8c\u5584\uff09<\/h3>\n\n\n\n<p>\u8868\u683c<\/p>\n\n\n\n<figure class=\"wp-block-table\"><table class=\"has-fixed-layout\"><thead><tr><th class=\"has-text-align-center\" data-align=\"center\">\u6280\u672f<\/th><th class=\"has-text-align-center\" data-align=\"center\">\u9009\u578b<\/th><th class=\"has-text-align-center\" data-align=\"center\">\u7528\u9014<\/th><\/tr><\/thead><tbody><tr><td>\u6846\u67b6<\/td><td><strong>React 19<\/strong><\/td><td>\u4e3b\u7ad9\u5f00\u53d1\uff08\u6700\u65b0\u7279\u6027\uff1a\u7f16\u8bd1\u5668\u3001\u670d\u52a1\u7ec4\u4ef6\uff09<\/td><\/tr><tr><td>\u6253\u5305<\/td><td><strong>Vite<\/strong><\/td><td>\u6781\u901f\u6784\u5efa\u3001\u70ed\u66f4\u65b0<\/td><\/tr><tr><td>\u72b6\u6001\u7ba1\u7406<\/td><td><strong>Zustand \/ TanStack Query<\/strong><\/td><td>\u5168\u5c40\u72b6\u6001 + \u670d\u52a1\u7aef\u6570\u636e\u7f13\u5b58<\/td><\/tr><tr><td>UI \u7ec4\u4ef6<\/td><td><strong>ShadCN UI + Tailwind CSS<\/strong><\/td><td>\u73b0\u4ee3\u5316\u3001\u53ef\u5b9a\u5236\u3001\u9ad8\u989c\u503c<\/td><\/tr><tr><td>\u8868\u5355<\/td><td><strong>React Hook Form + Zod<\/strong><\/td><td>\u9ad8\u6027\u80fd\u8868\u5355 + \u7c7b\u578b\u6821\u9a8c<\/td><\/tr><tr><td>\u79fb\u52a8\u7aef<\/td><td>\u54cd\u5e94\u5f0f + PWA<\/td><td>\u652f\u6301\u6dfb\u52a0\u5230\u684c\u9762\u3001\u79bb\u7ebf\u8bbf\u95ee<\/td><\/tr><tr><td>\u652f\u4ed8 \/ \u5f39\u7a97<\/td><td>\u539f\u751f\u7ec4\u4ef6 + \u7b2c\u4e09\u65b9 SDK<\/td><td>\u652f\u4ed8\u5b9d \/ \u5fae\u4fe1 \/ Stripe<\/td><\/tr><\/tbody><\/table><\/figure>\n\n\n\n<h3 class=\"wp-block-heading\">2. \u540e\u7aef\uff08\u9ad8\u6027\u80fd\u3001\u5b89\u5168\u3001\u6613\u7ef4\u62a4\uff09<\/h3>\n\n\n\n<p>\u8868\u683c<\/p>\n\n\n\n<figure class=\"wp-block-table\"><table class=\"has-fixed-layout\"><thead><tr><th class=\"has-text-align-center\" data-align=\"center\">\u6280\u672f<\/th><th class=\"has-text-align-center\" data-align=\"center\">\u9009\u578b<\/th><th class=\"has-text-align-center\" data-align=\"center\">\u7528\u9014<\/th><\/tr><\/thead><tbody><tr><td>\u8bed\u8a00 \/ \u6846\u67b6<\/td><td><strong>Node.js + NestJS<\/strong><\/td><td>\u4f01\u4e1a\u7ea7 TS \u540e\u7aef\uff0c\u6a21\u5757\u5316\u3001\u4f9d\u8d56\u6ce8\u5165<\/td><\/tr><tr><td>API \u98ce\u683c<\/td><td><strong>RESTful + Swagger<\/strong><\/td><td>\u6807\u51c6\u63a5\u53e3 + \u81ea\u52a8\u6587\u6863<\/td><\/tr><tr><td>\u8ba4\u8bc1\u6388\u6743<\/td><td><strong>JWT + Refresh Token + \u6743\u9650 RBAC<\/strong><\/td><td>\u7528\u6237\u7cfb\u7edf\u6838\u5fc3\u5b89\u5168<\/td><\/tr><tr><td>\u7b2c\u4e09\u65b9\u767b\u5f55<\/td><td>OAuth2.0\uff08\u5fae\u4fe1 \/ \u652f\u4ed8\u5b9d \/ Google\uff09<\/td><td>\u5feb\u6377\u767b\u5f55<\/td><\/tr><\/tbody><\/table><\/figure>\n\n\n\n<h3 class=\"wp-block-heading\">3. \u6570\u636e\u5b58\u50a8\uff08\u7535\u5546\u9ad8\u5e76\u53d1\u5fc5\u5907\uff09<\/h3>\n\n\n\n<p>\u8868\u683c<\/p>\n\n\n\n<figure class=\"wp-block-table\"><table class=\"has-fixed-layout\"><thead><tr><th class=\"has-text-align-center\" data-align=\"center\">\u6280\u672f<\/th><th class=\"has-text-align-center\" data-align=\"center\">\u9009\u578b<\/th><th class=\"has-text-align-center\" data-align=\"center\">\u7528\u9014<\/th><\/tr><\/thead><tbody><tr><td>\u4e3b\u6570\u636e\u5e93<\/td><td><strong>PostgreSQL<\/strong><\/td><td>\u4e8b\u52a1\u5f3a\u4e00\u81f4\uff08\u8ba2\u5355\u3001\u7528\u6237\u3001\u652f\u4ed8\uff09<\/td><\/tr><tr><td>\u7f13\u5b58<\/td><td><strong>Redis<\/strong><\/td><td>\u767b\u5f55\u72b6\u6001\u3001\u8d2d\u7269\u8f66\u3001\u79d2\u6740\u3001\u70ed\u70b9\u5546\u54c1<\/td><\/tr><tr><td>\u641c\u7d22\u5f15\u64ce<\/td><td><strong>Elasticsearch<\/strong><\/td><td>\u5546\u54c1\u641c\u7d22\u3001\u7b5b\u9009\u3001\u6392\u5e8f<\/td><\/tr><tr><td>\u56fe\u7247 \/ \u6587\u4ef6<\/td><td><strong>MinIO \/ OSS<\/strong><\/td><td>\u5546\u54c1\u56fe\u7247\u3001\u5934\u50cf\u5b58\u50a8<\/td><\/tr><\/tbody><\/table><\/figure>\n\n\n\n<h3 class=\"wp-block-heading\">4. \u9ad8\u5e76\u53d1 \/ \u5f02\u6b65\u5fc5\u5907<\/h3>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>\u6d88\u606f\u961f\u5217<\/strong>\uff1aRabbitMQ\uff08\u5f02\u6b65\u8ba2\u5355\u3001\u652f\u4ed8\u901a\u77e5\u3001\u5e93\u5b58\u6263\u51cf\uff09<\/li>\n\n\n\n<li><strong>\u9650\u6d41\u7194\u65ad<\/strong>\uff1aRate Limiter\uff08\u9632\u5237\u3001\u9632\u722c\u866b\uff09<\/li>\n<\/ul>\n\n\n\n<h3 class=\"wp-block-heading\">5. \u90e8\u7f72 \/ \u8fd0\u7ef4\uff08\u4e91\u539f\u751f\uff09<\/h3>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u5bb9\u5668\uff1a<strong>Docker + Docker Compose<\/strong><\/li>\n\n\n\n<li>\u90e8\u7f72\uff1a<strong>Vercel\/Netlify\uff08\u524d\u7aef\uff09 + \u963f\u91cc\u4e91 \/ \u817e\u8baf\u4e91\uff08\u540e\u7aef\uff09<\/strong><\/li>\n\n\n\n<li>\u76d1\u63a7\uff1a<strong>Prometheus + Grafana<\/strong><\/li>\n<\/ul>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity\"\/>\n\n\n\n<h2 class=\"wp-block-heading\">\u4e09\u3001\u6838\u5fc3\u6a21\u5757\u89c4\u5212\uff08\u542b\u5b8c\u6574\u7528\u6237\u7cfb\u7edf\uff09<\/h2>\n\n\n\n<h3 class=\"wp-block-heading\">1. \u7528\u6237\u4e2d\u5fc3\u7cfb\u7edf\uff08\u6838\u5fc3\uff09<\/h3>\n\n\n\n<p><strong>\u529f\u80fd\uff1a<\/strong><\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u6ce8\u518c \/ \u767b\u5f55 \/ \u767b\u51fa \/ \u627e\u56de\u5bc6\u7801<\/li>\n\n\n\n<li>\u7b2c\u4e09\u65b9\u767b\u5f55\uff08\u5fae\u4fe1\u3001\u652f\u4ed8\u5b9d\u3001Apple\uff09<\/li>\n\n\n\n<li>\u7528\u6237\u4fe1\u606f\u3001\u5934\u50cf\u3001\u6536\u8d27\u5730\u5740\u7ba1\u7406<\/li>\n\n\n\n<li>RBAC \u6743\u9650\uff08\u666e\u901a\u7528\u6237 \/ \u7ba1\u7406\u5458 \/ \u5546\u5bb6\uff09<\/li>\n\n\n\n<li>\u5b89\u5168\uff1a\u767b\u5f55\u65e5\u5fd7\u3001\u8bbe\u5907\u7ba1\u7406\u3001\u4fee\u6539\u5bc6\u7801\u3001\u8d26\u53f7\u9501\u5b9a<\/li>\n<\/ul>\n\n\n\n<p><strong>\u6280\u672f\u5b9e\u73b0\uff1a<\/strong><\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>JWT \u53cc\u4ee4\u724c\uff08Access Token + Refresh Token\uff09<\/li>\n\n\n\n<li>\u5bc6\u7801\u52a0\u5bc6\uff1abcrypt<\/li>\n\n\n\n<li>\u9632\u66b4\u529b\u7834\u89e3\uff1a5 \u6b21\u5931\u8d25\u9501\u5b9a + \u9a8c\u8bc1\u7801<\/li>\n\n\n\n<li>\u4f1a\u8bdd\u5b58\u50a8\uff1aRedis<\/li>\n<\/ul>\n\n\n\n<h3 class=\"wp-block-heading\">2. \u5546\u54c1\u6a21\u5757<\/h3>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u5546\u54c1\u5206\u7c7b\u3001\u54c1\u724c\u3001\u89c4\u683c\uff08\u989c\u8272 \/ \u5c3a\u5bf8\uff09<\/li>\n\n\n\n<li>\u5546\u54c1\u8be6\u60c5\u3001SKU \u5e93\u5b58<\/li>\n\n\n\n<li>\u5546\u54c1\u641c\u7d22\uff08ES \u652f\u6301\uff09<\/li>\n\n\n\n<li>\u5546\u54c1\u6536\u85cf\u3001\u6d4f\u89c8\u5386\u53f2<\/li>\n<\/ul>\n\n\n\n<h3 class=\"wp-block-heading\">3. \u8d2d\u7269\u8f66\u6a21\u5757<\/h3>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u767b\u5f55 \/ \u672a\u767b\u5f55\u72b6\u6001\u540c\u6b65<\/li>\n\n\n\n<li>\u5546\u54c1\u589e\u51cf\u3001\u9009\u4e2d\u72b6\u6001\u3001\u4ef7\u683c\u8ba1\u7b97<\/li>\n\n\n\n<li>\u5b58\u50a8\uff1aRedis\uff08\u9ad8\u6027\u80fd\uff09<\/li>\n<\/ul>\n\n\n\n<h3 class=\"wp-block-heading\">4. \u8ba2\u5355\u6a21\u5757<\/h3>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u8d2d\u7269\u8f66\u7ed3\u7b97<\/li>\n\n\n\n<li>\u8ba2\u5355\u521b\u5efa\u3001\u53d6\u6d88\u3001\u8d85\u65f6\u81ea\u52a8\u5173\u95ed<\/li>\n\n\n\n<li>\u8ba2\u5355\u72b6\u6001\u6d41\u8f6c\uff08\u5f85\u652f\u4ed8\u2192\u5df2\u652f\u4ed8\u2192\u53d1\u8d27\u2192\u5b8c\u6210\u2192\u552e\u540e\uff09<\/li>\n<\/ul>\n\n\n\n<h3 class=\"wp-block-heading\">5. \u652f\u4ed8\u6a21\u5757<\/h3>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u5bf9\u63a5\u652f\u4ed8\u5b9d \/ \u5fae\u4fe1\u652f\u4ed8<\/li>\n\n\n\n<li>\u652f\u4ed8\u7ed3\u679c\u5f02\u6b65\u901a\u77e5<\/li>\n\n\n\n<li>\u9000\u6b3e\u6d41\u7a0b<\/li>\n<\/ul>\n\n\n\n<h3 class=\"wp-block-heading\">6. \u540e\u53f0\u7ba1\u7406\u7cfb\u7edf<\/h3>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u5546\u54c1\u7ba1\u7406<\/li>\n\n\n\n<li>\u8ba2\u5355\u7ba1\u7406<\/li>\n\n\n\n<li>\u7528\u6237\u7ba1\u7406<\/li>\n\n\n\n<li>\u6743\u9650\u7ba1\u7406<\/li>\n\n\n\n<li>\u6570\u636e\u7edf\u8ba1\uff08\u9500\u552e\u989d\u3001\u8ba2\u5355\u91cf\u3001\u7528\u6237\u91cf\uff09<\/li>\n<\/ul>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity\"\/>\n\n\n\n<h2 class=\"wp-block-heading\">\u56db\u3001\u4e3a\u4ec0\u4e48\u8fd9\u5957\u6280\u672f\u6808\u6700\u9002\u5408\u7535\u5546\uff1f<\/h2>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>React 19 + NestJS<\/strong>\uff1a\u524d\u540e\u7aef\u7edf\u4e00\u4f7f\u7528 TypeScript\uff0c\u4e00\u5957\u8bed\u6cd5\u5168\u6808\u5f00\u53d1\uff0c\u6548\u7387\u6781\u9ad8<\/li>\n\n\n\n<li><strong>PostgreSQL<\/strong>\uff1a\u6bd4 MySQL \u66f4\u9002\u5408\u590d\u6742\u8ba2\u5355\u3001\u4e8b\u52a1\u3001\u5173\u8054\u67e5\u8be2<\/li>\n\n\n\n<li><strong>Redis<\/strong>\uff1a\u89e3\u51b3\u7535\u5546\u6700\u75db\u7684\u9ad8\u5e76\u53d1\u3001\u79d2\u6740\u3001\u7f13\u5b58\u95ee\u9898<\/li>\n\n\n\n<li><strong>Elasticsearch<\/strong>\uff1a\u5546\u54c1\u641c\u7d22\u5fc5\u7528\uff0c\u652f\u6301\u6a21\u7cca\u3001\u5206\u8bcd\u3001\u7b5b\u9009\u3001\u6392\u5e8f<\/li>\n\n\n\n<li><strong>\u5b89\u5168\u6210\u719f<\/strong>\uff1aJWT + RBAC + \u9650\u6d41 + \u52a0\u5bc6\uff0c\u6ee1\u8db3\u4f01\u4e1a\u7ea7\u5b89\u5168\u8981\u6c42<\/li>\n\n\n\n<li><strong>\u53ef\u6269\u5c55<\/strong>\uff1a\u5c0f\u9879\u76ee\u53ef\u5355\u4f53\u8fd0\u884c\uff0c\u5927\u6d41\u91cf\u53ef\u62c6\u5fae\u670d\u52a1<\/li>\n<\/ol>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity\"\/>\n\n\n\n<h2 class=\"wp-block-heading\">\u4e94\u3001\u9879\u76ee\u5f00\u53d1\u8def\u7ebf\uff08\u53ef\u76f4\u63a5\u7167\u505a\uff09<\/h2>\n\n\n\n<ol class=\"wp-block-list\">\n<li>\u642d\u5efa\u9879\u76ee\u9aa8\u67b6\uff08\u524d\u7aef Vite+React\uff0c\u540e\u7aef NestJS\uff09<\/li>\n\n\n\n<li>\u5f00\u53d1<strong>\u7528\u6237\u7cfb\u7edf<\/strong>\uff08\u6ce8\u518c\u3001\u767b\u5f55\u3001\u6743\u9650\u3001Redis\uff09<\/li>\n\n\n\n<li>\u5f00\u53d1\u5546\u54c1\u6a21\u5757 + \u641c\u7d22<\/li>\n\n\n\n<li>\u8d2d\u7269\u8f66 + \u8ba2\u5355 + \u652f\u4ed8<\/li>\n\n\n\n<li>\u540e\u53f0\u7ba1\u7406<\/li>\n\n\n\n<li>\u90e8\u7f72\u4e0a\u7ebf + \u76d1\u63a7<\/li>\n<\/ol>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity\"\/>\n\n\n\n<h2 class=\"wp-block-heading\">\u516d\u3001\u53ef\u76f4\u63a5\u843d\u5730\u7684\u67b6\u6784\u56fe\uff08\u6587\u5b57\u7248\uff09<\/h2>\n\n\n\n<p>plaintext<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>\u7528\u6237\u6d4f\u89c8\u5668\n    \u2193\n\u524d\u7aef (React19 + Tailwind)\n    \u2193\nNginx \u53cd\u5411\u4ee3\u7406 \/ \u8d1f\u8f7d\u5747\u8861\n    \u2193\n\u540e\u7aef\u670d\u52a1 (NestJS)\n \u251c\u2500\u2500 \u7528\u6237\u670d\u52a1\n \u251c\u2500\u2500 \u5546\u54c1\u670d\u52a1\n \u251c\u2500\u2500 \u8d2d\u7269\u8f66\u670d\u52a1\n \u251c\u2500\u2500 \u8ba2\u5355\u670d\u52a1\n \u2514\u2500\u2500 \u652f\u4ed8\u670d\u52a1\n    \u2193\n\u6570\u636e\u5c42\n \u251c\u2500\u2500 PostgreSQL\uff08\u8ba2\u5355\/\u7528\u6237\uff09\n \u251c\u2500\u2500 Redis\uff08\u7f13\u5b58\/\u8d2d\u7269\u8f66\/\u767b\u5f55\uff09\n \u2514\u2500\u2500 Elasticsearch\uff08\u5546\u54c1\u641c\u7d22\uff09\n<\/code><\/pre>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity\"\/>\n\n\n\n<h3 class=\"wp-block-heading\">\u603b\u7ed3<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li>\u8fd9\u662f<strong>2026 \u6700\u4e3b\u6d41\u3001\u6700\u65b0\u3001\u6700\u7a33<\/strong>\u7684\u7535\u5546\u6280\u672f\u6808<\/li>\n\n\n\n<li>\u5305\u542b<strong>\u5b8c\u6574\u5b89\u5168\u7684\u7528\u6237\u7cfb\u7edf<\/strong>\uff08\u767b\u5f55\u3001\u6743\u9650\u3001\u7b2c\u4e09\u65b9\u767b\u5f55\u3001\u5b89\u5168\u9632\u62a4\uff09<\/li>\n\n\n\n<li>\u652f\u6301<strong>\u9ad8\u5e76\u53d1\u3001\u79d2\u6740\u3001\u5927\u89c4\u6a21\u5546\u54c1\u3001\u652f\u4ed8\u95ed\u73af<\/strong><\/li>\n\n\n\n<li>\u524d\u540e\u7aef TS \u7edf\u4e00\uff0c\u5f00\u53d1\u6548\u7387\u9ad8\u3001\u7ef4\u62a4\u6210\u672c\u4f4e<\/li>\n\n\n\n<li>\u53ef\u4ece\u5c0f\u9879\u76ee\u8d77\u6b65\uff0c\u65e0\u7f1d\u6269\u5c55\u5230\u5927\u578b\u7535\u5546\u5e73\u53f0<\/li>\n<\/ol>\n\n\n\n<p>\u5982\u679c\u4f60\u9700\u8981\uff0c\u6211\u53ef\u4ee5\u7ee7\u7eed\u63d0\u4f9b\uff1a<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u5b8c\u6574\u6570\u636e\u5e93\u8868\u7ed3\u6784\u8bbe\u8ba1<\/li>\n\n\n\n<li>\u63a5\u53e3 API \u6587\u6863<\/li>\n\n\n\n<li>\u524d\u7aef\u8def\u7531 \/ \u9875\u9762\u89c4\u5212<\/li>\n\n\n\n<li>\u4e00\u952e\u542f\u52a8\u7684\u9879\u76ee\u6a21\u677f\uff08Docker \u4e00\u952e\u8dd1\uff09<\/li>\n<\/ul>\n\n\n\n<h1 class=\"wp-block-heading\">\u8c03\u6574\u4e3a\uff1aReact 19 + Next.js 15\uff08App Router\uff09\u7535\u5546\u524d\u53f0<\/h1>\n\n\n\n<p>\u8fd9\u662f <strong>2026 \u6700\u65b0\u3001\u6700\u9002\u5408\u7535\u5546<\/strong> \u7684\u524d\u7aef\u76ee\u5f55\uff0c\u670d\u52a1\u7aef\u6e32\u67d3\uff08SSR\uff09\u5bf9\u5546\u54c1 SEO\u3001\u52a0\u8f7d\u901f\u5ea6\u8d85\u7ea7\u53cb\u597d\uff0c\u76f4\u63a5\u7167\u7740\u5efa\u6587\u4ef6\u5939\u5373\u53ef\u3002<\/p>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity\"\/>\n\n\n\n<h2 class=\"wp-block-heading\">\u5b8c\u6574 Next.js \u524d\u7aef\u9879\u76ee\u76ee\u5f55\uff08\u5546\u57ce\u7528\u6237\u7aef + \u7528\u6237\u7cfb\u7edf\uff09<\/h2>\n\n\n\n<p>plaintext<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>mall-web\/\n\u251c\u2500\u2500 public\/                 # \u9759\u6001\u8d44\u6e90\uff08\u56fe\u7247\u3001logo\u3001favicon\uff09\n\u251c\u2500\u2500 app\/                   # Next.js 15 App Router \u6838\u5fc3\u76ee\u5f55\n\u2502   \u251c\u2500\u2500 api\/               # \u524d\u7aef\u8c03\u7528\u540e\u7aef\u63a5\u53e3\u5c01\u88c5\n\u2502   \u2502   \u251c\u2500\u2500 auth\/          # \u7528\u6237\u767b\u5f55\u3001\u6ce8\u518c\u3001\u9000\u51fa\n\u2502   \u2502   \u251c\u2500\u2500 user\/          # \u7528\u6237\u4fe1\u606f\u3001\u6536\u8d27\u5730\u5740\n\u2502   \u2502   \u251c\u2500\u2500 goods\/         # \u5546\u54c1\u5217\u8868\u3001\u8be6\u60c5\u3001\u641c\u7d22\n\u2502   \u2502   \u251c\u2500\u2500 cart\/          # \u8d2d\u7269\u8f66\n\u2502   \u2502   \u2514\u2500\u2500 order\/         # \u8ba2\u5355\u3001\u652f\u4ed8\n\u2502   \u251c\u2500\u2500 (auth)\/            # \u8def\u7531\u7ec4\uff1a\u7528\u6237\u76f8\u5173\u9875\u9762\uff08\u4e0d\u663e\u793alayout\uff09\n\u2502   \u2502   \u251c\u2500\u2500 login\/         # \u767b\u5f55\u9875\n\u2502   \u2502   \u2514\u2500\u2500 register\/      # \u6ce8\u518c\u9875\n\u2502   \u251c\u2500\u2500 (shop)\/            # \u8def\u7531\u7ec4\uff1a\u5546\u57ce\u9875\u9762\uff08\u5171\u7528\u5546\u57ce\u5bfc\u822a\uff09\n\u2502   \u2502   \u251c\u2500\u2500 layout.js      # \u5546\u57ce\u901a\u7528\u5e03\u5c40\uff08Header\/Footer\uff09\n\u2502   \u2502   \u251c\u2500\u2500 page.js        # \u5546\u57ce\u9996\u9875\n\u2502   \u2502   \u251c\u2500\u2500 goods\/         # \u5546\u54c1\u5217\u8868\u3001\u8be6\u60c5\u9875\n\u2502   \u2502   \u251c\u2500\u2500 cart\/          # \u8d2d\u7269\u8f66\u9875\u9762\n\u2502   \u2502   \u2514\u2500\u2500 checkout\/      # \u7ed3\u7b97\u4e0b\u5355\u9875\n\u2502   \u251c\u2500\u2500 user\/              # \u7528\u6237\u4e2d\u5fc3\n\u2502   \u2502   \u251c\u2500\u2500 page.js        # \u4e2a\u4eba\u4e2d\u5fc3\u9996\u9875\n\u2502   \u2502   \u251c\u2500\u2500 profile\/       # \u4e2a\u4eba\u4fe1\u606f\u4fee\u6539\n\u2502   \u2502   \u251c\u2500\u2500 address\/       # \u6536\u8d27\u5730\u5740\u7ba1\u7406\n\u2502   \u2502   \u2514\u2500\u2500 orders\/        # \u6211\u7684\u8ba2\u5355\n\u2502   \u251c\u2500\u2500 layout.js          # \u6839\u5e03\u5c40\uff08\u5168\u5c40\u6837\u5f0f\u3001Provider\uff09\n\u2502   \u2514\u2500\u2500 page.js            # \u5165\u53e3\u91cd\u5b9a\u5411\/\u9996\u9875\n\u251c\u2500\u2500 components\/            # \u516c\u5171\u7ec4\u4ef6\n\u2502   \u251c\u2500\u2500 ui\/                \/\/ shadcn\/ui \u57fa\u7840\u7ec4\u4ef6\n\u2502   \u251c\u2500\u2500 layout\/            # \u5e03\u5c40\u7ec4\u4ef6\n\u2502   \u2502   \u251c\u2500\u2500 Header.jsx     # \u9876\u90e8\u5bfc\u822a\uff08\u542b\u7528\u6237\u767b\u5f55\u72b6\u6001\uff09\n\u2502   \u2502   \u251c\u2500\u2500 Footer.jsx    # \u5e95\u90e8\n\u2502   \u2502   \u2514\u2500\u2500 UserMenu.jsx   # \u7528\u6237\u53f3\u4e0a\u89d2\u83dc\u5355\n\u2502   \u251c\u2500\u2500 auth\/              # \u767b\u5f55\u3001\u6ce8\u518c\u8868\u5355\u7ec4\u4ef6\n\u2502   \u251c\u2500\u2500 goods\/             # \u5546\u54c1\u5361\u7247\u3001\u5546\u54c1\u89c4\u683c\u3001\u641c\u7d22\u6846\n\u2502   \u251c\u2500\u2500 cart\/              # \u8d2d\u7269\u8f66\u5546\u54c1\u9879\n\u2502   \u2514\u2500\u2500 order\/             # \u8ba2\u5355\u72b6\u6001\u3001\u8ba2\u5355\u5361\u7247\n\u251c\u2500\u2500 lib\/                   # \u5de5\u5177 &amp; \u914d\u7f6e\n\u2502   \u251c\u2500\u2500 axios.js           # \u8bf7\u6c42\u5c01\u88c5\u3001token \u81ea\u52a8\u643a\u5e26\n\u2502   \u251c\u2500\u2500 auth.js            # \u767b\u5f55\u6001\u7ba1\u7406\uff08Cookie\/Tokens\uff09\n\u2502   \u2514\u2500\u2500 utils.js           # \u901a\u7528\u5de5\u5177\u51fd\u6570\n\u251c\u2500\u2500 stores\/                # \u5168\u5c40\u72b6\u6001\n\u2502   \u251c\u2500\u2500 user-store.js      # \u7528\u6237\u4fe1\u606f\u3001\u767b\u5f55\u72b6\u6001\n\u2502   \u2514\u2500\u2500 cart-store.js      # \u8d2d\u7269\u8f66\u72b6\u6001\n\u251c\u2500\u2500 styles\/                # \u5168\u5c40\u6837\u5f0f\n\u251c\u2500\u2500 .env.local             # \u73af\u5883\u53d8\u91cf\uff08\u540e\u7aef\u63a5\u53e3\u5730\u5740\uff09\n\u251c\u2500\u2500 next.config.js         # Next \u914d\u7f6e\n\u2514\u2500\u2500 package.json\n<\/code><\/pre>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity\"\/>\n\n\n\n<h2 class=\"wp-block-heading\">\u76ee\u5f55\u4eae\u70b9\uff08\u7535\u5546 + \u7528\u6237\u7cfb\u7edf\u4e13\u7528\uff09<\/h2>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>Next.js 15 App Router<\/strong>\uff1a\u6700\u65b0\u8def\u7531\u65b9\u6848\uff0c\u652f\u6301 SSR \u6e32\u67d3\u5546\u54c1\uff0cSEO \u62c9\u6ee1<\/li>\n\n\n\n<li><strong>\u8def\u7531\u5206\u7ec4 (auth) \/ (shop)<\/strong>\uff1a\u767b\u5f55\u9875\u548c\u5546\u57ce\u9875\u5206\u5f00\u5e03\u5c40\uff0c\u66f4\u6e05\u723d<\/li>\n\n\n\n<li><strong>\u7528\u6237\u4e2d\u5fc3\u72ec\u7acb\u8def\u7531<\/strong>\uff1a\u4e2a\u4eba\u4fe1\u606f\u3001\u5730\u5740\u3001\u8ba2\u5355\u5168\u90e8\u5230\u4f4d<\/li>\n\n\n\n<li><strong>\u8bf7\u6c42\u5c01\u88c5\u81ea\u5e26 Token<\/strong>\uff1a\u767b\u5f55\u540e\u81ea\u52a8\u643a\u5e26 JWT\uff0c\u9274\u6743\u7b80\u5355<\/li>\n\n\n\n<li><strong>\u72b6\u6001\u7ba1\u7406\u8f7b\u91cf\u5316<\/strong>\uff1aZustand\uff0c\u6bd4 Redux \u7b80\u5355 10 \u500d<\/li>\n\n\n\n<li><strong>shadcn\/ui + Tailwind<\/strong>\uff1a\u76f4\u63a5\u7528\u9ad8\u8d28\u91cf UI \u7ec4\u4ef6<\/li>\n<\/ol>\n\n\n\n<p><\/p>\n\n\n\n<p><\/p>\n\n\n\n<p><\/p>\n\n\n\n<p><\/p>\n\n\n\n<p><\/p>\n\n\n\n<p>\u57fa\u4e8e\u4f60\u9009\u5b9a\u7684&nbsp;<strong>Node.js + PostgreSQL + Redis<\/strong>&nbsp;\u8fd9\u4e00\u7ecf\u5178\u4e14\u5f3a\u5927\u7684\u7ec4\u5408\uff0c\u5728 2026 \u5e74\u7684\u6280\u672f\u80cc\u666f\u4e0b\uff0c\u6211\u5f3a\u70c8\u63a8\u8350\u4f60\u653e\u5f03 Express\uff0c\u76f4\u63a5\u9009\u62e9&nbsp;<strong>NestJS<\/strong>&nbsp;\u4f5c\u4e3a\u540e\u7aef\u6846\u67b6\u3002<\/p>\n\n\n\n<p>\u7ed3\u5408\u4f60\u4e4b\u524d\u7684\u7535\u5546\u89c4\u5212\uff08\u5fae\u670d\u52a1\u3001\u9ad8\u5e76\u53d1\u3001Stripe \u652f\u4ed8\uff09\uff0cNestJS \u7684\u67b6\u6784\u4f18\u52bf\u80fd\u5b8c\u7f8e\u652f\u6491\u8fd9\u4e9b\u9700\u6c42\u3002<\/p>\n\n\n\n<p>\u4ee5\u4e0b\u662f\u9488\u5bf9\u8be5\u6808\u7684\u8be6\u7ec6\u6280\u672f\u9009\u578b\u4e0e\u67b6\u6784\u63a8\u8350\uff1a<\/p>\n\n\n\n<h3 class=\"wp-block-heading\"><strong>\ud83c\udfc6 \u6838\u5fc3\u6846\u67b6\u9009\u578b\uff1aNestJS (\u5fc5\u9009)<\/strong><\/h3>\n\n\n\n<p>\u867d\u7136 Express \u5f88\u6d41\u884c\uff0c\u4f46\u5728 2026 \u5e74\u6784\u5efa\u4f01\u4e1a\u7ea7\u7535\u5546\u7cfb\u7edf\u65f6\uff0cNestJS \u662f\u66f4\u660e\u667a\u7684\u9009\u62e9\u3002<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>\u67b6\u6784\u7ea6\u675f\u4e0e\u89c4\u8303\uff1a<\/strong>\u00a0NestJS \u5f3a\u5236\u4f7f\u7528\u6a21\u5757\u5316\u67b6\u6784\uff08Modules, Controllers, Providers\uff09\uff0c\u8fd9\u5bf9\u4e8e\u591a\u4eba\u534f\u4f5c\u7684\u5927\u578b\u7535\u5546\u9879\u76ee\u81f3\u5173\u91cd\u8981\u3002\u5b83\u80fd\u9632\u6b62\u4ee3\u7801\u53d8\u6210\u201c\u610f\u5927\u5229\u9762\u6761\u5f0f\u201d\u7ed3\u6784\u3002<\/li>\n\n\n\n<li><strong>TypeScript \u539f\u751f\u652f\u6301\uff1a<\/strong>\u00a02026 \u5e74\u7684\u540e\u7aef\u5f00\u53d1\u51e0\u4e4e\u9ed8\u8ba4\u662f TypeScript\u3002NestJS \u5bf9 TS \u7684\u652f\u6301\u662f\u539f\u751f\u7684\uff0c\u80fd\u63d0\u4f9b\u6781\u4f73\u7684\u7c7b\u578b\u63d0\u793a\u548c\u91cd\u6784\u4f53\u9a8c\u3002<\/li>\n\n\n\n<li><strong>\u5fae\u670d\u52a1\u6f14\u8fdb\uff1a<\/strong>\u00a0\u4f60\u89c4\u5212\u4e86\u5fae\u670d\u52a1\u67b6\u6784\u3002NestJS \u5185\u7f6e\u4e86\u5fae\u670d\u52a1\u4f20\u8f93\u5c42\uff08\u652f\u6301 TCP, Redis, gRPC, MQTT\uff09\uff0c\u4f60\u53ef\u4ee5\u8f7b\u677e\u5730\u5c06\u5355\u4f53\u5e94\u7528\u62c6\u5206\u4e3a\u201c\u5546\u54c1\u670d\u52a1\u201d\u3001\u201c\u8ba2\u5355\u670d\u52a1\u201d\u7b49\uff0c\u800c\u65e0\u9700\u91cd\u5199\u4ee3\u7801\u903b\u8f91\u3002<\/li>\n\n\n\n<li><strong>\u751f\u6001\u6574\u5408\uff1a<\/strong>\u00a0\u5bf9 TypeORM\/Prisma\u3001Passport\uff08\u8ba4\u8bc1\uff09\u3001Swagger\uff08\u6587\u6863\uff09\u7684\u96c6\u6210\u90fd\u6709\u5b98\u65b9\u7ef4\u62a4\u7684\u6a21\u5757\uff0c\u5f00\u7bb1\u5373\u7528\u3002<\/li>\n<\/ul>\n\n\n\n<h3 class=\"wp-block-heading\"><strong>\ud83d\uddc4\ufe0f \u6570\u636e\u5e93\u5c42\uff1aPostgreSQL + Prisma ORM<\/strong><\/h3>\n\n\n\n<p>PostgreSQL \u662f\u5904\u7406\u590d\u6742\u7535\u5546\u4e8b\u52a1\uff08\u8ba2\u5355\u3001\u5e93\u5b58\uff09\u7684\u6700\u4f73\u5173\u7cfb\u578b\u6570\u636e\u5e93\u3002\u5728 ORM\uff08\u5bf9\u8c61\u5173\u7cfb\u6620\u5c04\uff09\u7684\u9009\u62e9\u4e0a\uff0c\u63a8\u8350&nbsp;<strong>Prisma<\/strong>\u3002<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>\u7c7b\u578b\u5b89\u5168\uff1a<\/strong>\u00a0Prisma \u80fd\u6839\u636e\u4f60\u7684\u6570\u636e\u5e93 Schema \u81ea\u52a8\u751f\u6210 TypeScript \u7c7b\u578b\u3002\u8fd9\u610f\u5473\u7740\u4f60\u5728\u5199\u00a0<code>prisma.user.findUnique()<\/code>\u00a0\u65f6\uff0cIDE \u5c31\u80fd\u7ed9\u51fa\u5b8c\u6574\u7684\u7c7b\u578b\u63d0\u793a\uff0c\u6781\u5927\u51cf\u5c11\u8fd0\u884c\u65f6\u9519\u8bef\u3002<\/li>\n\n\n\n<li><strong>\u5f00\u53d1\u4f53\u9a8c\uff1a<\/strong>\u00a0\u5b83\u7684\u8fc1\u79fb\u5de5\u5177\uff08Migration\uff09\u548c\u53ef\u89c6\u5316\u6570\u636e\u6d4f\u89c8\u5668\uff08Prisma Studio\uff09\u975e\u5e38\u73b0\u4ee3\u5316\uff0c\u6bd4\u4f20\u7edf\u7684 TypeORM \u6216 Sequelize \u66f4\u76f4\u89c2\u3002<\/li>\n\n\n\n<li><strong>\u6027\u80fd\uff1a<\/strong>\u00a0\u867d\u7136 TypeORM \u4e5f\u5f88\u6d41\u884c\uff0c\u4f46 Prisma \u5728\u67e5\u8be2\u4f18\u5316\u548c\u8fde\u63a5\u6c60\u7ba1\u7406\u4e0a\u8868\u73b0\u66f4\u4f73\uff0c\u7279\u522b\u662f\u5728\u9ad8\u5e76\u53d1\u7684\u7535\u5546\u573a\u666f\u4e0b\u3002<\/li>\n<\/ul>\n\n\n\n<h3 class=\"wp-block-heading\"><strong>\u26a1 \u7f13\u5b58\u4e0e\u4e2d\u95f4\u4ef6\uff1aRedis (\u4e0d\u4ec5\u4ec5\u662f\u4f1a\u8bdd)<\/strong><\/h3>\n\n\n\n<p>\u4f60\u63d0\u5230\u4e86\u7528 Redis \u505a\u201c\u7528\u6237\u4f1a\u8bdd\u201d\uff0c\u8fd9\u5f88\u597d\uff0c\u4f46\u5728 2026 \u5e74\uff0cRedis \u5e94\u8be5\u627f\u62c5\u66f4\u591a\u89d2\u8272\uff1a<\/p>\n\n\n\n<ol start=\"1\" class=\"wp-block-list\">\n<li><strong>\u4f1a\u8bdd\u5b58\u50a8\uff1a<\/strong>\u00a0\u914d\u5408\u00a0<code>connect-redis<\/code>\u00a0\u6216 NestJS \u7684 Session \u6a21\u5757\uff0c\u5b58\u50a8\u7528\u6237\u7684 JWT \u9ed1\u540d\u5355\u6216 Session ID\u3002<\/li>\n\n\n\n<li><strong>\u9ad8\u9891\u6570\u636e\u7f13\u5b58\uff1a<\/strong>\u00a0\u7535\u5546\u9996\u9875\u7684\u201c\u70ed\u95e8\u5546\u54c1\u201d\u3001\u201c\u5206\u7c7b\u5217\u8868\u201d\u8bfb\u53d6\u9891\u7387\u6781\u9ad8\uff0c\u5e94\u7f13\u5b58\u5230 Redis\uff0c\u8bbe\u7f6e\u77ed TTL\uff08\u5982 5 \u5206\u949f\uff09\uff0c\u51cf\u8f7b PG \u538b\u529b\u3002<\/li>\n\n\n\n<li><strong>\u5206\u5e03\u5f0f\u9501\uff1a<\/strong>\u00a0\u5728\u201c\u79d2\u6740\u201d\u6216\u201c\u5e93\u5b58\u6263\u51cf\u201d\u573a\u666f\u4e0b\uff0c\u5229\u7528 Redis \u7684\u539f\u5b50\u6027\u5b9e\u73b0\u5206\u5e03\u5f0f\u9501\uff0c\u9632\u6b62\u8d85\u5356\u3002<\/li>\n\n\n\n<li><strong>\u6d88\u606f\u961f\u5217\uff1a<\/strong>\u00a0\u7b80\u5355\u7684\u5f02\u6b65\u4efb\u52a1\uff08\u5982\u53d1\u9001\u6ce8\u518c\u90ae\u4ef6\u3001\u751f\u6210\u8ba2\u5355\u62a5\u8868\uff09\u53ef\u4ee5\u4f7f\u7528\u00a0<code>BullMQ<\/code>\uff08\u57fa\u4e8e Redis\uff09\u6765\u5904\u7406\u3002<\/li>\n<\/ol>\n\n\n\n<h3 class=\"wp-block-heading\"><strong>\ud83d\udee1\ufe0f \u8ba4\u8bc1\u4e0e\u5b89\u5168\uff1aPassport + JWT + Redis<\/strong><\/h3>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>\u7b56\u7565\u6a21\u5f0f\uff1a<\/strong>\u00a0\u4f7f\u7528\u00a0<code>@nestjs\/passport<\/code>\u00a0\u5b9e\u73b0\u7075\u6d3b\u7684\u8ba4\u8bc1\u7b56\u7565\uff08JWT\u3001Local\u3001Google OAuth \u7b49\uff09\u3002<\/li>\n\n\n\n<li><strong>\u6df7\u5408\u6a21\u5f0f\uff1a<\/strong>\n<ul class=\"wp-block-list\">\n<li><strong>Access Token (JWT)\uff1a<\/strong>\u00a0\u5b58\u50a8\u5728\u5ba2\u6237\u7aef\uff08HttpOnly Cookie\uff09\uff0c\u7528\u4e8e\u77ed\u671f\u9a8c\u8bc1\u3002<\/li>\n\n\n\n<li><strong>Refresh Token\uff1a<\/strong>\u00a0\u5b58\u50a8\u5728 Redis \u4e2d\uff0c\u7528\u4e8e\u5237\u65b0 Access Token\u3002\u8fd9\u6837\u53ef\u4ee5\u5728\u7528\u6237\u767b\u51fa\u6216\u4fee\u6539\u5bc6\u7801\u65f6\uff0c\u7acb\u5373\u5728 Redis \u4e2d\u5220\u9664 Token\uff0c\u5b9e\u73b0\u5373\u65f6\u5931\u6548\uff0c\u6bd4\u7eaf JWT \u66f4\u5b89\u5168\u3002<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n\n\n\n<h3 class=\"wp-block-heading\"><strong>\ud83d\udce6 \u63a8\u8350\u7684\u5b8c\u6574\u6280\u672f\u6808\u6e05\u5355<\/strong><\/h3>\n\n\n\n<p>\u8868\u683c<\/p>\n\n\n\n<figure class=\"wp-block-table\"><table class=\"has-fixed-layout\"><thead><tr><th class=\"has-text-align-left\" data-align=\"left\">\u6a21\u5757<\/th><th class=\"has-text-align-left\" data-align=\"left\">\u63a8\u8350\u6280\u672f<\/th><th class=\"has-text-align-left\" data-align=\"left\">\u7406\u7531<\/th><\/tr><\/thead><tbody><tr><td><strong>\u6846\u67b6<\/strong><\/td><td><strong>NestJS<\/strong><\/td><td>\u7ed3\u6784\u5316\u3001\u53ef\u6269\u5c55\u3001\u5fae\u670d\u52a1\u5c31\u7eea\u3002<\/td><\/tr><tr><td><strong>\u8bed\u8a00<\/strong><\/td><td><strong>TypeScript<\/strong><\/td><td>2026 \u5e74\u6807\u51c6\uff0c\u5168\u6808\u7c7b\u578b\u5b89\u5168\u3002<\/td><\/tr><tr><td><strong>\u6570\u636e\u5e93<\/strong><\/td><td><strong>PostgreSQL 16+<\/strong><\/td><td>\u7a33\u5b9a\u3001ACID \u517c\u5bb9\u3001\u5904\u7406\u590d\u6742\u67e5\u8be2\u80fd\u529b\u5f3a\u3002<\/td><\/tr><tr><td><strong>ORM<\/strong><\/td><td><strong>Prisma<\/strong><\/td><td>\u7c7b\u578b\u5b89\u5168\u3001\u81ea\u52a8\u8fc1\u79fb\u3001\u5f00\u53d1\u4f53\u9a8c\u6781\u4f73\u3002<\/td><\/tr><tr><td><strong>\u7f13\u5b58\/\u961f\u5217<\/strong><\/td><td><strong>Redis 7+<\/strong><\/td><td>\u4f1a\u8bdd\u3001\u7f13\u5b58\u3001\u5206\u5e03\u5f0f\u9501\u3001\u6d88\u606f\u961f\u5217\u3002<\/td><\/tr><tr><td><strong>\u9a8c\u8bc1<\/strong><\/td><td><strong>class-validator<\/strong><\/td><td>NestJS \u5185\u7f6e\uff0c\u57fa\u4e8e\u88c5\u9970\u5668\u7684 DTO \u9a8c\u8bc1\u3002<\/td><\/tr><tr><td><strong>\u6587\u6863<\/strong><\/td><td><strong>Swagger (OpenAPI)<\/strong><\/td><td><code>@nestjs\/swagger<\/code>&nbsp;\u81ea\u52a8\u751f\u6210 API \u6587\u6863\u3002<\/td><\/tr><tr><td><strong>\u65e5\u5fd7<\/strong><\/td><td><strong>Pino<\/strong><\/td><td>\u9ad8\u6027\u80fd JSON \u65e5\u5fd7\u5e93\uff0c\u9002\u5408\u5fae\u670d\u52a1\u76d1\u63a7\u3002<\/td><\/tr><tr><td><strong>\u6d4b\u8bd5<\/strong><\/td><td><strong>Jest + Supertest<\/strong><\/td><td>\u5b98\u65b9\u63a8\u8350\uff0c\u652f\u6301\u5355\u5143\u6d4b\u8bd5\u548c E2E \u6d4b\u8bd5\u3002<\/td><\/tr><\/tbody><\/table><\/figure>\n\n\n\n<h3 class=\"wp-block-heading\"><strong>\ud83d\udcc2 \u63a8\u8350\u7684 NestJS \u9879\u76ee\u76ee\u5f55\u7ed3\u6784<\/strong><\/h3>\n\n\n\n<p>\u8fd9\u662f\u4e00\u4e2a\u6807\u51c6\u7684\u3001\u53ef\u6269\u5c55\u7684\u7535\u5546\u540e\u7aef\u7ed3\u6784\uff1a<\/p>\n\n\n\n<p>plaintext<\/p>\n\n\n\n<p>\u7f16\u8f91<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>ecommerce-backend\/\n\u251c\u2500\u2500 src\/\n\u2502   \u251c\u2500\u2500 common\/             # \u516c\u5171\u6a21\u5757\n\u2502   \u2502   \u251c\u2500\u2500 decorators\/     # \u81ea\u5b9a\u4e49\u88c5\u9970\u5668 (\u5982 @CurrentUser)\n\u2502   \u2502   \u251c\u2500\u2500 filters\/        # \u5f02\u5e38\u8fc7\u6ee4\u5668 (\u5168\u5c40\u9519\u8bef\u5904\u7406)\n\u2502   \u2502   \u251c\u2500\u2500 guards\/         # \u5b88\u536b (\u6743\u9650\u63a7\u5236)\n\u2502   \u2502   \u251c\u2500\u2500 interceptors\/   # \u62e6\u622a\u5668 (\u54cd\u5e94\u683c\u5f0f\u5316)\n\u2502   \u2502   \u2514\u2500\u2500 utils\/          # \u5de5\u5177\u51fd\u6570\n\u2502   \u251c\u2500\u2500 config\/             # \u914d\u7f6e\u6587\u4ef6 (\u6570\u636e\u5e93\u3001Redis\u3001JWT \u914d\u7f6e)\n\u2502   \u2502   \u251c\u2500\u2500 database.config.ts\n\u2502   \u2502   \u2514\u2500\u2500 redis.config.ts\n\u2502   \u251c\u2500\u2500 modules\/            # \u4e1a\u52a1\u6a21\u5757 (\u6838\u5fc3)\n\u2502   \u2502   \u251c\u2500\u2500 auth\/           # \u8ba4\u8bc1\u6a21\u5757 (\u767b\u5f55\u3001\u6ce8\u518c\u3001JWT \u7b56\u7565)\n\u2502   \u2502   \u251c\u2500\u2500 user\/           # \u7528\u6237\u6a21\u5757\n\u2502   \u2502   \u251c\u2500\u2500 product\/        # \u5546\u54c1\u6a21\u5757\n\u2502   \u2502   \u251c\u2500\u2500 order\/          # \u8ba2\u5355\u6a21\u5757 (\u542b\u4e8b\u52a1\u5904\u7406)\n\u2502   \u2502   \u251c\u2500\u2500 cart\/           # \u8d2d\u7269\u8f66\u6a21\u5757\n\u2502   \u2502   \u2514\u2500\u2500 payment\/        # \u652f\u4ed8\u6a21\u5757 (Stripe \u96c6\u6210)\n\u2502   \u251c\u2500\u2500 main.ts             # \u5165\u53e3\u6587\u4ef6\n\u2502   \u2514\u2500\u2500 app.module.ts       # \u6839\u6a21\u5757\n\u251c\u2500\u2500 prisma\/                 # Prisma \u6570\u636e\u5e93\u7ba1\u7406\n\u2502   \u251c\u2500\u2500 schema.prisma       # \u6570\u636e\u5e93\u6a21\u578b\u5b9a\u4e49\n\u2502   \u251c\u2500\u2500 migrations\/         # \u6570\u636e\u5e93\u8fc1\u79fb\u6587\u4ef6\n\u2502   \u2514\u2500\u2500 seed.ts             # \u6570\u636e\u5e93\u79cd\u5b50\u6570\u636e\n\u251c\u2500\u2500 test\/                   # \u6d4b\u8bd5\u6587\u4ef6\n\u251c\u2500\u2500 .env                    # \u73af\u5883\u53d8\u91cf\n\u251c\u2500\u2500 nest-cli.json\n\u251c\u2500\u2500 package.json\n\u2514\u2500\u2500 tsconfig.json<\/code><\/pre>\n\n\n\n<h3 class=\"wp-block-heading\"><strong>\ud83d\ude80 \u5173\u952e\u5b9e\u65bd\u5efa\u8bae<\/strong><\/h3>\n\n\n\n<ol start=\"1\" class=\"wp-block-list\">\n<li><strong>\u4e8b\u52a1\u7ba1\u7406\uff1a<\/strong>\u00a0\u5728\u8ba2\u5355\u6a21\u5757\uff08<code>order<\/code>\uff09\u4e2d\uff0c\u52a1\u5fc5\u4f7f\u7528 Prisma \u7684\u4e8b\u52a1\uff08<code>$transaction<\/code>\uff09\u3002\u4f8b\u5982\uff0c\u521b\u5efa\u8ba2\u5355\u65f6\uff0c\u9700\u8981\u540c\u65f6\uff1a\n<ul class=\"wp-block-list\">\n<li>\u6263\u51cf\u5e93\u5b58\uff08<code>product<\/code>\u00a0\u8868\uff09\u3002<\/li>\n\n\n\n<li>\u521b\u5efa\u8ba2\u5355\u8bb0\u5f55\uff08<code>order<\/code>\u00a0\u8868\uff09\u3002<\/li>\n\n\n\n<li>\u521b\u5efa\u8ba2\u5355\u8be6\u60c5\uff08<code>orderItem<\/code>\u00a0\u8868\uff09\u3002<\/li>\n\n\n\n<li>\u6e05\u7a7a\u8d2d\u7269\u8f66\uff08<code>cart<\/code>\u00a0\u8868\uff09\u3002<br>\u8fd9\u56db\u4e2a\u64cd\u4f5c\u5fc5\u987b\u8981\u4e48\u5168\u6210\u529f\uff0c\u8981\u4e48\u5168\u5931\u8d25\u3002<\/li>\n<\/ul>\n<\/li>\n\n\n\n<li><strong>API \u7248\u672c\u63a7\u5236\uff1a<\/strong>\u00a0\u5728\u8def\u7531\u4e2d\u52a0\u5165\u7248\u672c\u53f7\uff08\u5982\u00a0<code>\/api\/v1\/products<\/code>\uff09\uff0c\u65b9\u4fbf\u672a\u6765\u5347\u7ea7 API \u800c\u4e0d\u7834\u574f\u65e7\u5ba2\u6237\u7aef\u3002<\/li>\n\n\n\n<li><strong>Docker \u5316\uff1a<\/strong>\u00a0\u4f7f\u7528\u00a0<code>docker-compose<\/code>\u00a0\u7f16\u6392 PostgreSQL \u548c Redis \u670d\u52a1\uff0c\u786e\u4fdd\u5f00\u53d1\u73af\u5883\u4e0e\u751f\u4ea7\u73af\u5883\u4e00\u81f4\u3002<\/li>\n<\/ol>\n\n\n\n<p>\u8fd9\u4e2a\u6280\u672f\u6808\u5728 2026 \u5e74\u4f9d\u7136\u662f<strong>\u201c\u9ec4\u91d1\u6807\u51c6\u201d<\/strong>\uff0c\u517c\u987e\u4e86\u5f00\u53d1\u6548\u7387\u3001\u6027\u80fd\u548c\u53ef\u7ef4\u62a4\u6027\uff0c\u975e\u5e38\u9002\u5408\u4f60\u7684\u7535\u5546\u9879\u76ee\u3002<\/p>\n\n\n\n<p><\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u73b0\u4ee3\u5316\u5168\u6808\u7535\u5546\u7f51\u7ad9\uff08\u542b\u7528\u6237\u7cfb\u7edf\uff09\u6280\u672f\u6808\u89c4 [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"site-sidebar-layout":"default","site-content-layout":"","ast-site-content-layout":"default","site-content-style":"default","site-sidebar-style":"default","ast-global-header-display":"","ast-banner-title-visibility":"","ast-main-header-display":"","ast-hfb-above-header-display":"","ast-hfb-below-header-display":"","ast-hfb-mobile-header-display":"","site-post-title":"","ast-breadcrumbs-content":"","ast-featured-img":"","footer-sml-layout":"","ast-disable-related-posts":"","theme-transparent-header-meta":"","adv-header-id-meta":"","stick-header-meta":"","header-above-stick-meta":"","header-main-stick-meta":"","header-below-stick-meta":"","astra-migrate-meta-layouts":"default","ast-page-background-enabled":"default","ast-page-background-meta":{"desktop":{"background-color":"var(--ast-global-color-5)","background-image":"","background-repeat":"repeat","background-position":"center center","background-size":"auto","background-attachment":"scroll","background-type":"","background-media":"","overlay-type":"","overlay-color":"","overlay-opacity":"","overlay-gradient":""},"tablet":{"background-color":"","background-image":"","background-repeat":"repeat","background-position":"center center","background-size":"auto","background-attachment":"scroll","background-type":"","background-media":"","overlay-type":"","overlay-color":"","overlay-opacity":"","overlay-gradient":""},"mobile":{"background-color":"","background-image":"","background-repeat":"repeat","background-position":"center center","background-size":"auto","background-attachment":"scroll","background-type":"","background-media":"","overlay-type":"","overlay-color":"","overlay-opacity":"","overlay-gradient":""}},"ast-content-background-meta":{"desktop":{"background-color":"var(--ast-global-color-4)","background-image":"","background-repeat":"repeat","background-position":"center center","background-size":"auto","background-attachment":"scroll","background-type":"","background-media":"","overlay-type":"","overlay-color":"","overlay-opacity":"","overlay-gradient":""},"tablet":{"background-color":"var(--ast-global-color-4)","background-image":"","background-repeat":"repeat","background-position":"center center","background-size":"auto","background-attachment":"scroll","background-type":"","background-media":"","overlay-type":"","overlay-color":"","overlay-opacity":"","overlay-gradient":""},"mobile":{"background-color":"var(--ast-global-color-4)","background-image":"","background-repeat":"repeat","background-position":"center center","background-size":"auto","background-attachment":"scroll","background-type":"","background-media":"","overlay-type":"","overlay-color":"","overlay-opacity":"","overlay-gradient":""}},"footnotes":""},"categories":[1],"tags":[],"class_list":["post-104","post","type-post","status-publish","format-standard","hentry","category-uncategorized"],"_links":{"self":[{"href":"https:\/\/word.ronrin.cn\/index.php\/wp-json\/wp\/v2\/posts\/104","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/word.ronrin.cn\/index.php\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/word.ronrin.cn\/index.php\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/word.ronrin.cn\/index.php\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/word.ronrin.cn\/index.php\/wp-json\/wp\/v2\/comments?post=104"}],"version-history":[{"count":1,"href":"https:\/\/word.ronrin.cn\/index.php\/wp-json\/wp\/v2\/posts\/104\/revisions"}],"predecessor-version":[{"id":105,"href":"https:\/\/word.ronrin.cn\/index.php\/wp-json\/wp\/v2\/posts\/104\/revisions\/105"}],"wp:attachment":[{"href":"https:\/\/word.ronrin.cn\/index.php\/wp-json\/wp\/v2\/media?parent=104"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/word.ronrin.cn\/index.php\/wp-json\/wp\/v2\/categories?post=104"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/word.ronrin.cn\/index.php\/wp-json\/wp\/v2\/tags?post=104"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}