先说一下问题场景吧,
产品需要将数据处理并汇总到一个Excel,但是因为数据太多了,前端实现不现实,所以就想着写一个脚本运行着,运行完的就展示在最右侧的 “已完成任务列表”,用户需要的时候点击下载即可,下载接口负责将文件找到,并且用koa-send发送给前端。

如果是相对路径,只需要提供ctx,path就好
const excel_path = './runtask/' + excelName + '.xlsx';
if(fs.existsSync(excel_path)){
if(nodeEnv==="test" || nodeEnv==="production"){//Linux
await send(ctx,excel_path);
}else{// 本地下
await send(ctx,excelName+'.xlsx',{
root:__dirname.split(':')[0]+':/runtask'
});
}
}else {
ctx.body = {
code:-1,
msg:'文件不存在'
}
}
如果是根路径下的某文件 path传 “/runtask/”,此方法会remove掉‘/’,所以需要添加root参数。
const excel_path = '/runtask/' + excelName + '.xlsx';
if(fs.existsSync(excel_path)){
if(nodeEnv==="test" || nodeEnv==="production"){
await send(ctx,excel_path,{root:'/'});
}else{// 本地下
await send(ctx,excelName+'.xlsx',{
root:__dirname.split(':')[0]+':/runtask'
});
}
}else {
ctx.body = {
code:-1,
msg:'文件不存在'
}
}
2841

被折叠的 条评论
为什么被折叠?



