package com.lf.server.service.all;
|
|
import com.alibaba.fastjson.JSON;
|
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
import com.lf.server.controller.all.BaseController;
|
import com.lf.server.entity.all.*;
|
import com.lf.server.entity.ctrl.KeyValueEntity;
|
import com.lf.server.entity.data.MetaEntity;
|
import com.lf.server.entity.data.MetaFileEntity;
|
import com.lf.server.entity.sys.AttachEntity;
|
import com.lf.server.entity.sys.UserEntity;
|
import com.lf.server.helper.*;
|
import com.lf.server.mapper.all.BasicMapper;
|
import com.lf.server.service.sys.AttachService;
|
import org.apache.commons.logging.Log;
|
import org.apache.commons.logging.LogFactory;
|
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.stereotype.Service;
|
import org.springframework.web.multipart.MultipartFile;
|
|
import javax.servlet.http.HttpServletResponse;
|
import java.io.File;
|
import java.lang.reflect.Field;
|
import java.util.ArrayList;
|
import java.util.HashMap;
|
import java.util.List;
|
import java.util.Map;
|
|
/**
|
* 上传附件服务类
|
* @author WWW
|
*/
|
@Service
|
public class UploadAttachService {
|
@Autowired
|
PathHelper pathHelper;
|
|
@Autowired
|
AttachService attachService;
|
|
private static String tabs = "''";
|
|
private final static Map<String, String> ATTACH_TABS = new HashMap<>();
|
|
private final static Log log = LogFactory.getLog(UploadAttachService.class);
|
|
/**
|
* 获取表名
|
*/
|
public static String getTabs() {
|
return tabs;
|
}
|
|
/**
|
* 初始化附件表
|
*/
|
public static void init(String cfg) {
|
if (StringHelper.isEmpty(cfg)) {
|
return;
|
}
|
|
String[] strs = cfg.split(StaticData.COMMA);
|
if (strs.length == 0) {
|
return;
|
}
|
|
List<String> keys = new ArrayList<>();
|
for (String str : strs) {
|
if (ATTACH_TABS.containsKey(str)) {
|
continue;
|
}
|
|
ATTACH_TABS.put(str, str.contains("bd.") ? "materiname" : "photono");
|
keys.add("'" + str + "'");
|
}
|
tabs = StringHelper.join(keys, ",");
|
}
|
|
/**
|
* 上传文件
|
*/
|
public ResponseMsg<String> upload(UserEntity ue, String tab, MultipartFile file, BaseController ctrl) {
|
try {
|
if (file == null && file.isEmpty()) {
|
return ctrl.fail("文件上传为空", null);
|
}
|
if (file.getSize() > SettingData.MAX_FILE_SIZE) {
|
return ctrl.fail(String.format("文件大于 %d MB", SettingData.MAX_FILE_SIZE / 1024 / 1024), null);
|
}
|
|
// 传输文件
|
String oldName = file.getOriginalFilename();
|
String filePath = pathHelper.getTempPath() + File.separator + oldName;
|
File newFile = new File(filePath);
|
file.transferTo(newFile);
|
double sizes = FileHelper.sizeToMb(file.getSize());
|
|
// 获取MD5
|
String md5 = FileHelper.getFileMd5(filePath);
|
AttachEntity entity = attachService.selectByGuid(md5);
|
if (entity != null) {
|
newFile.delete();
|
return ctrl.success("文件已存在", md5);
|
}
|
|
AttachEntity ae = getAttachEntity(ue, tab, oldName, md5, sizes);
|
String targetPath = pathHelper.getConfig().getUploadPath() + File.separator + ae.getPath();
|
newFile.renameTo(new File(targetPath));
|
|
int rows = attachService.insert(ae);
|
|
return rows > 0 ? ctrl.success(md5) : ctrl.fail("保存文件失败", null);
|
} catch (Exception ex) {
|
return ctrl.fail(ex.getMessage(), null);
|
}
|
}
|
|
/**
|
* 获取附件实体类
|
*/
|
protected AttachEntity getAttachEntity(UserEntity ue, String tab, String oldName, String md5, double sizes) {
|
AttachEntity entity = new AttachEntity();
|
entity.setName(oldName);
|
entity.setTab(tab);
|
entity.setGuid(md5);
|
String subPath = PathHelper.getUploadPath() + File.separator + md5 + FileHelper.getExtension(oldName);
|
entity.setPath(subPath);
|
entity.setSizes(sizes);
|
if (ue != null) {
|
entity.setCreateUser(ue.getId());
|
}
|
|
return entity;
|
}
|
|
/**
|
* 下载文件
|
*/
|
public void download(String guid, HttpServletResponse res) {
|
download(guid, false, res);
|
}
|
|
/**
|
* 下载文件
|
*/
|
public void download(String guid, boolean inline, HttpServletResponse res) {
|
try {
|
if (StringHelper.isEmpty(guid)) {
|
WebHelper.writeStr2Page(res, StaticData.NO_FILE);
|
return;
|
}
|
|
AttachEntity entity = attachService.selectByGuid(guid);
|
if (entity == null) {
|
WebHelper.writeStr2Page(res, StaticData.NO_FILE);
|
return;
|
}
|
|
String filePath = pathHelper.getConfig().getUploadPath() + File.separator + entity.getPath();
|
File file = new File(filePath);
|
if (!file.exists() || file.isDirectory()) {
|
WebHelper.writeJson2Page(res, "文件不存在");
|
}
|
|
WebHelper.download(filePath, entity.getName(), inline, res);
|
} catch (Exception ex) {
|
WebHelper.writeJson2Page(res, "文件下载出错");
|
log.error(ex.getMessage(), ex);
|
}
|
}
|
|
/**
|
* 上传Excel附件
|
*/
|
public List<KeyValueEntity> uploadXlsAnnex(UserEntity ue, List<MetaEntity> ms, List<MetaFileEntity> list, String path) {
|
List<String> files = getAttachFiles(list, path);
|
if (files.size() == 0) {
|
return null;
|
}
|
|
List<KeyValueEntity> rs = new ArrayList<>();
|
for (MetaEntity meta : ms) {
|
int rows = uploadXlsAnnex(ue, meta, files);
|
rs.add(new KeyValueEntity(meta.getName(), String.valueOf(rows)));
|
}
|
|
return rs;
|
}
|
|
/**
|
* 获取附件文件
|
*/
|
private List<String> getAttachFiles(List<MetaFileEntity> list, String path) {
|
List<String> files = new ArrayList<>();
|
|
for (MetaFileEntity mf : list) {
|
if (mf.getName().contains(StaticData.ZIP)) {
|
List<String> subs = getZipFiles(mf, path);
|
if (null != subs && subs.size() > 0) {
|
files.addAll(subs);
|
}
|
continue;
|
}
|
|
files.add(mf.getPath());
|
}
|
|
return files;
|
}
|
|
/**
|
* 获取zip中的文件
|
*/
|
private List<String> getZipFiles(MetaFileEntity mf, String path) {
|
File file = new File(mf.getPath());
|
if (!file.exists() || file.isDirectory()) {
|
return null;
|
}
|
|
File zipFolder = new File(pathHelper.getConfig().getTempPath() + File.separator + path + "_zip");
|
if (!zipFolder.exists() || !zipFolder.isDirectory()) {
|
zipFolder.mkdirs();
|
}
|
|
String subPath = zipFolder + File.separator + mf.getName().toLowerCase().replace(".zip", "");
|
ZipHelper.unzip(mf.getPath(), subPath);
|
|
List<String> files = new ArrayList<>();
|
getFilesByPath(files, subPath);
|
|
return files;
|
}
|
|
/**
|
* 根据路径获取文件
|
*/
|
private void getFilesByPath(List<String> list, String path) {
|
File file = new File(path);
|
if (!file.isDirectory()) {
|
list.add(file.getPath());
|
return;
|
}
|
|
File[] files = file.listFiles();
|
if (null == files) {
|
return;
|
}
|
|
for (File f : files) {
|
if (f.isDirectory()) {
|
getFilesByPath(list, f.getPath());
|
} else {
|
list.add(f.getPath());
|
}
|
}
|
}
|
|
/**
|
* 上传Excel附件
|
*/
|
private int uploadXlsAnnex(UserEntity ue, MetaEntity meta, List<String> files) {
|
List<?> list = queryXlsData(meta);
|
if (null == list || list.size() == 0) {
|
return 0;
|
}
|
|
Field field = getAnnexField(list.get(0), meta);
|
String folder = meta.getName().split("\\.")[0].trim().toLowerCase() + File.separator;
|
|
int rows = 0;
|
for (Object obj : list) {
|
String name = getAnnexName(obj, field);
|
if (StringHelper.isEmpty(name)) {
|
continue;
|
}
|
|
String file = findAnnexFile(name, folder, files);
|
if (null == file) {
|
continue;
|
}
|
|
BaseEntity be = (BaseEntity) obj;
|
rows += insertXlsAnnex(ue, meta, be, file);
|
files.remove(file);
|
}
|
|
return rows;
|
}
|
|
/**
|
* 查询Excel数据
|
*/
|
private List<?> queryXlsData(MetaEntity meta) {
|
String entity = meta.getTab().substring(meta.getTab().indexOf(".") + 1).replace("_", "").toLowerCase();
|
BasicMapper basicMapper = ClassHelper.getBasicMapper(entity);
|
if (null == basicMapper) {
|
return null;
|
}
|
|
QueryWrapper wrapper = new QueryWrapper();
|
wrapper.eq("parentid", meta.getEventid());
|
|
List<?> list = basicMapper.selectList(wrapper);
|
if (null == list || list.size() == 0) {
|
return null;
|
}
|
if (!(list.get(0) instanceof BaseEntity)) {
|
return null;
|
}
|
|
return list;
|
}
|
|
/**
|
* 获取附件字段
|
*/
|
private Field getAnnexField(Object obj, MetaEntity meta) {
|
try {
|
String str = ATTACH_TABS.get(meta.getTab());
|
|
Field field = obj.getClass().getDeclaredField(str);
|
field.setAccessible(true);
|
|
return field;
|
} catch (Exception ex) {
|
return null;
|
}
|
}
|
|
/**
|
* 获取附件名称
|
*/
|
private String getAnnexName(Object obj, Field field) {
|
try {
|
Object val = field.get(obj);
|
|
return null == val ? null : val.toString().trim();
|
} catch (Exception ex) {
|
return null;
|
}
|
}
|
|
/**
|
* 查找附件文件
|
*/
|
private String findAnnexFile(String name, String folder, List<String> files) {
|
name = File.separator + name.split("\\.")[0].trim().toLowerCase();
|
for (String file : files) {
|
if (file.toLowerCase().contains(folder) && file.toLowerCase().contains(name)) {
|
return file;
|
}
|
}
|
for (String file : files) {
|
if (file.toLowerCase().contains(name)) {
|
return file;
|
}
|
}
|
|
return null;
|
}
|
|
/**
|
* 插入Excel附件
|
*/
|
private int insertXlsAnnex(UserEntity ue, MetaEntity meta, BaseEntity be, String file) {
|
File f = new File(file);
|
if (!f.exists() || f.isDirectory()) {
|
return 0;
|
}
|
|
String md5 = FileHelper.getFileMd5(file);
|
AttachEntity old = attachService.selectByTabAndGuid(meta.getTab(), be.getEventid(), md5);
|
if (null != old) {
|
f.delete();
|
return 0;
|
}
|
|
String fileName = FileHelper.getFileName(file);
|
double sizes = FileHelper.sizeToMb(f.length());
|
|
AttachEntity ae = getAttachEntity(ue, meta.getTab(), be.getEventid(), fileName, md5, sizes);
|
String targetPath = pathHelper.getConfig().getUploadPath() + File.separator + ae.getPath();
|
|
f.renameTo(new File(targetPath));
|
int rows = attachService.insert(ae);
|
|
return rows > 0 ? 1 : 0;
|
}
|
|
/**
|
* 获取附件实体类
|
*/
|
protected AttachEntity getAttachEntity(UserEntity ue, String tabName, String eventid, String fileName, String md5, double sizes) {
|
AttachEntity entity = new AttachEntity();
|
entity.setTab(tabName);
|
entity.setTabGuid(eventid);
|
entity.setName(fileName);
|
entity.setGuid(md5);
|
String subPath = PathHelper.getUploadPath() + File.separator + md5 + FileHelper.getExtension(fileName);
|
entity.setPath(subPath);
|
entity.setSizes(sizes);
|
if (ue != null) {
|
entity.setCreateUser(ue.getId());
|
}
|
|
return entity;
|
}
|
}
|