{"id":1798,"date":"2025-09-10T20:29:24","date_gmt":"2025-09-10T12:29:24","guid":{"rendered":"https:\/\/zero-zl.cn\/?p=1798"},"modified":"2025-09-11T08:58:15","modified_gmt":"2025-09-11T00:58:15","slug":"07-springboot3vue3%e5%ae%9e%e7%8e%b0excel%e6%89%b9%e9%87%8f%e5%af%bc%e5%85%a5%e5%af%bc%e5%87%ba","status":"publish","type":"post","link":"https:\/\/zero-zl.cn\/index.php\/2025\/09\/10\/07-springboot3vue3%e5%ae%9e%e7%8e%b0excel%e6%89%b9%e9%87%8f%e5%af%bc%e5%85%a5%e5%af%bc%e5%87%ba\/","title":{"rendered":"07. Springboot3+Vue3\u5b9e\u73b0excel\u6279\u91cf\u5bfc\u5165\u5bfc\u51fa"},"content":{"rendered":"\n<h2 class=\"wp-block-heading\">Hutool\u5de5\u5177\u7c7b<\/h2>\n\n\n\n<p class=\"wp-block-paragraph\"><a href=\"https:\/\/doc.hutool.cn\/pages\/index\/\">\u7b80\u4ecb | Hutool<\/a><\/p>\n\n\n\n<h2 class=\"wp-block-heading\">Excel\u5bfc\u51fa<\/h2>\n\n\n\n<p class=\"wp-block-paragraph\">\u901a\u8fc7\u8f93\u51fa\u6d41\u7684\u65b9\u5f0f\u5bfc\u51fa\u6570\u636e<\/p>\n\n\n\n<h3 class=\"wp-block-heading\">\u5bfc\u51fa\u6570\u636e\u6d41\u7a0b<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li>\u62ff\u5230\u6240\u6709\u6570\u636e<\/li>\n\n\n\n<li>\u6784\u5efaExcelWriter<\/li>\n\n\n\n<li>\u8bbe\u7f6e\u4e2d\u6587\u8868\u5934<\/li>\n\n\n\n<li>\u5199\u51fa\u6570\u636e\u5230writer<\/li>\n\n\n\n<li>\u8bbe\u7f6e\u8f93\u51fa\u7684\u6587\u4ef6\u540d\u79f0\u4ee5\u53ca\u8f93\u51fa\u6d41\u7684\u4fe1\u606f<\/li>\n\n\n\n<li>\u5199\u51fa\u5230\u8f93\u51fa\u6d41\u5e76\u5173\u95edwriter<\/li>\n<\/ol>\n\n\n\n<p class=\"wp-block-paragraph\">\u9ed8\u8ba4\u7684\uff0c\u672a\u6dfb\u52a0alias\u7684\u5c5e\u6027\u4e5f\u4f1a\u5199\u51fa\uff0c\u5982\u679c\u60f3\u53ea\u5199\u51fa\u52a0\u4e86\u522b\u540d\u7684\u5b57\u6bb5\uff0c\u53ef\u4ee5\u8c03\u7528\u6b64\u65b9\u6cd5\u6392\u9664<br>writer.setOnlyAlias(true);<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>    \/**\n     * \u5bfc\u51fa\u6570\u636e\n     *\/\n    @GetMapping(\"\/export\")\n    public void exportData(HttpServletResponse response) throws Exception {\n        \/\/ 1.\u62ff\u5230\u6240\u6709\u6570\u636e\n        List&lt;Admin&gt; list = adminService.selectAll();\n        \/\/ 2.\u6784\u5efaWriter\u5bf9\u8c61\n        ExcelWriter writer = ExcelUtil.getWriter(true);\n        \/\/ 3.\u8bbe\u7f6e\u4e2d\u6587\u8868\u5934\n        writer.addHeaderAlias(\"username\", \"\u8d26\u53f7\");\n        writer.addHeaderAlias(\"name\", \"\u540d\u79f0\");\n        writer.addHeaderAlias(\"phone\", \"\u7535\u8bdd\");\n        writer.addHeaderAlias(\"email\", \"\u90ae\u7bb1\");\n        \/\/ \u9ed8\u8ba4\u7684\uff0c\u672a\u6dfb\u52a0alias\u7684\u5c5e\u6027\u4e5f\u4f1a\u5199\u51fa\uff0c\u5982\u679c\u60f3\u53ea\u5199\u51fa\u52a0\u4e86\u522b\u540d\u7684\u5b57\u6bb5\uff0c\u53ef\u4ee5\u8c03\u7528\u6b64\u65b9\u6cd5\u6392\u9664\n        writer.setOnlyAlias(true);\n        \/\/ 4.\u5199\u51fa\u6570\u636e\u5230writer\n        writer.write(list);\n        \/\/ 5.\u8bbe\u7f6e\u8f93\u51fa\u6587\u4ef6\u7684\u540d\u79f0\n        response.setContentType(\"application\/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=utf-8\");\n        String fileName = URLEncoder.encode(\"\u7ba1\u7406\u5458\u4fe1\u606f\", StandardCharsets.UTF_8);\n        response.setHeader(\"Content-Disposition\", \"attachment;filename=\" + fileName + \".xlsx\");\n        \/\/ 6.\u5199\u51fa\u5230\u8f93\u51fa\u6d41\uff0c\u5e76\u5173\u95edwriter\n        ServletOutputStream os = response.getOutputStream();\n        writer.flush(os);\n        writer.close();\n        os.close();\n    }\n<\/code><\/pre>\n\n\n\n<h3 class=\"wp-block-heading\">\u5f02\u5e38\u5904\u7406\uff0c\u7f3a\u5c11\u4f9d\u8d56<\/h3>\n\n\n\n<figure class=\"wp-block-image size-large\"><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='https:\/\/zero-zl.cn\/wp-content\/uploads\/2025\/09\/image-40-1024x161.png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  loading=\"lazy\" decoding=\"async\" width=\"1024\" height=\"161\" data-original=\"https:\/\/zero-zl.cn\/wp-content\/uploads\/2025\/09\/image-40-1024x161.png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"\" class=\"wp-image-1799\"  sizes=\"auto, (max-width: 1024px) 100vw, 1024px\" \/><\/div><\/figure>\n\n\n\n<p class=\"wp-block-paragraph\">\u52a0\u4e0a poi-ooxml \u4f9d\u8d56<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>        &lt;!-- \u5904\u7406office\u6587\u4ef6\u7684\u4f9d\u8d56 --&gt;\n        &lt;dependency&gt;\n            &lt;groupId&gt;org.apache.poi&lt;\/groupId&gt;\n            &lt;artifactId&gt;poi-ooxml&lt;\/artifactId&gt;\n            &lt;version&gt;5.2.3&lt;\/version&gt;\n        &lt;\/dependency&gt;<\/code><\/pre>\n\n\n\n<h3 class=\"wp-block-heading\">\u524d\u7aef\u8c03\u7528<\/h3>\n\n\n\n<pre class=\"wp-block-code\"><code>const exportData = () =&gt; {\n  window.open('http:\/\/localhost:9999\/admin\/export')\n}<\/code><\/pre>\n\n\n\n<h3 class=\"wp-block-heading\">\u6761\u4ef6\u5bfc\u51fa<\/h3>\n\n\n\n<figure class=\"wp-block-image size-full\"><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='https:\/\/zero-zl.cn\/wp-content\/uploads\/2025\/09\/image-41.png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  loading=\"lazy\" decoding=\"async\" width=\"713\" height=\"54\" data-original=\"https:\/\/zero-zl.cn\/wp-content\/uploads\/2025\/09\/image-41.png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"\" class=\"wp-image-1800\"  sizes=\"auto, (max-width: 713px) 100vw, 713px\" \/><\/div><\/figure>\n\n\n\n<p class=\"wp-block-paragraph\">null \u4f20\u5230\u540e\u7aef\u662f\u4e00\u4e2a\u5b57\u7b26\u4e32 \u201cnull\u201d<\/p>\n\n\n\n<figure class=\"wp-block-image size-full\"><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='https:\/\/zero-zl.cn\/wp-content\/uploads\/2025\/09\/image-42.png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  loading=\"lazy\" decoding=\"async\" width=\"850\" height=\"339\" data-original=\"https:\/\/zero-zl.cn\/wp-content\/uploads\/2025\/09\/image-42.png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"\" class=\"wp-image-1802\"  sizes=\"auto, (max-width: 850px) 100vw, 850px\" \/><\/div><\/figure>\n\n\n\n<p class=\"wp-block-paragraph\">\u5728\u67e5\u8be2\u8bed\u53e5\u91cc\u9762\u52a0\u4e0a\u7a7a\u5b57\u7b26\u4e32\u7684\u5224\u65ad<\/p>\n\n\n\n<figure class=\"wp-block-image size-large\"><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='https:\/\/zero-zl.cn\/wp-content\/uploads\/2025\/09\/image-43-1024x190.png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  loading=\"lazy\" decoding=\"async\" width=\"1024\" height=\"190\" data-original=\"https:\/\/zero-zl.cn\/wp-content\/uploads\/2025\/09\/image-43-1024x190.png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"\" class=\"wp-image-1803\"  sizes=\"auto, (max-width: 1024px) 100vw, 1024px\" \/><\/div><\/figure>\n\n\n\n<h3 class=\"wp-block-heading\">\u6839\u636e\u9009\u62e9\u9879\u5bfc\u51fa<\/h3>\n\n\n\n<p class=\"wp-block-paragraph\">\u89e3\u6790\u53c2\u6570<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>String ids = admin.getIds();\n        if (StrUtil.isNotBlank(ids)){\n            String&#91;] idsArr = ids.split(\",\");\n            admin.setIdsArr(idsArr);\n        }<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">\u67e5\u8be2\u7684 sql<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>    &lt;select id=\"selectAll\" resultType=\"org.example.springdemo.entity.Admin\"&gt;\n        select * from `admin`\n        &lt;where&gt;\n            &lt;if test=\"username != null and username != ''\"&gt;username like concat('%',#{username},'%')&lt;\/if&gt;\n            &lt;if test=\"name != null and name != ''\"&gt;and name like concat('%',#{name},'%')&lt;\/if&gt;  &lt;!--\u76f8\u5f53\u4e8e name like '%1%'--&gt;\n            &lt;if test=\"ids != null and ids != ''\"&gt;\n                and id in\n                &lt;foreach collection=\"idsArr\" open=\"(\" close=\")\" separator=\",\" item=\"id\"&gt;\n                    #{id}\n                &lt;\/foreach&gt;\n            &lt;\/if&gt;\n        &lt;\/where&gt;\n        order by id desc\n    &lt;\/select&gt;<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">\u53c2\u6570\u7684\u683c\u5f0f<\/p>\n\n\n\n<figure class=\"wp-block-image size-full is-resized\"><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='https:\/\/zero-zl.cn\/wp-content\/uploads\/2025\/09\/image-44.png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  loading=\"lazy\" decoding=\"async\" width=\"811\" height=\"59\" data-original=\"https:\/\/zero-zl.cn\/wp-content\/uploads\/2025\/09\/image-44.png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"\" class=\"wp-image-1804\" style=\"width:672px;height:auto\"  sizes=\"auto, (max-width: 811px) 100vw, 811px\" \/><\/div><\/figure>\n\n\n\n<p class=\"wp-block-paragraph\">\u524d\u7aef\u7684\u5bfc\u51fa\u65b9\u6cd5<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>const exportData = () =&gt; {\n  let idsStr = data.ids.join(\",\")   \/\/ \u628a\u6570\u7ec4\u8f6c\u6362\u6210\u5b57\u7b26\u4e32 &#91; 1,2,3 ] =&gt; \" 1,2,3 \"\n  let url = `http:\/\/localhost:9999\/admin\/export?username=${data.username === null ? '' : data.username}`\n  + `&amp;name=${data.name === null ? '' :data.name}`\n  +`&amp;ids=${idsStr}`\n  window.open(url)\n}<\/code><\/pre>\n\n\n\n<h2 class=\"wp-block-heading\">Excel\u5bfc\u5165<\/h2>\n\n\n\n<h3 class=\"wp-block-heading\">\u5bfc\u5165\u6570\u636e\u6d41\u7a0b<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li>\u83b7\u53d6\u8f93\u5165\u6d41\uff0c\u6784\u5efaReader\u5bf9\u8c61<\/li>\n\n\n\n<li>\u901a\u8fc7Reader\u8bfb\u53d6excel\u91cc\u9762\u7684\u6570\u636e<\/li>\n\n\n\n<li>\u5c06\u6570\u636e\u5199\u5230\u6570\u636e\u5e93<\/li>\n<\/ol>\n\n\n\n<pre class=\"wp-block-code\"><code>    \/**\n     *\u6279\u91cf\u5bfc\u5165\u6570\u636e\n     *\/\n    @PostMapping(\"\/import\")\n    public Result importData(MultipartFile file) throws Exception {\n        \/\/ 1.\u62ff\u5230\u8f93\u5165\u6d41\uff0c\u6784\u5efareader\n        InputStream inputStream = file.getInputStream();\n        ExcelReader reader = ExcelUtil.getReader(inputStream);\n        \/\/ 2.\u901a\u8fc7Reader\u8bfb\u53d6excel\u91cc\u9762\u7684\u6570\u636e\n        reader.addHeaderAlias(\"\u8d26\u53f7\", \"username\");\n        reader.addHeaderAlias(\"\u540d\u79f0\", \"name\");\n        reader.addHeaderAlias(\"\u7535\u8bdd\", \"phone\");\n        reader.addHeaderAlias(\"\u90ae\u7bb1\", \"email\");\n        List&lt;Admin&gt; list = reader.readAll(Admin.class);\n        \/\/ 3.\u5c06\u6570\u636e\u5199\u5230\u6570\u636e\u5e93\n        for (Admin admin : list) {\n            adminService.add(admin);\n        }\n        return Result.success();\n    }<\/code><\/pre>\n\n\n\n<h3 class=\"wp-block-heading\">\u524d\u7aef\u9875\u9762<\/h3>\n\n\n\n<pre class=\"wp-block-preformatted\">      &lt;el-upload<br>          style=\"display: inline-block; margin-left: 10px\"<br>          action=\"http:\/\/localhost:9999\/admin\/import\"<br>          :show-file-list=\"false\"<br>          :on-success=\"handleImportSuccess\"<br>      ><br>        &lt;el-button type=\"success\">\u6279\u91cf\u5bfc\u5165&lt;\/el-button><br>      &lt;\/el-upload><br><br>const handleImportSuccess = (res) => {<br>  if (res.code ==='200') {<br>    ElMessage.success('\u6279\u91cf\u5bfc\u5165\u6210\u529f')<br>    load()<br>  } else {<br>    ElMessage.error(res.msg)<br>  }<br>}<\/pre>\n","protected":false},"excerpt":{"rendered":"<p>Hutool\u5de5\u5177\u7c7b \u7b80\u4ecb | Hutool Excel\u5bfc\u51fa \u901a\u8fc7\u8f93\u51fa\u6d41\u7684\u65b9\u5f0f\u5bfc\u51fa\u6570\u636e \u5bfc\u51fa\u6570\u636e\u6d41\u7a0b \u9ed8\u8ba4\u7684\uff0c\u672a [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[114,102],"tags":[],"class_list":["post-1798","post","type-post","status-publish","format-standard","hentry","category-spring-boot3vue3","category-102"],"_links":{"self":[{"href":"https:\/\/zero-zl.cn\/index.php\/wp-json\/wp\/v2\/posts\/1798","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/zero-zl.cn\/index.php\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/zero-zl.cn\/index.php\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/zero-zl.cn\/index.php\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/zero-zl.cn\/index.php\/wp-json\/wp\/v2\/comments?post=1798"}],"version-history":[{"count":5,"href":"https:\/\/zero-zl.cn\/index.php\/wp-json\/wp\/v2\/posts\/1798\/revisions"}],"predecessor-version":[{"id":1810,"href":"https:\/\/zero-zl.cn\/index.php\/wp-json\/wp\/v2\/posts\/1798\/revisions\/1810"}],"wp:attachment":[{"href":"https:\/\/zero-zl.cn\/index.php\/wp-json\/wp\/v2\/media?parent=1798"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/zero-zl.cn\/index.php\/wp-json\/wp\/v2\/categories?post=1798"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/zero-zl.cn\/index.php\/wp-json\/wp\/v2\/tags?post=1798"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}