欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

在SpringBoot框架下實現(xiàn)Excel導入導出的方法詳解

 更新時間:2023年06月18日 09:43:41   作者:葡萄城技術團隊  
SpringBoot是由Pivotal團隊提供的全新框架,其設計目的是用來簡化新Spring應用的初始搭建以及開發(fā)過程,今天我們就使用純前對按表格控件帶大家了解,如何在Spring Boot框架下實現(xiàn)Excel服務端導入導出,需要的朋友可以參考下

1.IDEA創(chuàng)建SpringBoot項目

1.1 Spring Initializr

想要在IDEA下快速搭建一個SpringBoot項目,可以使用Spring Initializr工具作為腳手架。

進入IDEA后,在左側(cè)菜單中可以找到Plugins,點擊后,在上方的搜索框中輸入Spring Initializr。

之后點擊右上角的綠色Install按鈕進行安裝。

安裝完畢后,在New Project 的時候就會多一個Spring Initializr的選項。

1.2 SpringBoot 項目的創(chuàng)建

Project SDK:根據(jù)實際應用情況選擇用于配置項目所依賴的Java SDK。

Choose Spring Initializr Server:選擇一個Spring Initializr服務器,一般來說都選擇默認的。

GroupId:一般分為多個段,第一段為域,第二段為公司名稱。例如:org.apache,com.grapecity。

ArtifactId:是項目的唯一標識符,在實際開發(fā)中一般對應項目的名稱,就是項目根目錄的名稱。

Group Id,Artfact Id是保證項目唯一性的標識,一般來說如果項目打包上傳至maven這樣的包管理倉庫中。在搜索你的項目時,Group Id,Artfact Id是必要的條件。

Version:版本號,默認0.0.1-SNAPSHOT。SNAPSHOT代表不穩(wěn)定的版本,與之相對的有RELEASE。

Project type:工程的類型,maven工程還是gradle工程。

Language:語言(Java,Kotlin,Groovy)。

Packaging:Jar包還是War包。

Java version:語法版本,與Project SDK不同,Project SDK是實際用到的JDK。Java version指的是語法版本。一般來說語言特性不能比SDK高。比如SDK版本是11,語法選擇8。那么實際項目中只能使用java 8的語法。反之SDK版本是8,語法選11就有問題了。一般情況下都會與SDK保持一致。

Project name:項目名稱

Project description:項目描述

Package name:包名

第三部分根據(jù)項目的實際需求去配置。

第四部分:

設置項目名稱與路徑。

2.前端配置

考慮到導入導出功能需要對Excel具有較高的還原度,這里使用了SpreadJS組件,通過SpreadJS組件的ExcelIO功能,進行Excel的導入與導出。SpreadJS是一款純前端的組件,與后端完全解耦,可以完美的整合到SpringBoot工程中。

2.1 前端頁面創(chuàng)建

在static目錄下建立index.html文件,用來繪制前端頁面。如果用了thymeleaf也可以將文件建立在templates目錄中。

2.2 SpreadJS組件引入和初始化

在header中引入SpreadJS相關的css與js引用。

創(chuàng)建SpreadJS對應的DOM對象。

在JS中初始化SpreadJS和導入導出Excel相關的ExcelIO對象。

通過按鈕點擊進行服務端導入與導出。

導入導出事件處理,在事件中發(fā)送請求與服務端進行連接。

導入原理:

將服務端的文件以文件流的形式傳輸至前端,前端通過ExcelIO將結(jié)果導入結(jié)果呈現(xiàn)值SpreadJS中,所以導入的傳遞的參數(shù)是一個文件路徑。注意該路徑是文件在服務端或者工程中的一個路徑。

導出原理:

通過SpreadJS ExcelIO的功能將內(nèi)容導出成Excel的blob流。之后將blob流傳至服務器端,在服務器端進行保存Excel文件的操作。

3.后端配置

創(chuàng)建后端controller,可按照自身項目的包的層級分類進行創(chuàng)建。

構建服務端的導入導出方法和相關邏輯。

服務器端導入:

由于前端傳入的是一個文件的路徑,所以參數(shù)這里我們需要一個字符串類型的參數(shù)去接收。

另外,我們會將流傳到前端,所以會將流寫到response中,所以參數(shù)中還需要response對象,方法本身不需要返回,返回空即可。原理是通過inputStream讀取文件后,將其寫入response的outputStream中。

導出到服務器:

由于前端傳入傳入的是保存文件的名稱以及文件blob文件流。服務器端需要兩個參數(shù),String用來接收文件名稱,MultipartFile對象用來接收blob文件流。后端接受到文件流之后通過transferTo方法在指定目錄下根軍傳來的fileName轉(zhuǎn)存成新的文件。

