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 ...
随机推荐
- Linux之文件系统各种符号说明
/ 根目录 唯一必须挂载的目录.不要有任何的犹豫,选一个分区,挂载它!(在绝大多数情况下,有10G的容量应该是够用了.当然了,很多东西都是多多益善的) /boot 它包含了操作系统的内核和在启动系统过 ...
- Maven项目错误解决小结
http://blog.csdn.net/typa01_kk/article/details/49185759 Maven项目错误解决小结 注:整理错误,不喜欢为了一个小问题,占篇幅,所以请Ctrl+ ...
- TIJ -- 任务间使用管道进行输入/输出
1. 通过输入/输出在线程间进行通信通常很有用.提供线程功能的类库以“管道”的形式对线程间的输入/输出提供了支持.它们在Java输入/输出类库中的对应物就是PipedWriter类(允许任务向管道写) ...
- Win10 高分屏软件界面字体模糊问题解决
只需要将自定义缩放值改为 124% 即可
- nginx的https和http共存反向代理配置
一.设置http反向代理: upstream ly.com { server ; server ; } upstream home.ly.com { server ; server ; } 对应增加: ...
- linux signal
1) SIGHUP 本信号在用户终端连接(正常或非正常)结束时发出, 通常是在终端的控制进程结束时, 通知同一session内的各个作业, 这时它们与控制终端不再关联. 登录Linux时,系统会分配给 ...
- redis出现错误:NOAUTH Authentication required.
出现认证问题,应该是设置了认证密码,输入密码既可以啦 注意密码是字符串形式! 127.0.0.1:6379> auth "yourpassword" 127.0.0.1:63 ...
- nw.js---创建一个点击菜单
使用nw.js创建一个可点击的菜单: <!doctype html> <html lang="en"> <head> <meta char ...
- 9、BOM (浏览器对象模型)
1.认识BOM js 三个部分: 1.ECMAScript标准 ECMA5 ECMA6 2.BOM Browser Object Model 浏览器对象模型 3.DOM 文档对象类型 window对象 ...
- python中文分词库——pynlpir
安装 pip install pynlpir import pynlpir #加载包 pynlpir.open() #加载nlpir的库,这步是必须的 #否则会出现 段错误/段转储 segment f ...