在SpringBoot框架下實(shí)現(xiàn)Excel導(dǎo)入導(dǎo)出的方法詳解
1.IDEA創(chuàng)建SpringBoot項(xiàng)目
1.1 Spring Initializr
想要在IDEA下快速搭建一個(gè)SpringBoot項(xiàng)目,可以使用Spring Initializr工具作為腳手架。
進(jìn)入IDEA后,在左側(cè)菜單中可以找到Plugins,點(diǎn)擊后,在上方的搜索框中輸入Spring Initializr。
之后點(diǎn)擊右上角的綠色I(xiàn)nstall按鈕進(jìn)行安裝。
安裝完畢后,在New Project 的時(shí)候就會(huì)多一個(gè)Spring Initializr的選項(xiàng)。
1.2 SpringBoot 項(xiàng)目的創(chuàng)建
Project SDK:根據(jù)實(shí)際應(yīng)用情況選擇用于配置項(xiàng)目所依賴(lài)的Java SDK。
Choose Spring Initializr Server:選擇一個(gè)Spring Initializr服務(wù)器,一般來(lái)說(shuō)都選擇默認(rèn)的。
GroupId:一般分為多個(gè)段,第一段為域,第二段為公司名稱(chēng)。例如:org.apache,com.grapecity。
ArtifactId:是項(xiàng)目的唯一標(biāo)識(shí)符,在實(shí)際開(kāi)發(fā)中一般對(duì)應(yīng)項(xiàng)目的名稱(chēng),就是項(xiàng)目根目錄的名稱(chēng)。
Group Id,Artfact Id是保證項(xiàng)目唯一性的標(biāo)識(shí),一般來(lái)說(shuō)如果項(xiàng)目打包上傳至maven這樣的包管理倉(cāng)庫(kù)中。在搜索你的項(xiàng)目時(shí),Group Id,Artfact Id是必要的條件。
Version:版本號(hào),默認(rèn)0.0.1-SNAPSHOT。SNAPSHOT代表不穩(wěn)定的版本,與之相對(duì)的有RELEASE。
Project type:工程的類(lèi)型,maven工程還是gradle工程。
Language:語(yǔ)言(Java,Kotlin,Groovy)。
Packaging:Jar包還是War包。
Java version:語(yǔ)法版本,與Project SDK不同,Project SDK是實(shí)際用到的JDK。Java version指的是語(yǔ)法版本。一般來(lái)說(shuō)語(yǔ)言特性不能比SDK高。比如SDK版本是11,語(yǔ)法選擇8。那么實(shí)際項(xiàng)目中只能使用java 8的語(yǔ)法。反之SDK版本是8,語(yǔ)法選11就有問(wèn)題了。一般情況下都會(huì)與SDK保持一致。
Project name:項(xiàng)目名稱(chēng)
Project description:項(xiàng)目描述
Package name:包名
第三部分根據(jù)項(xiàng)目的實(shí)際需求去配置。
第四部分:
設(shè)置項(xiàng)目名稱(chēng)與路徑。
2.前端配置
考慮到導(dǎo)入導(dǎo)出功能需要對(duì)Excel具有較高的還原度,這里使用了SpreadJS組件,通過(guò)SpreadJS組件的ExcelIO功能,進(jìn)行Excel的導(dǎo)入與導(dǎo)出。SpreadJS是一款純前端的組件,與后端完全解耦,可以完美的整合到SpringBoot工程中。
2.1 前端頁(yè)面創(chuàng)建
在static目錄下建立index.html文件,用來(lái)繪制前端頁(yè)面。如果用了thymeleaf也可以將文件建立在templates目錄中。
2.2 SpreadJS組件引入和初始化
在header中引入SpreadJS相關(guān)的css與js引用。
創(chuàng)建SpreadJS對(duì)應(yīng)的DOM對(duì)象。
在JS中初始化SpreadJS和導(dǎo)入導(dǎo)出Excel相關(guān)的ExcelIO對(duì)象。
通過(guò)按鈕點(diǎn)擊進(jìn)行服務(wù)端導(dǎo)入與導(dǎo)出。
導(dǎo)入導(dǎo)出事件處理,在事件中發(fā)送請(qǐng)求與服務(wù)端進(jìn)行連接。
導(dǎo)入原理:
將服務(wù)端的文件以文件流的形式傳輸至前端,前端通過(guò)ExcelIO將結(jié)果導(dǎo)入結(jié)果呈現(xiàn)值SpreadJS中,所以導(dǎo)入的傳遞的參數(shù)是一個(gè)文件路徑。注意該路徑是文件在服務(wù)端或者工程中的一個(gè)路徑。
導(dǎo)出原理:
通過(guò)SpreadJS ExcelIO的功能將內(nèi)容導(dǎo)出成Excel的blob流。之后將blob流傳至服務(wù)器端,在服務(wù)器端進(jìn)行保存Excel文件的操作。
3.后端配置
創(chuàng)建后端controller,可按照自身項(xiàng)目的包的層級(jí)分類(lèi)進(jìn)行創(chuàng)建。
構(gòu)建服務(wù)端的導(dǎo)入導(dǎo)出方法和相關(guān)邏輯。
服務(wù)器端導(dǎo)入:
由于前端傳入的是一個(gè)文件的路徑,所以參數(shù)這里我們需要一個(gè)字符串類(lèi)型的參數(shù)去接收。
另外,我們會(huì)將流傳到前端,所以會(huì)將流寫(xiě)到response中,所以參數(shù)中還需要response對(duì)象,方法本身不需要返回,返回空即可。原理是通過(guò)inputStream讀取文件后,將其寫(xiě)入response的outputStream中。
導(dǎo)出到服務(wù)器:
由于前端傳入傳入的是保存文件的名稱(chēng)以及文件blob文件流。服務(wù)器端需要兩個(gè)參數(shù),String用來(lái)接收文件名稱(chēng),MultipartFile對(duì)象用來(lái)接收blob文件流。后端接受到文件流之后通過(guò)transferTo方法在指定目錄下根軍傳來(lái)的fileName轉(zhuǎn)存成新的文件。
4.測(cè)試運(yùn)行
將工程跑起來(lái)之后進(jìn)入主頁(yè)面,顯示如下
點(diǎn)擊服務(wù)端導(dǎo)入按鈕,從服務(wù)器端下載指定的Excel文件并打開(kāi)。
對(duì)該文件進(jìn)行操作修改并點(diǎn)擊服務(wù)端導(dǎo)出的按鈕。
之后我們?nèi)シ?wù)器端的導(dǎo)出路徑下查看,發(fā)下文件存在,用Excel打開(kāi)文件后發(fā)現(xiàn),修改后的內(nèi)容健在并且其他內(nèi)容顯示均無(wú)問(wèn)題。
到這里我們就實(shí)現(xiàn)了Spring Boot框架下實(shí)現(xiàn)Excel服務(wù)端導(dǎo)入導(dǎo)出。
以上就是在SpringBoot框架下實(shí)現(xiàn)Excel導(dǎo)入導(dǎo)出的方法詳解的詳細(xì)內(nèi)容,更多關(guān)于SpringBoot Excel導(dǎo)入導(dǎo)出的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
SpringBoot中配置多數(shù)據(jù)源的方法詳解
這篇文章主要為大家詳細(xì)介紹了SpringBoot中配置多數(shù)據(jù)源的方法的相關(guān)知識(shí),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-02-02SpringSecurity6.4中一次性令牌登錄(One-Time Token Login)實(shí)現(xiàn)
Spring Security為一次性令牌認(rèn)證提供了支持,本文就來(lái)介紹一下SpringSecurity6.4中一次性令牌登錄(One-Time Token Login)實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下2025-03-03k8s部署springboot實(shí)現(xiàn)前后端分離項(xiàng)目
本文主要介紹了k8s部署springboot實(shí)現(xiàn)前后端分離項(xiàng)目,主要包括配置文件、鏡像構(gòu)建和容器編排等方面,具有一定的參考價(jià)值,感興趣的可以了解一下2024-01-01SpringBoot利用切面注解及反射實(shí)現(xiàn)事件監(jiān)聽(tīng)功能
這篇文章主要介紹了springboot事件監(jiān)聽(tīng),通過(guò)利用切面、注解、反射實(shí)現(xiàn),接下來(lái)將對(duì)這幾種方式逐一說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助2022-07-07在Spring應(yīng)用中進(jìn)行單元測(cè)試的解析和代碼演示
在Spring應(yīng)用中進(jìn)行單元測(cè)試通常涉及到Spring TestContext Framework,它提供了豐富的注解和工具來(lái)支持單元測(cè)試和集成測(cè)試,以下是如何在Spring應(yīng)用中進(jìn)行單元測(cè)試的詳細(xì)解析和代碼演示,需要的朋友可以參考下2024-06-06Spring Cloud Zuul自定義過(guò)濾器的實(shí)現(xiàn)
這篇文章主要介紹了自定義Spring Cloud Zuul過(guò)濾器的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03以Java代碼的方式總結(jié)幾個(gè)典型的內(nèi)存溢出案例
作為程序員,多多少少都會(huì)遇到一些內(nèi)存溢出的場(chǎng)景,如果你還沒(méi)遇到,說(shuō)明你工作的年限可能比較短,或者你根本就是個(gè)假程序員!哈哈,開(kāi)個(gè)玩笑.今天分享給大家Java內(nèi)存溢出的相關(guān)案例,希望大家在日常工作中,盡量避免寫(xiě)這些low水平的代碼,需要的朋友可以參考下2021-06-06