4.測試運行

將工程跑起來之后進入主頁面,顯示如下

點擊服務端導入按鈕,從服務器端下載指定的Excel文件并打開。

對該文件進行操作修改并點擊服務端導出的按鈕。

之后我們?nèi)シ掌鞫说膶С雎窂较虏榭?,發(fā)下文件存在,用Excel打開文件后發(fā)現(xiàn),修改后的內(nèi)容健在并且其他內(nèi)容顯示均無問題。

到這里我們就實現(xiàn)了Spring Boot框架下實現(xiàn)Excel服務端導入導出。

以上就是在SpringBoot框架下實現(xiàn)Excel導入導出的方法詳解的詳細內(nèi)容,更多關于SpringBoot Excel導入導出的資料請關注腳本之家其它相關文章!

相關文章

  • SpringBoot中配置多數(shù)據(jù)源的方法詳解

    SpringBoot中配置多數(shù)據(jù)源的方法詳解

    這篇文章主要為大家詳細介紹了SpringBoot中配置多數(shù)據(jù)源的方法的相關知識,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下
    2024-02-02
  • SpringSecurity6.4中一次性令牌登錄(One-Time Token Login)實現(xiàn)

    SpringSecurity6.4中一次性令牌登錄(One-Time Token Login)實現(xiàn)

    Spring Security為一次性令牌認證提供了支持,本文就來介紹一下SpringSecurity6.4中一次性令牌登錄(One-Time Token Login)實現(xiàn),具有一定的參考價值,感興趣的可以了解一下
    2025-03-03
  • k8s部署springboot實現(xiàn)前后端分離項目

    k8s部署springboot實現(xiàn)前后端分離項目

    本文主要介紹了k8s部署springboot實現(xiàn)前后端分離項目,主要包括配置文件、鏡像構建和容器編排等方面,具有一定的參考價值,感興趣的可以了解一下
    2024-01-01
  • SpringBoot讀取外部配置文件的方法

    SpringBoot讀取外部配置文件的方法

    這篇文章主要介紹了SpringBoot讀取外部配置文件的方法,以端口配置為例,本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-02-02
  • SpringBoot利用切面注解及反射實現(xiàn)事件監(jiān)聽功能

    SpringBoot利用切面注解及反射實現(xiàn)事件監(jiān)聽功能

    這篇文章主要介紹了springboot事件監(jiān)聽,通過利用切面、注解、反射實現(xiàn),接下來將對這幾種方式逐一說明,具有很好的參考價值,希望對大家有所幫助
    2022-07-07
  • 在Spring應用中進行單元測試的解析和代碼演示

    在Spring應用中進行單元測試的解析和代碼演示

    在Spring應用中進行單元測試通常涉及到Spring TestContext Framework,它提供了豐富的注解和工具來支持單元測試和集成測試,以下是如何在Spring應用中進行單元測試的詳細解析和代碼演示,需要的朋友可以參考下
    2024-06-06
  • Java中Stream流Map分組方式詳細匯總

    Java中Stream流Map分組方式詳細匯總

    Stream將要處理的元素集合看作一種流,在流的過程中借助Stream?API對流中的元素進行操作,比如篩選、排序、聚合等,下面這篇文章主要給大家介紹了關于Java中Stream流Map分組方式的相關資料,需要的朋友可以參考下
    2024-01-01
  • Spring Cloud Zuul自定義過濾器的實現(xiàn)

    Spring Cloud Zuul自定義過濾器的實現(xiàn)

    這篇文章主要介紹了自定義Spring Cloud Zuul過濾器的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-03-03
  • Mybatis-Plus?CRUD操作方法

    Mybatis-Plus?CRUD操作方法

    通用?Service?CRUD?封裝?IService?接口,進一步封裝?CRUD?采用?get?查詢、remove?刪除?、list?查詢集合、page?分頁的前綴命名方式區(qū)分?Mapper?層避免混淆,這篇文章主要介紹了Mybatis-Plus?CRUD的相關知識,需要的朋友可以參考下
    2023-10-10
  • 以Java代碼的方式總結(jié)幾個典型的內(nèi)存溢出案例

    以Java代碼的方式總結(jié)幾個典型的內(nèi)存溢出案例

    作為程序員,多多少少都會遇到一些內(nèi)存溢出的場景,如果你還沒遇到,說明你工作的年限可能比較短,或者你根本就是個假程序員!哈哈,開個玩笑.今天分享給大家Java內(nèi)存溢出的相關案例,希望大家在日常工作中,盡量避免寫這些low水平的代碼,需要的朋友可以參考下
    2021-06-06

最新評論