【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. 使用SMART监控Ubuntu

    参考:完全用 GNU/Linux 工作 - 29. 檢測硬碟 S.M.A.R.T. 健康狀態 1.安装 sudo apt-get install smartmontools 2.查看硬盘的参数,需要获 ...

  2. Groovy和Java互调

    Scala和Java为静态语言,Groovy为动态语言 Scala: 函数式编程,同时支持面向对象 Groovy: jvm上的脚本,较好兼容java语法,Groovy加强了Java集成. 可配置化的优 ...

  3. BarTender中如何为称重设备设置秤显示?

    有关BarTender 2016表单中的称显示,前面都给大家介绍过了,包括秤显示属性设置,链接数据源属性设置等等.本文,将以图文并茂的方式,教大家如何为称重设备设置秤显示控件. 我们打开BarTend ...

  4. [转]解决Error: That port is already in use.

    ubuntu系统下,运行一个django项目,即输入python manage.py runserver后,可能出现 Error: That port is already in use.的错误. 即 ...

  5. js 注意

    1.如果想要动态加清除浮动的代码,可以这样做: document.getElementById("mainBody").innerHTML += "<div sty ...

  6. linux Ubuntu系统安装百度aip

    1.下载百度api pip install baidu-aip 2.配置视频转码工具ffmpeg Ubuntu16.04下安装FFmpeg(超简单版) 第一步:添加源. sudo add-apt-re ...

  7. react 使用 lazyload 懒加载图片

    文档地址 index.html <script> (function(w, d) { var b = d.getElementsByTagName("body")[0] ...

  8. 网站ASHX不执行故障

    今天修改之前做的一个网站,添加了ashx文件,但调试时发现里面的代码不执行. 检查webconfig文件发现其中有一项配置了ashx的处理方式: <system.web> <http ...

  9. MOT北京站 | 卓越研发之路:亿万级云端架构演进

    随着IT行业技术周期的快速迭代,如何在激烈的市场竞争中突出重围成为了不少技术人的困惑.除了要保持良好的技术视野外,多向IT行业精英学习他们分享的实战经验,也可让技术提升,达到事半功倍的效果. MOT北 ...

  10. Xmodem协议简介

    1.      Xmodem协议 1.1.    简介 在上一章中,BootLoader和APP在串口下的升级其实都用到了一种文件传输协议,即Xmodem协议,该协议因其简单,易实现和使用的特点在很多 ...