前言:示例只是做了一个最最基础的上传csv的示例,如果要引用到代码中去,还需要根据自己的业务自行添加一些逻辑处理。

ReadCsvUtil工具类

  1. package com.hanfengyeqiao.gjb.utils;
  2. import java.io.*;
  3. import java.util.*;
  4.  
  5. /**
  6. * csv工具类
  7. */
  8. public class ReadCsvUtil {
  9. private static final String FIX="\uFEFF";
  10. /**
  11. * 获取csv文件内容
  12. * @return 对象list
  13. */
  14. public static List<Map<String,Object>> getResource(byte[] bate) throws IOException {
  15. List<Map<String,Object>> allString = new ArrayList();
  16. Map<String,Object> callLogInfo ;
  17. List<String> list = new ArrayList();
  18. // 获取文件内容
  19. list = getSource(bate);
  20. // 获取文件表头
  21. List<String> title = Arrays.asList(list.get(0).split(","));
  22. String customerName = title.get(0).trim();
  23. String customerNo = title.get(1).trim();
  24. // 头部会带有"\uFEFF"值
  25. if(customerName.startsWith(FIX)){
  26. customerName = customerName.replace(FIX, "");
  27. }
  28. callLogInfo = new HashMap();
  29. callLogInfo.put("param1",customerName);
  30. callLogInfo.put("param2",customerNo);
  31. allString.add(callLogInfo);
  32.  
  33. list.remove(0);
  34. // 循环内容
  35. for(int i = 0; i<list.size();i++){
  36. List<String> content = Arrays.asList(list.get(i).split(","));
  37. // 当没有添加额外参数时
  38. if(content!=null){
  39. callLogInfo = new HashMap();
  40. callLogInfo.put("param1",content.get(0));
  41. callLogInfo.put("param2",content.get(1));
  42. allString.add(callLogInfo);
  43. }
  44. }
  45. return allString;
  46. }
  47.  
  48. /**
  49. * 读文件数据
  50. */
  51. public static List<String> getSource(byte[] bate) throws IOException {
  52. BufferedReader br = null;
  53. ByteArrayInputStream fis=null;
  54. InputStreamReader isr = null;
  55. try {
  56. fis = new ByteArrayInputStream(bate);
  57. //指定以UTF-8编码读入
  58. isr = new InputStreamReader(fis,"UTF-8");
  59. br = new BufferedReader(isr);
  60. } catch (Exception e) {
  61. e.printStackTrace();
  62. }
  63. String line;
  64. String everyLine ;
  65. List<String> allString = new ArrayList<>();
  66. try {
  67. //读取到的内容给line变量
  68. while ((line = br.readLine()) != null){
  69. everyLine = line;
  70. allString.add(everyLine);
  71. }
  72. } catch (IOException e) {
  73. e.printStackTrace();
  74. }finally {
  75. if(fis != null){
  76. fis.close();
  77. }
  78. if(isr != null){
  79. isr.close();
  80. }
  81. }
  82. return allString;
  83. }
  84. }

控制器(这里用的springboot):

  1. package com.hanfengyeqiao.gjb.controller.admin;
  2.  
  3. import com.hanfengyeqiao.gjb.utils.ReadCsvUtil;
  4. import io.swagger.annotations.Api;
  5. import org.springframework.web.bind.annotation.RequestMapping;
  6. import org.springframework.web.bind.annotation.RestController;
  7. import org.springframework.web.multipart.MultipartFile;
  8. import javax.servlet.http.HttpServletRequest;
  9. import java.util.List;
  10. import java.util.Map;
  11.  
  12. @Api(tags = "")
  13. @RestController
  14. @RequestMapping("/admin")
  15. public class AdminCertController {
  16. @RequestMapping("/test/upload")
  17. public void upload(HttpServletRequest request, MultipartFile upfile) throws Exception {
  18. if (request.getMethod().equals("POST")) {
  19. byte[] bate =upfile.getBytes();
  20.  
  21. List<Map<String,Object>> list=ReadCsvUtil.getResource(bate);
  22. if(list!=null){
  23. for(Map<String,Object> m:list){
  24. System.out.println("param1:"+m.get("param1")+";param2:"+m.get("param2")+"。");
  25. }
  26. }
  27. }
  28. }
  29. }

 html代码:

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>test</title>
  6. </head>
  7. <body>
  8.  
  9. <form action="http://localhost:8088/admin/test/upload" method="post" enctype="multipart/form-data">
  10. 上传:<input type="file" name="upfile"/>
  11. <input type="submit" value="提交"/>
  12. </form>
  13.  
  14. </body>
  15. <script type="text/javascript">
  16. </script>
  17. </html>

 示例文件

运行结果:

在处理csv文件的时候容易出现编码上的问题,小伙伴们写代码的时候要多注意一下!!!

