node第三方模块 path.basename

path.basename(path[, ext])

path.basename() 方法会返回 path 的最后一部分。 尾部的目录分隔符会被忽略。

  • path :string
  • ext :string 可选的文件扩展名。
  • 返回:string

返回: ‘文件.html’:

path.basename('/目录1/目录2/文件.html');

返回: ‘文件’:

path.basename('/目录1/目录2/文件.html', '.html');

尽管 Windows 通常以不区分大小写的方式处理文件名(包括文件扩展名),但是此函数不会这样。 例如, C:\文件.html 和 C:\文件.HTML 指向相同的文件,但是 basename 会将扩展名视为区分大小写的字符串:

返回: ‘文件’:

path.win32.basename('C:\\文件.html', '.html');

返回: ‘文件.HTML’:

path.win32.basename('C:\\文件.HTML', '.html');

如果 path 不是字符串、或给定了 ext 但不是字符串,则抛出 TypeError。

英雄案例后台-文件上传:

img: path.basename(files.img.path) ==> 截取图片路径的图片名

  uploadFile: function (req, res) {
    // 1.创建文件上传对象
    let form = new IncomingForm()

    // 2.添加必要的配置
    // 2.1 设置编码,formidable也可 接收普通键值对,这个时候就有需要设置编码,如果只是上传文件,则不用设置
    // form.encoding = 'utf-8'
    // // 2.2 设置上传文件的存放路径,一定给一个全路径,否则报错
    form.uploadDir = __dirname + '/public/images'
    // // 2.3 设置是否保留文件的扩展名,默认不保留
    form.keepExtensions = true

    // 3.调用上传方法,实现文件上传
    // form.parse(请求报文,回调函数)
    // err:文件上传失败时的错误信息
    // fields:接收到普通键值对--对象
    // files:文件的相关信息,特别是上传成功后在服务器端的信息
    form.parse(req, (err, fields, files) => {
      if (err) {
        console.log(err)
        res.json({
          code: 204,
          msg: '文件上传失败'
        })
      } else {
        res.json({
          code: 200,
          msg: '文件上传成功',
          img: path.basename(files.img.path)
        })
      }
    })
  },
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值