亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Java+EasyExcel實(shí)現(xiàn)文件上傳功能

 更新時(shí)間:2023年02月24日 14:33:55   作者:糊涂涂是個(gè)小盆友  
這篇文章主要為大家詳細(xì)介紹了如何通過Java和EasyExcel實(shí)現(xiàn)文件上傳功能,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下

需求描述

頁(yè)面中當(dāng)用戶將excel表格上傳到服務(wù)器后,將該excel文件保存在本地然后在服務(wù)器中將excel中的數(shù)據(jù)讀取出來然后存入數(shù)據(jù)庫(kù)

實(shí)現(xiàn)

0、依賴

<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>easyexcel</artifactId>
    <version>3.1.4</version>
</dependency>
<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>fastjson</artifactId>
    <version>1.2.75</version>
</dependency>
 <!-- 糊涂工具類-->
<dependency>
    <groupId>cn.hutool</groupId>
    <artifactId>hutool-all</artifactId>
    <version>5.8.11</version>
</dependency>

1、編寫配置類

文件上傳的路徑:用戶傳來的文件存放在哪

  # 文件上傳
spring:
  servlet:
    multipart:
      max-file-size: 5MB
      max-request-size: 50MB

???????## 文件上傳路徑
savepath: C:\Users\86186\Desktop\pp

2、文件上傳工具類

文件上傳時(shí)需要使用到的一些方法

/**
 * 文件上傳的工具類
 */
public class FileUploadUtil {
    /**
     * 得到filename文件名的后綴名
     * @param filename  文件名
     *                 aasdsad.jpg asaa.gif
     * @return
     */
    public static String getFileSuffix(String filename){
        if(filename == null || filename.isEmpty()){
            throw new RuntimeException("文件名不能為空,filename:"+filename);
        }
        return filename.substring(filename.lastIndexOf("."));
    }

    /**
     * 使用UUID生成一個(gè)唯一的字符串
     * @return
     */
    public static String randomFilename(){
        return UUID.randomUUID().toString().replaceAll("-","");
    }

    /**
     * 基于時(shí)間戳生成文件名
     * @return
     */
    public static String randomFilename2(){
        return System.currentTimeMillis()+"";
    }
    /**
     * 基于時(shí)間戳 + UUID生成文件名
     * @return
     */
    public static String randomFilename3(){
        return System.currentTimeMillis()+randomFilename();
    }


    /**
     * 創(chuàng)建目錄
     */
    public static void mkdir(String path){
        File file = new  File(path);
        if(!file.exists()){ //不存在
            file.mkdirs();
        }
    }

    /**
     * 基于當(dāng)前時(shí)間創(chuàng)建文件名
     */
    public static String getTimeFilename(){
        SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyy-MM-dd-HH-mm-ss");
        Date date = new Date(System.currentTimeMillis());
        return simpleDateFormat.format(date)+"-"+randomFilename2();
    }
}

3、編寫Controller

需要接受前端返回回來的文件

/**
    * excel文件導(dǎo)入進(jìn)數(shù)據(jù)庫(kù)中
    * @param file
    * @return
    */
   @Autowired
   private FileUploadService fileUploadService;

   @PostMapping("excelImport")
   public ResponseData excelImport(MultipartFile file) throws Exception {
   		// 由于easyExcel所以需要傳入fileUploadService對(duì)象
       String upload = fileUploadService.upload(file,fileUploadService);
       return ResponseDataUtil.buildOk(upload);
   }

4、編寫Service

@Service("fileUploadService")
@Slf4j
public class FileUploadServiceImpl implements FileUploadService {
	// 注入environment來獲取在配置文件中文件保存的路徑
    @Autowired
    private Environment environment;
    // 注入數(shù)據(jù)層的對(duì)象
    @Autowired
    private productMapper productMapper;

    @Override
    public String upload(MultipartFile file, FileUploadService fileUploadService) throws Exception {
        if (file == null) {
            throw new Exception("文件不可以為空");
        }
        //得到上傳的保存路徑
        String savePath = environment.getProperty("savepath");
        //創(chuàng)建目錄
        FileUploadUtil.mkdir(savePath);
        String dbPath = "";

        //得到上傳的原文件名
        String originalFilename = file.getOriginalFilename();
        String suffix = FileUploadUtil.getFileSuffix(originalFilename);
        String filename = FileUploadUtil.getTimeFilename() + suffix;
        dbPath += filename;
        //保存
        file.transferTo(new File(savePath, filename));
        dbPath = savePath +"\\"+ dbPath;

        //調(diào)用方法進(jìn)行讀取
        EasyExcel.read(dbPath, ExcelDTO.class, new PageReadListener<ExcelDTO>(dataList -> {
            for (ExcelDTO demoData : dataList) {
                log.info("讀取到一條數(shù)據(jù){}", JSON.toJSONString(demoData));
                insert(demoData);
            }
        })).sheet().doRead();

        return dbPath;
    }

	// 插入數(shù)據(jù)到數(shù)據(jù)庫(kù)中
    @Override
    public void insert(ExcelDTO excelDTO) {
    	// 使用hutool工具類將excelDTO類轉(zhuǎn)換成product類,因?yàn)閜roduct類對(duì)應(yīng)的是數(shù)據(jù)庫(kù)中的字段
        Product product = BeanUtil.copyProperties(excelDTO, Product.class);
        productMapper.insert(product);
    }

}

