{"id":23260,"date":"2024-11-21T11:59:45","date_gmt":"2024-11-21T03:59:45","guid":{"rendered":"https:\/\/fwq.ai\/blog\/23260\/"},"modified":"2024-11-21T11:59:45","modified_gmt":"2024-11-21T03:59:45","slug":"%e6%80%8e%e6%a0%b7%e5%9c%a8thinkphp6%e4%b8%ad%e8%bf%9b%e8%a1%8c%e5%af%8c%e6%96%87%e6%9c%ac%e7%bc%96%e8%be%91%e5%99%a8%e5%9b%be%e7%89%87%e4%b8%8a%e4%bc%a0%e6%93%8d%e4%bd%9c%ef%bc%9f","status":"publish","type":"post","link":"https:\/\/fwq.ai\/blog\/23260\/","title":{"rendered":"\u600e\u6837\u5728ThinkPHP6\u4e2d\u8fdb\u884c\u5bcc\u6587\u672c\u7f16\u8f91\u5668\u56fe\u7247\u4e0a\u4f20\u64cd\u4f5c\uff1f"},"content":{"rendered":"<p>6\u4f5c\u4e3a\u4e00\u6b3e\u4f18\u79c0\u7684php\u6846\u67b6\uff0c\u63d0\u4f9b\u4e86\u4e30\u5bcc\u7684\u64cd\u4f5c\u7c7b\u5e93\u548c\u5de5\u5177\uff0c\u4f7f\u5f97\u5f00\u53d1\u8005\u53ef\u4ee5\u66f4\u5feb\u6377\u5730\u5b9e\u73b0\u529f\u80fd\u9700\u6c42\u3002\u5728\u7f51\u9875\u5f00\u53d1\u4e2d\uff0c\u5bcc\u6587\u672c\u7f16\u8f91\u5668\u5e38\u4f5c\u4e3a\u5fc5\u5907\u5de5\u5177\u4e4b\u4e00\uff0c\u53ef\u4ee5\u5e2e\u52a9\u7528\u6237\u66f4\u65b9\u4fbf\u5730\u7f16\u8f91\u5185\u5bb9\u3002\u7136\u800c\uff0c\u5f53\u7528\u6237\u60f3\u8981\u63d2\u5165\u56fe\u7247\u65f6\uff0c\u5c31\u9700\u8981\u6709\u56fe\u7247\u4e0a\u4f20\u529f\u80fd\u652f\u6301\u3002<\/p>\n<p>\u672c\u6587\u5c06\u4ee5UMEditor\u4f5c\u4e3a\u793a\u4f8b\uff0c\u4ecb\u7ecd\u5728ThinkPHP6\u4e2d\u5982\u4f55\u5b9e\u73b0\u5bcc\u6587\u672c\u7f16\u8f91\u5668\u56fe\u7247\u4e0a\u4f20\u529f\u80fd\u3002<\/p>\n<p>\u7b2c\u4e00\u6b65\uff1a\u5f15\u5165UMEditor<\/p>\n<p>\u5c06UMEditor\u7684\u8d44\u6e90\u6587\u4ef6\uff08\u5305\u62ecjs\u3001css\u3001images\u7b49\uff09\u653e\u5230\u9879\u76ee\u76ee\u5f55\u4e0b\u7684public\u76ee\u5f55\u4e2d\uff0c\u7136\u540e\u5728HTML\u9875\u9762\u4e2d\u5f15\u5165UMEditor\u7684\u76f8\u5173\u8d44\u6e90\u6587\u4ef6\u3002\u793a\u4f8b\u5982\u4e0b\uff1a<\/p>\n<pre>&lt;!-- \u5f15\u5165UMEditor --&gt;\n&lt;link href=\"\/public\/UMEditor\/themes\/default\/css\/umeditor.css\" rel=\"stylesheet\"&gt;&lt;script src=\"\/public\/UMEditor\/umeditor.config.js\"&gt;&lt;\/script&gt;&lt;script src=\"\/public\/UMEditor\/umeditor.min.js\"&gt;&lt;\/script&gt;<\/pre>\n<p> \u767b\u5f55\u540e\u590d\u5236 <\/p>\n<p>\u7b2c\u4e8c\u6b65\uff1a\u7f16\u5199\u56fe\u7247\u4e0a\u4f20\u63a5\u53e3<\/p>\n<p><span>\u7acb\u5373\u5b66\u4e60<\/span>\u201c\u201d\uff1b<\/p>\n<p>\u5728ThinkPHP6\u4e2d\uff0c\u53ef\u4ee5\u901a\u8fc7Route\u7c7b\u548cController\u7c7b\u6765\u5b9e\u73b0\u63a5\u53e3\u7684\u7f16\u5199\u3002<\/p>\n<ol>\n<li>\u5728routes\u76ee\u5f55\u4e0b\u521b\u5efa\u4e00\u4e2aupload.php\u6587\u4ef6\uff0c\u4ee3\u7801\u5982\u4e0b\uff1a<\/li>\n<\/ol>\n<pre>acadeRoute;\n\nRoute::post('upload\/image', 'api\/Upload\/uploadImage');<\/pre>\n<p> \u767b\u5f55\u540e\u590d\u5236 <\/p>\n<p>\u8be5\u8def\u7531\u6620\u5c04\u7684\u63a7\u5236\u5668\u65b9\u6cd5\u4e3aUpload\u63a7\u5236\u5668\u7684uploadImage\u65b9\u6cd5\u3002<\/p>\n<ol>\n<li>\u5728app\u76ee\u5f55\u4e0b\u521b\u5efa\u4e00\u4e2aapi\u76ee\u5f55\uff0c\u7136\u540e\u5728api\u76ee\u5f55\u4e0b\u521b\u5efa\u4e00\u4e2aUpload\u63a7\u5236\u5668\u548c\u4e00\u4e2aUploadService\u670d\u52a1\uff0c\u4ee3\u7801\u5982\u4e0b\uff1a<\/li>\n<\/ol>\n<p>Upload\u63a7\u5236\u5668\uff1a<\/p>\n<pre>picontroller;\n\nuse apppiserviceUploadService;\nuse thinkacadeRequest;\n\nclass Upload\n{\n    public function uploadImage()\n    {\n        $file = Request::file('upfile');\n        $uploadService = new UploadService();\n        $result = $uploadService-&amp;gt;uploadImage($file);\n        return json($result);\n    }\n}<\/pre>\n<p> \u767b\u5f55\u540e\u590d\u5236 <\/p>\n<p>UploadService\u670d\u52a1\uff1a<\/p>\n<pre>piservice;\n\nuse thinkacadeFilesystem;\nuse thinkacadeConfig;\n\nclass UploadService\n{\n    public function uploadImage($file)\n    {\n        $storage = Config::get('filesystem.default');\n        $savename = Filesystem::disk($storage)-&amp;gt;putFile('images', $file);\n        $url = Config::get(\"filesystem.disks.{$storage}.url\") . '\/' . str_replace('', '\/', $savename);\n        return [\n            'state' =&amp;gt; 'SUCCESS',\n            'url' =&amp;gt; $url,\n            'title' =&amp;gt; '',\n            'original' =&amp;gt; $file-&amp;gt;getOriginalName(),\n            'type' =&amp;gt; $file-&amp;gt;getOriginalExtension(),\n            'size' =&amp;gt; $file-&amp;gt;getSize(),\n        ];\n    }\n}<\/pre>\n<p> \u767b\u5f55\u540e\u590d\u5236 <\/p>\n<p>\u5728UploadService\u4e2d\uff0c\u6211\u4eec\u4f7f\u7528\u4e86ThinkPHP6\u63d0\u4f9b\u7684\u6587\u4ef6\u5b58\u50a8\u529f\u80fd\uff0c\u4ee5\u8fbe\u5230\u56fe\u7247\u4e0a\u4f20\u7684\u76ee\u7684\u3002\u5177\u4f53\u5b9e\u73b0\u4f7f\u7528\u4e86Filesystem\u7c7b\u548cConfig\u7c7b\u3002\u5728\u914d\u7f6e\u6587\u4ef6config\/filesystem.php\u4e2d\uff0c\u9700\u8981\u914d\u7f6e\u76f8\u5e94\u7684\u5b58\u50a8\u65b9\u5f0f\u548c\u8def\u5f84\u3002<\/p>\n<p>\u7b2c\u4e09\u6b65\uff1a\u914d\u7f6eUMEditor<\/p>\n<ol>\n<li>\u5728HTML\u9875\u9762\u4e2d\u5b9e\u4f8b\u5316UMEditor\uff0c\u5e76\u914d\u7f6e\u56fe\u7247\u4e0a\u4f20\u63a5\u53e3\uff1a<\/li>\n<\/ol>\n<pre>&lt;script type=\"text\/javascript\"&gt;\n    var um = UM.getEditor('myEditor', {\n        imageUrl: '\/upload\/image',  \/\/\u56fe\u7247\u4e0a\u4f20\u63a5\u53e3\n        imageFieldName: 'upfile',   \/\/\u56fe\u7247\u63d0\u4ea4\u7684\u8868\u5355\u540d\u79f0\n        imageMaxSize: 2048000,      \/\/\u56fe\u7247\u5927\u5c0f\u9650\u5236\uff0c\u5355\u4f4d\u662f\u5b57\u8282\n        imageAllowFiles: ['.jpg', '.png', '.gif', '.jpeg'],  \/\/\u5141\u8bb8\u4e0a\u4f20\u7684\u56fe\u7247\u7c7b\u578b\n    });\n&lt;\/script&gt;<\/pre>\n<p> \u767b\u5f55\u540e\u590d\u5236 <\/p>\n<ol>\n<li>\u914d\u7f6eUMEditor\u7684\u6587\u4ef6\u4e0a\u4f20\u8def\u5f84\uff1a<\/li>\n<\/ol>\n<pre>&lt;script type=\"text\/javascript\"&gt;\n    UMEDITOR_CONFIG.serverUrl = '\/public\/UMEditor\/php\/controller.php\/?action=';\n&lt;\/script&gt;<\/pre>\n<p> \u767b\u5f55\u540e\u590d\u5236 <\/p>\n<p>\u5728controller.php\u4e2d\uff0c\u9700\u8981\u5c06\u56fe\u7247\u4e0a\u4f20\u7684\u8bf7\u6c42\u8f6c\u53d1\u5230\u6211\u4eec\u521a\u521a\u7f16\u5199\u7684\u56fe\u7247\u4e0a\u4f20\u63a5\u53e3\u3002<\/p>\n<p>\u81f3\u6b64\uff0c\u6211\u4eec\u5df2\u7ecf\u6210\u529f\u5730\u5728ThinkPHP6\u4e2d\u5b9e\u73b0\u4e86UMEditor\u5bcc\u6587\u672c\u7f16\u8f91\u5668\u7684\u56fe\u7247\u4e0a\u4f20\u529f\u80fd\u3002\u5f00\u53d1\u8005\u53ef\u4ee5\u901a\u8fc7\u7c7b\u4f3c\u7684\u65b9\u6cd5\uff0c\u5b9e\u73b0\u5176\u5b83\u5bcc\u6587\u672c\u7f16\u8f91\u5668\u7684\u56fe\u7247\u4e0a\u4f20\u529f\u80fd\u3002<\/p>\n<p>\u4ee5\u4e0a\u5c31\u662f\u600e\u6837\u5728ThinkPHP6\u4e2d\u8fdb\u884c\u5bcc\u6587\u672c\u7f16\u8f91\u5668\u56fe\u7247\u4e0a\u4f20\u64cd\u4f5c\uff1f\u7684\u8be6\u7ec6\u5185\u5bb9\uff0c\u66f4\u591a\u8bf7\u5173\u6ce8\u7c73\u4e91\u5176\u5b83\u76f8\u5173\u6587\u7ae0\uff01<\/p>\n","protected":false},"excerpt":{"rendered":"<p>6\u4f5c\u4e3a\u4e00\u6b3e\u4f18\u79c0\u7684php\u6846\u67b6\uff0c\u63d0\u4f9b\u4e86\u4e30\u5bcc\u7684\u64cd\u4f5c\u7c7b\u5e93\u548c\u5de5\u5177\uff0c\u4f7f\u5f97\u5f00\u53d1\u8005\u53ef\u4ee5\u66f4\u5feb\u6377\u5730\u5b9e\u73b0\u529f\u80fd\u9700\u6c42\u3002\u5728\u7f51\u9875\u5f00\u53d1\u4e2d\uff0c\u5bcc\u6587\u672c\u7f16\u8f91\u5668\u5e38\u4f5c\u4e3a\u5fc5\u5907\u5de5\u5177\u4e4b\u4e00\uff0c\u53ef\u4ee5\u5e2e\u52a9\u7528\u6237\u66f4\u65b9\u4fbf\u5730\u7f16\u8f91\u5185\u5bb9\u3002\u7136\u800c\uff0c\u5f53\u7528\u6237\u60f3\u8981\u63d2\u5165\u56fe\u7247\u65f6\uff0c\u5c31\u9700\u8981\u6709\u56fe\u7247\u4e0a\u4f20\u529f\u80fd\u652f\u6301\u3002 \u672c\u6587\u5c06\u4ee5UMEditor\u4f5c\u4e3a\u793a\u4f8b\uff0c\u4ecb\u7ecd\u5728ThinkPHP6\u4e2d\u5982\u4f55\u5b9e\u73b0\u5bcc\u6587\u672c\u7f16\u8f91\u5668\u56fe\u7247\u4e0a\u4f20\u529f\u80fd\u3002 \u7b2c\u4e00\u6b65\uff1a\u5f15\u5165UMEditor \u5c06UMEditor\u7684\u8d44\u6e90\u6587\u4ef6\uff08\u5305\u62ecjs\u3001css\u3001images\u7b49\uff09\u653e\u5230\u9879\u76ee\u76ee\u5f55\u4e0b\u7684public\u76ee\u5f55\u4e2d\uff0c\u7136\u540e\u5728HTML\u9875\u9762\u4e2d\u5f15\u5165UMEditor\u7684\u76f8\u5173\u8d44\u6e90\u6587\u4ef6\u3002\u793a\u4f8b\u5982\u4e0b\uff1a &lt;!&#8211; \u5f15\u5165UMEditor &#8211;&gt; &lt;link href=&#8221;\/public\/UMEditor\/themes\/default\/css\/umeditor.css&#8221; rel=&#8221;stylesheet&#8221;&gt;&lt;script src=&#8221;\/public\/UMEditor\/umeditor.config.js&#8221;&gt;&lt;\/script&gt;&lt;script src=&#8221;\/public\/UMEditor\/umeditor.min.js&#8221;&gt;&lt;\/script&gt; \u767b\u5f55\u540e\u590d\u5236 \u7b2c\u4e8c\u6b65\uff1a\u7f16\u5199\u56fe\u7247\u4e0a\u4f20\u63a5\u53e3 \u7acb\u5373\u5b66\u4e60\u201c\u201d\uff1b \u5728ThinkPHP6\u4e2d\uff0c\u53ef\u4ee5\u901a\u8fc7Route\u7c7b\u548cController\u7c7b\u6765\u5b9e\u73b0\u63a5\u53e3\u7684\u7f16\u5199\u3002 \u5728routes\u76ee\u5f55\u4e0b\u521b\u5efa\u4e00\u4e2aupload.php\u6587\u4ef6\uff0c\u4ee3\u7801\u5982\u4e0b\uff1a acadeRoute; Route::post(&#8216;upload\/image&#8217;, &#8216;api\/Upload\/uploadImage&#8217;); \u767b\u5f55\u540e\u590d\u5236 \u8be5\u8def\u7531\u6620\u5c04\u7684\u63a7\u5236\u5668\u65b9\u6cd5\u4e3aUpload\u63a7\u5236\u5668\u7684uploadImage\u65b9\u6cd5\u3002 \u5728app\u76ee\u5f55\u4e0b\u521b\u5efa\u4e00\u4e2aapi\u76ee\u5f55\uff0c\u7136\u540e\u5728api\u76ee\u5f55\u4e0b\u521b\u5efa\u4e00\u4e2aUpload\u63a7\u5236\u5668\u548c\u4e00\u4e2aUploadService\u670d\u52a1\uff0c\u4ee3\u7801\u5982\u4e0b\uff1a Upload\u63a7\u5236\u5668\uff1a picontroller; use apppiserviceUploadService; use thinkacadeRequest; class Upload { public function uploadImage() { $file = Request::file(&#8216;upfile&#8217;); $uploadService = new UploadService(); $result = $uploadService-&amp;gt;uploadImage($file); return json($result); } } \u767b\u5f55\u540e\u590d\u5236 UploadService\u670d\u52a1\uff1a piservice; use thinkacadeFilesystem; [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[16],"tags":[],"class_list":["post-23260","post","type-post","status-publish","format-standard","hentry","category-16"],"_links":{"self":[{"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/posts\/23260","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/comments?post=23260"}],"version-history":[{"count":0,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/posts\/23260\/revisions"}],"wp:attachment":[{"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/media?parent=23260"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/categories?post=23260"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/tags?post=23260"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}