配置maven依赖读取excel
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi</artifactId>
<version>3.15</version>
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>3.15</version>
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml-schemas</artifactId>
<version>3.15</version>
</dependency>
yml 配置阿里oss
#oss
aliyun_oss_endPoint: https://oss-cn-shanghai.aliyuncs.com
aliyun_oss_ak: xxxxxxxxxx
aliyun_oss_sk: xxxxxxxxxx
aliyun_oss_bucketName: xxxxxxxxxx
aliyun_oss_folder: xxx/
oss上传工具类
@Component
@PropertySource("classpath:application-${spring.profiles.active}.yml")
@Slf4j
public class AliYunOSSClientUtil {
@Value("${aliyun_oss_ak}")
public String ak = "LTAI4Fh7ZhAzUeapAHCydamS";
@Value("${aliyun_oss_sk}")
public String sk = "J20qeghKlyAFrcoFVtqULjGG3GTIpf";
@Value("${aliyun_oss_endPoint}")
public String endPoint;
@Value("${aliyun_oss_bucketName}")
public String bucketName;
@Value("${aliyun_oss_folder}")
public String folder;
private OSSClient ossClient;
/**
* 初始化
*/
@PostConstruct
public void init() {
ossClient = new OSSClient(endPoint, ak, sk);
}
/**
* 创建存储空间
* @param ossClient OSS连接
* @param bucketName 存储空间
* @return
*/
public String createBucketName(OSSClient ossClient, String bucketName){
//存储空间
final String bucketNames=bucketName;
if(!ossClient.doesBucketExist(bucketName)){
//创建存储空间
Bucket bucket=ossClient.createBucket(bucketName);
log.info("创建存储空间成功");
return bucket.getName();
}
return bucketNames;
}
/**
* 删除存储空间buckName
* @param ossClient oss对象
* @param bucketName 存储空间
*/
public void deleteBucket(OSSClient ossClient, String bucketName){
ossClient.deleteBucket(bucketName);
log.info("删除" + bucketName + "Bucket成功");
}
/**
* 创建模拟文件夹
* @param ossClient oss连接
* @param bucketName 存储空间
* @param folder 模拟文件夹名如"qj_nanjing/"
* @return 文件夹名
*/
public String createFolder(OSSClient ossClient, String bucketName, String folder){
//文件夹名
final String keySuffixWithSlash =folder;
//判断文件夹是否存在,不存在则创建
if(!ossClient.doesObjectExist(bucketName, keySuffixWithSlash)){
//创建文件夹
ossClient.putObject(bucketName, keySuffixWithSlash, new ByteArrayInputStream(new byte[0]));
log.info("创建文件夹成功");
//得到文件夹名
OSSObject object = ossClient.getObject(bucketName, keySuffixWithSlash);
String fileDir=object.getKey();
return fileDir;
}
return keySuffixWithSlash;
}
/**
* 根据key删除OSS服务器上的文件
* @param ossClient oss连接
* @param bucketName 存储空间
* @param folder 模拟文件夹名 如"qj_nanjing/"
* @param key Bucket下的文件的路径名+文件名 如:"upload/cake.jpg"
*/
public void deleteFile(OSSClient ossClient, String bucketName, String folder, String key){
ossClient.deleteObject(bucketName, folder + key);
log.info("删除" + bucketName + "下的文件" + folder + key + "成功");
}
public String uploadImgOss(MultipartFile file, String fileName) throws Exception {
log.info("图片大小为:"+ file.getSize());
if (file.getSize() > 8 * 1024 * 1024) {
throw new UploadImgException("上传图片大小不能超过8M!");
}
String originalFilename = file.getOriginalFilename();
String substring = originalFilename.substring(originalFilename.lastIndexOf(".")).toLowerCase();
String name = fileName + substring;
try {
InputStream inputStream = file.getInputStream();
this.uploadFile2OSS(inputStream, name);
return name;
} catch (Exception e) {
throw new Exception("图片上传失败");
}
}
/**
* 上传到OSS服务器 如果同名文件会覆盖服务器上的
*
* @param instream
* 文件流
* @param fileName
* 文件名称 包括后缀名
* @return 出错返回"" ,唯一MD5数字签名
*/
public String uploadFile2OSS(InputStream instream, String fileName) {
String ret = "";
try {
// 创建上传Object的Metadata
ObjectMetadata objectMetadata = new ObjectMetadata();
objectMetadata.setContentLength(instream.available());
objectMetadata.setCacheControl("max-age="+24*60*60);
objectMetadata.setHeader("Pragma", "no-cache");
objectMetadata.setContentType(getContentType(fileName.substring(fileName.lastIndexOf("."))));
objectMetadata.setContentDisposition("inline;filename=" + fileName);
// 上传文件
PutObjectResult putResult = ossClient.putObject(bucketName, folder + fileName, instream, objectMetadata);
ret = putResult.getETag();
} catch (IOException e) {
log.error(e.getMessage(), e);
} finally {
try {
if (instream != null) {
instream.close();
}
} catch (IOException e) {
e.printStackTrace();
}
}
return ret;
}
/**
* 上传图片至OSS
* @param file 上传文件(文件全路径如:D:\\image\\cake.jpg)
* @return String 返回的唯一MD5数字签名
* */
public String uploadObject2OSS(MultipartFile file) {
String resultStr = null;
try {
//以输入流的形式上传文件
InputStream is = file.getInputStream();
//文件名
String fileName = file.getName();
//文件大小
//创建上传Object的Metadata
ObjectMetadata metadata = new ObjectMetadata();
//上传的文件的长度
metadata.setContentLength(is.available());
//指定该Object被下载时的网页的缓存行为
metadata.setCacheControl("no-cache");
//指定该Object下设置Header
metadata.setHeader("Pragma", "no-cache");
//指定该Object被下载时的内容编码格式
metadata.setContentEncoding("utf-8");
//文件的MIME,定义文件的类型及网页编码,决定浏览器将以什么形式、什么编码读取文件。如果用户没有指定则根据Key或文件名的扩展名生成,
//如果没有扩展名则填默认值application/octet-stream
metadata.setContentType(getContentType(fileName));
//上传文件 (上传文件流的形式)
PutObjectResult putResult = ossClient.putObject(bucketName, folder + fileName, is, metadata);
//解析结果
resultStr = putResult.getETag();
} catch (Exception e) {
e.printStackTrace();
log.error("上传阿里云OSS服务器异常." + e.getMessage(), e);
}
return resultStr;
}
/**
* 通过文件名判断并获取OSS服务文件上传时文件的contentType
* @param fileName 文件名
* @return 文件的contentType
*/
public String getContentType(String fileName){
//文件的后缀名
String fileExtension = fileName.substring(fileName.lastIndexOf("."));
if(".bmp".equalsIgnoreCase(fileExtension)) {
return "image/bmp";
}
if(".gif".equalsIgnoreCase(fileExtension)) {
return "image/gif";
}
if(".jpeg".equalsIgnoreCase(fileExtension) || ".jpg".equalsIgnoreCase(fileExtension) || ".png".equalsIgnoreCase(fileExtension) ) {
return "image/jpeg";
}
if(".html".equalsIgnoreCase(fileExtension)) {
return "text/html";
}
if(".txt".equalsIgnoreCase(fileExtension)) {
return "text/plain";
}
if(".vsd".equalsIgnoreCase(fileExtension)) {
return "application/vnd.visio";
}
if(".ppt".equalsIgnoreCase(fileExtension) || "pptx".equalsIgnoreCase(fileExtension)) {
return "application/vnd.ms-powerpoint";
}
if(".doc".equalsIgnoreCase(fileExtension) || "docx".equalsIgnoreCase(fileExtension)) {
return "application/msword";
}
if(".xml".equalsIgnoreCase(fileExtension)) {
return "text/xml";
}
//默认返回类型
return "image/jpeg";
}
/**
* 获得图片路径
*
* @param fileUrl
* @return
*/
public String getImgUrl(String fileUrl) {
System.out.println(fileUrl);
if (!StringUtil.isEmpty(fileUrl)) {
String[] split = fileUrl.split("/");
return this.getUrl(this.folder + split[split.length - 1]);
}
return null;
}
/**
* 获得url链接
*
* @param key
* @return
*/
public String getUrl(String key) {
// 设置URL过期时间为10年 3600l* 1000*24*365*10
Date expiration = new Date(System.currentTimeMillis() + 3600L * 1000 * 24 * 365 * 10);
// 生成URL
URL url = ossClient.generatePresignedUrl(bucketName, key, expiration);
if (url != null) {
return url.toString();
}
return null;
}
}
读取excel上传oss测试类
/**
* @author by will
* @Classname ImageFromNetWork
* @Description TODO
* @Date 2022/6/30 13:38
*/
@RunWith(SpringRunner.class)
@SpringBootTest(classes = CmsApplication.class)
public class ImageFromNetWork {
@Resource
private AliYunOSSClientUtil aliYunOSSClientUtil;
@Test
public void test12312312() throws IOException {
FileInputStream fileInputStream = new FileInputStream("D:\\img\\excel\\tu.xlsx");//开启文件读取流
XSSFWorkbook sheets = new XSSFWorkbook(fileInputStream);//读取文件
//获取sheet
XSSFSheet sheet = sheets.getSheetAt(0);
//获取行数
int rows = sheet.getPhysicalNumberOfRows();
for(int i=0;i<rows;i++){
//获取列数
XSSFRow row = sheet.getRow(i);
XSSFCell cell = row.getCell((short) 0);
String url =cell.getStringCellValue();
System.out.println(url);
String name = url.substring(url.lastIndexOf("/")+1,url.length()).replace("tims_uat","");
System.out.println(name);
String filePath = "D:\\img\\"+name;
String pash1 = url.substring(0,url.lastIndexOf("/")+1)+URLEncoder.encode(url.substring(url.lastIndexOf("/")+1,url.length()));
System.out.println(pash1);
writeImageToDisk(getImageFromNetByUrl(pash1),filePath);
File file = new File(filePath);
String s = aliYunOSSClientUtil.uploadFile2OSS(new FileInputStream(file), name);
System.out.println(s);
}
}
/**
* 将获取的字节数组保存为文件写入硬盘
*
* @param data
* @param fileName
*/
public static void writeImageToDisk(byte[] data, String fileName) {
try {
File file = new File(fileName); // 本地目录
File fileParent = file.getParentFile();
if (!fileParent.exists()) {
fileParent.mkdirs();
file.createNewFile();
}
FileOutputStream fops = new FileOutputStream(file);
fops.write(data);
fops.flush();
fops.close();
} catch (Exception e) {
e.printStackTrace();
}
}
/**
* 获取远程http地址视图片
*
* @param strUrl
* @return
*/
public static byte[] getImageFromNetByUrl(String strUrl) {
try {
URL url = new URL(strUrl);
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
conn.setRequestMethod("GET");
conn.setConnectTimeout(5 * 1000);
InputStream inStream = conn.getInputStream();
byte[] btData = readInputStream(inStream);
return btData;
}catch (FileNotFoundException e) {
System.out.println("文件没找到:"+strUrl);
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
/**
* 读取流
*
* @param inStream
* @return
* @throws Exception
*/
public static byte[] readInputStream(InputStream inStream) throws Exception {
ByteArrayOutputStream outStream = new ByteArrayOutputStream();
byte[] buffer = new byte[1024];
int len = 0;
while ((len = inStream.read(buffer)) != -1) {
outStream.write(buffer, 0, len);
}
inStream.close();
return outStream.toByteArray();
}
}