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

关于koa-send的path参数
如果是相对路径,只需要提供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:'文件不存在'
                }
            }

相关文章: