1.7 KiB
1.7 KiB
项目异步文件上传功能
数据库
- 文件上传记录表:记录项目下所有文件的上传记录。项目id,流水分析平台的项目id,文件id,文件名称,文件大小,文件状态(上传中、解析中、解析成功、解析失败),主体名称,主体账号,上传时间,上传人
流程
- 在项目详情的上传数据页面,点击流水导入的上传流水按钮
- 批量选择文件,点击确认
- 每个文件都需要调接口传输到流水分析平台。建一个线程池,然后每个文件一个线程进行异步处理。处理流程如下
- 在文件上传表中插入一条该文件的记录,关联文件与项目和保存文件参数,此时文件状态为上传中
- 调用流水分析平台的上传文件接口,获取返回参数中的logId,将状态更新为解析中并更新数据库
- 轮询调用判断文件是否解析结束接口,间隔2秒,如果parsing为true继续,如果为false或者轮询达到300次则结束
- 调用文件上传后获取单个文件上传后的状态接口,status等于-5且uploadStatusDesc等于data.wait.confirm.newaccount表示文件上传后解析成功,从返回值中获取enterpriseNameList更新到主体名称,accountNoList更新到主体账号,文件状态更新为解析成功;反之将文件状态更新为解析失败
- 解析成功后,轮询调用获取流水列表并存储到兰溪本地接口,获取所有的流水,通过批量插入的方式保存到流水表中
设计
- 线程池容量为200个线程。如果线程池空闲线程不足,则提示系统繁忙稍后再试
- 方法中添加完善的日志
- 每次调用文件上传接口产生的日志单独生成一个日志文件,方便进行维护