5、編寫excel對(duì)應(yīng)的類

@Data
public class ExcelDTO {
   @ExcelProperty("藥品名稱")
   private String pname;
   @ExcelProperty("藥品價(jià)格")
   private BigDecimal pprice;
   @ExcelProperty("藥品數(shù)量")
   private String pcount;
   @ExcelProperty("藥品描述")
   private String pdes;
   @ExcelProperty("藥品類別")
   private Integer ptype;
}

6、創(chuàng)建easyExcel的監(jiān)聽器

ExcelDTO = excel對(duì)應(yīng)的類

fileUploadService = service對(duì)象

@Slf4j
@Component
public class DataListener extends AnalysisEventListener<ExcelDTO> {

    public FileUploadService fileUploadService;

    public  DataListener(FileUploadService fileUploadService) {
        this.fileUploadService = fileUploadService;
    }

    public  DataListener() {
    }

    //讀取excel內(nèi)容,一行一行讀取
    @Override
    public void invoke(ExcelDTO excelDTO, AnalysisContext analysisContext) {
        if (excelDTO == null) {
            try {
                throw new Exception("文件數(shù)據(jù)為空");
            } catch (Exception e) {
                e.printStackTrace();
            }
        }

    }
    @Override
    public void doAfterAllAnalysed(AnalysisContext analysisContext) {

    }
}

7、最終效果

以上就是Java+EasyExcel實(shí)現(xiàn)文件上傳功能的詳細(xì)內(nèi)容,更多關(guān)于Java EasyExcel文件上傳的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Android中Parcelable的作用實(shí)例解析

    Android中Parcelable的作用實(shí)例解析

    這篇文章主要介紹了Android中Parcelable的作用,對(duì)于Android初學(xué)者有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2014-08-08
  • 詳解SpringBoot結(jié)合策略模式實(shí)戰(zhàn)套路

    詳解SpringBoot結(jié)合策略模式實(shí)戰(zhàn)套路

    這篇文章主要介紹了詳解SpringBoot結(jié)合策略模式實(shí)戰(zhàn)套路,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • Jenkins遷移job插件Job Import Plugin流程詳解

    Jenkins遷移job插件Job Import Plugin流程詳解

    這篇文章主要介紹了Jenkins遷移job插件Job Import Plugin流程詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-08-08
  • IDEA強(qiáng)制清除Maven緩存的實(shí)現(xiàn)示例

    IDEA強(qiáng)制清除Maven緩存的實(shí)現(xiàn)示例

    清除項(xiàng)目緩存是一個(gè)常見的操作,本文主要介紹了IDEA強(qiáng)制清除Maven緩存的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-07-07
  • 微信公眾號(hào)支付(一)如何獲取用戶openId

    微信公眾號(hào)支付(一)如何獲取用戶openId

    本篇文章給大家介紹微信公眾號(hào)支付如何獲取用戶openid,需要授權(quán)回調(diào)頁(yè)面域名等一系列途徑實(shí)現(xiàn)此功能,需要的朋友可以參考下
    2015-09-09
  • Java中使用HashMap時(shí)指定初始化容量性能解析

    Java中使用HashMap時(shí)指定初始化容量性能解析

    這篇文章主要為大家介紹了Java中使用HashMap時(shí)指定初始化容量性能解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-02-02
  • Java實(shí)現(xiàn)分解任意輸入數(shù)的質(zhì)因數(shù)算法示例

    Java實(shí)現(xiàn)分解任意輸入數(shù)的質(zhì)因數(shù)算法示例

    這篇文章主要介紹了Java實(shí)現(xiàn)分解任意輸入數(shù)的質(zhì)因數(shù)算法,涉及java數(shù)學(xué)運(yùn)算相關(guān)操作技巧,需要的朋友可以參考下
    2017-10-10
  • 使用SpringMVC響應(yīng)json格式返回的結(jié)果類型

    使用SpringMVC響應(yīng)json格式返回的結(jié)果類型

    這篇文章主要介紹了使用SpringMVC響應(yīng)json格式返回的結(jié)果類型,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • Java實(shí)現(xiàn)在線SQL編程最新完整版

    Java實(shí)現(xiàn)在線SQL編程最新完整版

    這篇文章主要介紹了Java實(shí)現(xiàn)在線SQL編程,在使用JDBC來進(jìn)行數(shù)據(jù)庫(kù)的操作,在使用時(shí)由于對(duì)其方法并不是全部了解,所以需要邊看源碼邊改善功能,感興趣的朋友跟隨小編一起看看吧
    2022-06-06
  • SpringCloudAlibaba Nacos開啟鑒權(quán)解決跳過登錄頁(yè)面問題

    SpringCloudAlibaba Nacos開啟鑒權(quán)解決跳過登錄頁(yè)面問題

    對(duì)于Nacos,如果需要開啟權(quán)限控制,可以在 Nacos 控制臺(tái)上進(jìn)行配置,本文主要介紹了SpringCloudAlibaba Nacos開啟鑒權(quán)解決跳過登錄頁(yè)面問題,感興趣的可以了解一下
    2023-10-10

最新評(píng)論