java处理csv文件上传示例的更多相关文章

  1. 【原创】用JAVA实现大文件上传及显示进度信息

    用JAVA实现大文件上传及显示进度信息 ---解析HTTP MultiPart协议 (本文提供全部源码下载,请访问 https://github.com/grayprince/UploadBigFil ...

  2. Java FtpClient 实现文件上传服务

    一.Ubuntu 安装 Vsftpd 服务 1.安装 sudo apt-get install vsftpd 2.添加用户(uftp) sudo useradd -d /home/uftp -s /b ...

  3. Java中实现文件上传下载的三种解决方案

    第一点:Java代码实现文件上传 FormFile file=manform.getFile(); String newfileName = null; String newpathname=null ...

  4. Java下载https文件上传到阿里云oss服务器

    Java下载https文件上传到阿里云oss服务器 今天做了一个从Https链接中下载音频并且上传到OSS服务器,记录一下希望大家也少走弯路. 一共两个类: 1 .实现自己的证书信任管理器类 /** ...

  5. 【Java】JavaWeb文件上传和下载

    文件上传和下载在web应用中非常普遍,要在jsp环境中实现文件上传功能是非常容易的,因为网上有许多用java开发的文件上传组件,本文以commons-fileupload组件为例,为jsp应用添加文件 ...

  6. java+web+大文件上传下载

    文件上传是最古老的互联网操作之一,20多年来几乎没有怎么变化,还是操作麻烦.缺乏交互.用户体验差. 一.前端代码 英国程序员Remy Sharp总结了这些新的接口 ,本文在他的基础之上,讨论在前端采用 ...

  7. Java开发系列-文件上传

    概述 Java开发中文件上传的方式有很多,常见的有servlet3.0.common-fileUpload.框架.不管哪种方式,对于文件上传的本质是不变的. 文件上传的准备 文件上传需要客户端跟服务都 ...

  8. HTTP请求中的Body构建——.NET客户端调用JAVA服务进行文件上传

    PS:今日的第二篇,当日事还要当日毕:)   http的POST请求发送的内容在Body中,因此有时候会有我们自己构建body的情况. JAVA使用http—post上传file时,spring框架中 ...

  9. 用JAVA实现大文件上传及显示进度信息

    一. 大文件上传基础描述: 各种WEB框架中,对于浏览器上传文件的请求,都有自己的处理对象负责对Http MultiPart协议内容进行解析,并供开发人员调用请求的表单内容. 比如: Spring 框 ...

随机推荐

  1. WARN: Establishing SSL connection without server’s identity verification is not recommended

    问题 使用Spring JDBC 连接 MySQL时,出现如下警告: WARN: Establishing SSL connection without server's identity verif ...

  2. Hyperledger Fabric——balance transfer(六)查询

    balance transfer 提供了很多查询接口,包括链码查询,根据区块号查询区块数据,根据交易ID查询交易信息,查询链上的区块数,查询已安装或已实例化的链码,查询通道. 源码解析 1.调用链码查 ...

  3. 杨辉三角(hdu2032)——有待完善

    思考:杨辉三角形 #include<stdio.h> #include<cstring> int main() { int n; char d; ][] = {}; while ...

  4. web项目——org.apache.jasper.JasperException: /WEB-INF/content/mainForm.jsp (line: 3, column: 62) File "/WEB-INF/c.tld" not found

    报错信息: HTTP Status 500 – Internal Server Error Type Exception Report Message /WEB-INF/content/mainFor ...

  5. S32DS编译程序出现Type region `SRAM' overflowed by 19240 bytes错误

    用S32DS编译工程遇到Type region `SRAM' overflowed by 19240 bytes错误(芯片为S9KEAZ64AMLH) 程序中未初始化的变量存放SRAM中 当程序出现未 ...

  6. matlab单目相机标定——标定步骤以及参数含义

    参考博客园的一篇文章: https://www.cnblogs.com/flyinggod/p/8470407.html#commentform

  7. jchdl - RTL实例 - MOS6502 Mem

    https://mp.weixin.qq.com/s/ST8q-VWOT47kcYg10-4AQw   实现一个简单的内存模块,匹配MOS6502 CPU使用.   参考链接 https://gith ...

  8. Chisel3 - util - LFSR16

    https://mp.weixin.qq.com/s/DSdb4tmRwDTOki7mbyuu9A     实现16位线性反馈移位寄存器.可用于生成简单的伪随机数.     ​​     ​​   参 ...

  9. Java实现 LeetCode 834 树中距离之和(DFS+分析)

    834. 树中距离之和 给定一个无向.连通的树.树中有 N 个标记为 0-N-1 的节点以及 N-1 条边 . 第 i 条边连接节点 edges[i][0] 和 edges[i][1] . 返回一个表 ...

  10. ASP.NET关于书籍详情和删除的Demo(HttpHandler进行页面静态化[自动生成html网页]+Entity Framework通过类创建数据库+EF删查)

    这次的Demo如标题所示, 首先第一步EF创建数据库 创建两个类,一个是图书类,一个是图书类别的类 using System; using System.Collections.Generic; us ...