openresty lua 文件上传与删除
【1】openresty 上传upload源码库
Github:https://github.com/openresty/lua-resty-upload
源码文件upload.lua文件
【2】上传
代码如下,详见注释:
local upload = require "resty.upload"
local cjson = require "cjson"
-- test.sh
-- curl -F "filename=@/home/test/test.wav" "http://127.0.0.1/uploadfile.gss?filename=test.wav&&type=wav&&billingcode=87654321"
, ["msg"] = "upload success!"}
local args = ngx.req.get_uri_args()
if not args then
ngx.exit(ngx.HTTP_BAD_REQUEST)
end
local filename = args["filename"] or "noname.file"
local billingcode = args["billingcode"]
local filetype = args["type"]
-- 判断文件类型
local res, err = ngx.re.match(filename, [[\.(?:xml|wav|ext)$]])
if not res then
response.code =
response.msg = "only xml or wav or ext format file can upload"
ngx.say(cjson.encode(response))
return
end
if err then
ngx.log(ngx.ERR, "match err:", err)
ngx.exit(ngx.HTTP_BAD_REQUEST)
end
-- 保存文件根目录
local save_file_root = "/home/kaizenly/"
local save_file_dir = save_file_root
-- 创建各类文件的保存目录[wav/ext/app]
if "wav" == filetype or "ext" == filetype then
save_file_dir = save_file_dir .. filetype
elseif "flow" == filetype or "state" == filetype then
save_file_dir = save_file_dir .. "app"
else
response.code =
response.msg = "error file type! filetype: " .. filetype
ngx.say(cjson.encode(response))
return
end
local dfile = io.open(save_file_dir, "rb")
if dfile then
dfile:close()
else
local md = "mkdir "
local mdpath = md .. save_file_dir
os.execute(mdpath)
ngx.log(ngx.ERR, "create save file first dir: " .. mdpath)
end
save_file_dir = save_file_dir .. "/"
-- 创建各类文件的保存子目录[按billingcode存储]
local save_file_path = ''
if "wav" == filetype or "ext" == filetype then
save_file_path = save_file_dir .. billingcode
else
save_file_path = save_file_dir .. filetype .. "xml"
end
local dfile = io.open(save_file_path, "rb")
if dfile then
dfile:close()
else
local md = "mkdir "
local mdpath = md .. save_file_path
os.execute(mdpath)
ngx.log(ngx.ERR, "create save file second dir: " .. mdpath)
end
save_file_path = save_file_path .. "/"
-- 创建上传form
-- should be set to 4096 or 8192
local form, err = upload:new(chunk_size)
if not form then
ngx.log(ngx.ERR, "failed to new upload: ", err)
ngx.exit()
end
form:set_timeout() -- 1 sec
local function close_file(write_file)
if io.type(write_file) == "file" then -- write_file处于打开状态,则关闭文件。
write_file:close()
write_file = nil
end
end
-- 上传过程
local write_file -- 文件句柄
while true do
local typ, recv, err = form:read()
if not typ then
response.code =
-- ngx.say("failed to read file: ", err)
response.msg = "failed to read file"
break
end
if typ == "header" and "file" ~= io.type(write_file) then
write_file, err = io.open(save_file_path .. filename, 'wb+')
if err then
ngx.log(ngx.ERR, "failed create hd:", err)
response.code =
response.msg = "failed create file:" .. err
break
end
elseif typ == "body" and "file" == io.type(write_file) then
write_file:write(recv)
elseif typ == "part_end" then
close_file(write_file)
elseif typ == "eof" then
response.code =
response.msg = "upload success"
break
end
end
ngx.say(cjson.encode(response))
如上代码。
【3】删除
代码如下,详见注释:
local upload = require "resty.upload"
local cjson = require "cjson"
local args = ngx.req.get_uri_args()
if not args then
ngx.exit(ngx.HTTP_BAD_REQUEST)
end
local filename = args["filename"] or "noname.file"
local billingcode = args["billingcode"] or ""
local filetype = args["type"]
, ["msg"] = "remove success!"}
-- 判断文件类型
local res, err = ngx.re.match(filename, [[\.(?:xml|wav|ext)$]])
if not res then
response.code =
response.msg = "only xml or wav or ext format file can remove"
ngx.say(cjson.encode(response))
return
end
if err then
ngx.log(ngx.ERR, "match err:", err)
ngx.exit(ngx.HTTP_BAD_REQUEST)
end
-- 保存文件根目录
local save_file_root = "/home/kaizenly/"
-- 确定删除文件路径
local remove_file_path = ''
if "wav" == filetype or "ext" == filetype then
remove_file_path = save_file_root .. filetype
if "" ~= billingcode then
remove_file_path = remove_file_path .. "/" .. billingcode
end
elseif "flow" == filetype or "state" == filetype then
remove_file_path = save_file_root .. "app/" .. filetype .. "xml"
else
response.code =
response.msg = "failed to remove, error file type!"
ngx.say(cjson.encode(response))
return
end
remove_file = remove_file_path .. "/" .. filename
-- 判断删除文件是否存在
local dfile = io.open(remove_file, "rb")
if dfile then
dfile:close()
else
response.code =
response.msg = "the remove file is not exist!"
ngx.say(cjson.encode(response))
return
end
-- 执行删除
local res, err = os.remove(remove_file)
if not res then
response.code =
response.msg = "failed to remove " .. remove_file .. ", err: " .. (err or '')
else
ngx.log(ngx.ERR, "success to remove file: " .. remove_file)
-- 如果目录为空,删除目录
local cmd = "ls " .. remove_file_path
local s = io.popen(cmd)
local file_lists = s:read("*all")
then
ngx.log(ngx.ERR, "success to remove file second dir: " .. remove_file_path)
os.remove(remove_file_path)
end
end
ngx.say(cjson.encode(response))
如上代码
Good Good Study, Day Day Up.
顺序 选择 循环 总结
openresty lua 文件上传与删除的更多相关文章
- Struts2 文件上传,下载,删除
本文介绍了: 1.基于表单的文件上传 2.Struts 2 的文件下载 3.Struts2.文件上传 4.使用FileInputStream FileOutputStream文件流来上传 5.使用Fi ...
- SpringMVC ajax技术无刷新文件上传下载删除示例
参考 Spring MVC中上传文件实例 SpringMVC结合ajaxfileupload.js实现ajax无刷新文件上传 Spring MVC 文件上传下载 (FileOperateUtil.ja ...
- 又拍云 Node.js 实现文件上传、删除
Node.js 服务端 使用 Node.js + Express.js 实现 服务端 const express = require("express"); const app = ...
- java操作FTP,实现文件上传下载删除操作
上传文件到FTP服务器: /** * Description: 向FTP服务器上传文件 * @param url FTP服务器hostname * @param port FTP服务器端口,如果默认端 ...
- HDFS操作--文件上传/创建/删除/查询文件信息
1.上传本地文件到HDFS //上传本地文件到HDFS public class CopyFile { public static void main(String[] args) { try { C ...
- js实现文件上传,删除效果
效果图: 刚开始: 点击按钮"选择更多后",可以添加很多选择文件: 点击按钮"删除"后: 实现代码: <!DOCTYPE html><html ...
- [java]文件上传下载删除与图片预览
图片预览 @GetMapping("/image") @ResponseBody public Result image(@RequestParam("imageName ...
- 【C#公共帮助类】FTPClientHelper帮助类,实现文件上传,目录操作,下载等动作
关于本文档的说明 本文档使用Socket通信方式来实现ftp文件的上传下载等命令的执行 欢迎传播分享,必须保持原作者的信息,但禁止将该文档直接用于商业盈利. 本人自从几年前走上编程之路,一直致力于收集 ...
- C# 文件上传下载功能实现 文件管理引擎开发
Prepare 本文将使用一个NuGet公开的组件技术来实现一个服务器端的文件管理引擎,提供了一些简单的API,来方便的实现文件引擎来对您自己的软件系统的文件进行管理. 在Visual Studio ...
随机推荐
- 使用SMART监控Ubuntu
参考:完全用 GNU/Linux 工作 - 29. 檢測硬碟 S.M.A.R.T. 健康狀態 1.安装 sudo apt-get install smartmontools 2.查看硬盘的参数,需要获 ...
- Groovy和Java互调
Scala和Java为静态语言,Groovy为动态语言 Scala: 函数式编程,同时支持面向对象 Groovy: jvm上的脚本,较好兼容java语法,Groovy加强了Java集成. 可配置化的优 ...
- BarTender中如何为称重设备设置秤显示?
有关BarTender 2016表单中的称显示,前面都给大家介绍过了,包括秤显示属性设置,链接数据源属性设置等等.本文,将以图文并茂的方式,教大家如何为称重设备设置秤显示控件. 我们打开BarTend ...
- [转]解决Error: That port is already in use.
ubuntu系统下,运行一个django项目,即输入python manage.py runserver后,可能出现 Error: That port is already in use.的错误. 即 ...
- js 注意
1.如果想要动态加清除浮动的代码,可以这样做: document.getElementById("mainBody").innerHTML += "<div sty ...
- linux Ubuntu系统安装百度aip
1.下载百度api pip install baidu-aip 2.配置视频转码工具ffmpeg Ubuntu16.04下安装FFmpeg(超简单版) 第一步:添加源. sudo add-apt-re ...
- react 使用 lazyload 懒加载图片
文档地址 index.html <script> (function(w, d) { var b = d.getElementsByTagName("body")[0] ...
- 网站ASHX不执行故障
今天修改之前做的一个网站,添加了ashx文件,但调试时发现里面的代码不执行. 检查webconfig文件发现其中有一项配置了ashx的处理方式: <system.web> <http ...
- MOT北京站 | 卓越研发之路:亿万级云端架构演进
随着IT行业技术周期的快速迭代,如何在激烈的市场竞争中突出重围成为了不少技术人的困惑.除了要保持良好的技术视野外,多向IT行业精英学习他们分享的实战经验,也可让技术提升,达到事半功倍的效果. MOT北 ...
- Xmodem协议简介
1. Xmodem协议 1.1. 简介 在上一章中,BootLoader和APP在串口下的升级其实都用到了一种文件传输协议,即Xmodem协议,该协议因其简单,易实现和使用的特点在很多 ...