【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 文件上传与删除的更多相关文章

  1. Struts2 文件上传,下载,删除

    本文介绍了: 1.基于表单的文件上传 2.Struts 2 的文件下载 3.Struts2.文件上传 4.使用FileInputStream FileOutputStream文件流来上传 5.使用Fi ...

  2. SpringMVC ajax技术无刷新文件上传下载删除示例

    参考 Spring MVC中上传文件实例 SpringMVC结合ajaxfileupload.js实现ajax无刷新文件上传 Spring MVC 文件上传下载 (FileOperateUtil.ja ...

  3. 又拍云 Node.js 实现文件上传、删除

    Node.js 服务端 使用 Node.js + Express.js 实现 服务端 const express = require("express"); const app = ...

  4. java操作FTP,实现文件上传下载删除操作

    上传文件到FTP服务器: /** * Description: 向FTP服务器上传文件 * @param url FTP服务器hostname * @param port FTP服务器端口,如果默认端 ...

  5. HDFS操作--文件上传/创建/删除/查询文件信息

    1.上传本地文件到HDFS //上传本地文件到HDFS public class CopyFile { public static void main(String[] args) { try { C ...

  6. js实现文件上传,删除效果

    效果图: 刚开始: 点击按钮"选择更多后",可以添加很多选择文件: 点击按钮"删除"后: 实现代码: <!DOCTYPE html><html ...

  7. [java]文件上传下载删除与图片预览

    图片预览 @GetMapping("/image") @ResponseBody public Result image(@RequestParam("imageName ...

  8. 【C#公共帮助类】FTPClientHelper帮助类,实现文件上传,目录操作,下载等动作

    关于本文档的说明 本文档使用Socket通信方式来实现ftp文件的上传下载等命令的执行 欢迎传播分享,必须保持原作者的信息,但禁止将该文档直接用于商业盈利. 本人自从几年前走上编程之路,一直致力于收集 ...

  9. C# 文件上传下载功能实现 文件管理引擎开发

    Prepare 本文将使用一个NuGet公开的组件技术来实现一个服务器端的文件管理引擎,提供了一些简单的API,来方便的实现文件引擎来对您自己的软件系统的文件进行管理. 在Visual Studio ...

随机推荐

  1. geoserver 图层样式

    1.Styled Layer Descriptor 标准描述了稳当的结构合使用规则.一个文档包含了符号定义和绘制规则,那么这个文档就叫做Styled Layer Desciptor(SLD)样式,它是 ...

  2. Javascript中Promise对象的实现

    http://segmentfault.com/a/1190000000684654 http://www.infoq.com/cn/news/2011/09/js-promise/

  3. Mac 安装win10操作系统

    因为是做苹果开发的,用的一直是苹果的系统,前两天因为想要做内网穿透,需要用到花生壳这个软件,问题是这个软件只有windows版本和Linux版本,所以就想在苹果电脑上装一个windows系统,也想借此 ...

  4. 使用Docker的macvlan为容器提供桥接网络及跨主机通讯

    对于了解Docker容器网络的朋友,我想对虚拟机的网络也不会陌生,毕竟我们是跟随这个时代一起学习和进步的人.相比VM,Docker的网络也在逐步走向成熟,本文主要针对其中的macvlan做下简单的介绍 ...

  5. ubuntu使任何地方右键都能打开terminal

    ubuntu下安装terminal,在任何地方右键都可以快速的打开termial sudo apt-get install nautilus-open-terminal 重启电脑

  6. keras入门

    自己要搞深度学习,正好手上有本keras之父写的深度学习书,于是就从keras入手吧.看了一个电影的二分类问题,确实很简单,可以熟悉深度学习的流程.首先熟悉了结果keras的模块,如model,Seq ...

  7. 用memset设置无穷大无穷小

    memeset是以字节为单位进行赋值的,对字符数组可以直接用. 但对于int数组就不行了. 但设置无穷大来说有个技巧: 如果我们将无穷大设为0x3f3f3f3f,那么奇迹就发生了,0x3f3f3f3f ...

  8. C/S,B/S的区别

    一.概念说明 C/S(Client/Server(客服机/服务器))架构:客户端/服务器架构.通过将任务合理分配到Client端和Server端,降低了系统的通讯开销,需要安装客服端才可进行管理操作. ...

  9. linux samba建立共享文件夹

    sudo  apt-get install samba 1.  mkdir  /home/lgs/samba_share    (/home/lgs为自己的家目录) 2.  find    -name ...

  10. EasyUI combogrid/combobox过滤时限制只能选择现有项

    在使用EasyUI的combogrid时可以通过输入进行过滤,达到快速选择的目的,但是手工输入不存在的项也不会出错,结果提交到数据库后就会产生错误. 比如idField是int型的,输入的数据通过是检 ...