web-dev-qa-db-ja.com

Node.jsファイル拡張子を取得

Express 3を使用してnode.jsでファイルアップロード関数を作成しています。

画像のファイル拡張子を取得したいと思います。ファイルの名前を変更してから、ファイル拡張子を追加できます。

app.post('/upload', function(req, res, next) {
    var is = fs.createReadStream(req.files.upload.path),
        fileExt = >>>> I want to get the extension of the image here <<<<,
        os = fs.createWriteStream('public/images/users/' + req.session.adress + '.' + fileExt);
});

Node.jsで画像の拡張子を取得するにはどうすればよいですか?

148
georgesamper

次の方法でファイル名の拡張子を取得できると思います。

var path = require('path')

path.extname('index.html')
// returns
'.html'
369
Snowfish

更新

元の回答 extname()pathモジュールに追加されたため、Snowfishの回答を参照してください

元の答え:

私はこの機能を使用してファイル拡張子を取得していますが、それを簡単な方法で見つける方法が見つかりませんでした(しかし、あると思います):

function getExtension(filename) {
    var ext = path.extname(filename||'').split('.');
    return ext[ext.length - 1];
}

使用するには「パス」が必要です。

パスモジュールを使用しない別の方法:

function getExtension(filename) {
    var i = filename.lastIndexOf('.');
    return (i < 0) ? '' : filename.substr(i);
}
30
dievardump
// you can send full url here
function getExtension(filename) {
    return filename.split('.').pop();
}

エクスプレスを使用している場合は、ミドルウェア(bodyParser)を構成するときに次の行を追加してください。

app.use(express.bodyParser({ keepExtensions: true}));
17
Kamrul

このソリューションはクエリ文字列をサポートしています!

var Url = require('url');
var Path = require('path');

var url = 'http://i.imgur.com/Mvv4bx8.jpg?querystring=true';
var result = Path.extname(Url.parse(url).pathname); // '.jpg'
11
aleclarson

substr()split()の代わりにpop()メソッドを使用する方がはるかに効率的です

ここでパフォーマンスの違いを見てください: http://jsperf.com/remove-first-character-from-string

// returns: 'html'
var path = require('path');
path.extname('index.html').substr(1);

enter image description here

8
magikMaker

複数期間の延長問題を解決するrequireを必要としないシンプルなソリューション:

var filename = 'file.with.long.extension';
var ext = filename.substring(filename.indexOf('.')); 
//ext = '.with.long.extension'

または、先頭のドットが必要ない場合:

var filename = 'file.with.long.extension';
var ext = filename.substring(filename.indexOf('.')+1); 
//ext = 'with.long.extension'

ファイルにも拡張子があることをテストしてください。

6
smileham

リクエスト内のContent-Typeヘッダーのマッピングも機能すると思います。これは、拡張子のないファイルをアップロードする場合でも機能します。 (リクエストにファイル名の拡張子がない場合)

HTTP POSTを使用してデータを送信すると仮定します。

POST /upload2 HTTP/1.1
Host: localhost:7098
Connection: keep-alive
Content-Length: 1047799
Accept: */*
Origin: http://localhost:63342
User-Agent: Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML,    like Gecko) Chrome/51.0.2704.106 Safari/537.36
Content-Type: multipart/form-data; boundary=----   WebKitFormBoundaryPDULZN8DYK3VppPp
Referer: http://localhost:63342/Admin/index.html? _ijt=3a6a054pasorvrljf8t8ea0j4h
Accept-Encoding: gzip, deflate
Accept-Language: en-US,en;q=0.8,az;q=0.6,tr;q=0.4
Request Payload
------WebKitFormBoundaryPDULZN8DYK3VppPp
Content-Disposition: form-data; name="image"; filename="blob"
Content-Type: image/png


------WebKitFormBoundaryPDULZN8DYK3VppPp--

ここで、名前Content-Typeヘッダーには、データのMIMEタイプが含まれています。このMIMEタイプを拡張子にマッピングすると、ファイル拡張子が取得されます:)。

Restify BodyParserは、このヘッダーをtypeという名前のプロパティに変換します

File {
  domain: 
   Domain {
     domain: null,
     _events: { .... },
     _eventsCount: 1,
     _maxListeners: undefined,
     members: [ ... ] },
  _events: {},
  _eventsCount: 0,
  _maxListeners: undefined,
  size: 1047621,
  path: '/tmp/upload_2a4ac9ef22f7156180d369162ef08cb8',
  name: 'blob',
  **type: 'image/png'**,
  hash: null,
  lastModifiedDate: Wed Jul 20 2016 16:12:21 GMT+0300 (EEST),
  _writeStream: 
  WriteStream {
   ... },
     writable: true,
     domain: 
     Domain {
        ...
     },
      _events: {},
      _eventsCount: 0,
     _maxListeners: undefined,
     path: '/tmp/upload_2a4ac9ef22f7156180d369162ef08cb8',
     fd: null,
     flags: 'w',
     mode: 438,
     start: undefined,
     pos: undefined,
     bytesWritten: 1047621,
     closed: true } 
}

このヘッダーを使用して、手動で拡張マッピング(サブストリングなど)を実行できますが、このための既製ライブラリもあります。以下は、Google検索を行ったときの上位の結果です

  • mime
  • mime-types

また、その使用方法も簡単です。

 app.post('/upload2', function (req, res) {
  console.log(mime.extension(req.files.image.type));
 }

上記のスニペットは、コンソールにpngを出力します。

3
rozaydin
var fileName = req.files.upload.name;

var arr = fileName.split('.');

var extension = arr[length-1];
2
rajesh

ほとんどの場合、path.extnameがトリックを行います。ただし、クエリ文字列やhttp要求のハッシュフラグメントを含む、最後の.以降のすべてが含まれます。

var path = require('path')
var extname = path.extname('index.html?username=asdf')
// extname contains '.html?username=asdf'

そのような場合は、次のようなものを試してください。

var regex = /[#\\?]/g; // regex of illegal extension characters
var extname = path.extname('index.html?username=asdf');
var endOfExt = extname.search(regex);
if (endOfExt > -1) {
    extname = extname.substring(0, endOfExt);
}
// extname contains '.html'

複数のピリオドを持つ拡張機能(.tar.gzなど)は、path.extnameではまったく機能しないことに注意してください。

1
dug

次の関数は、文字列を分割し、拡張子にドットがいくつあっても名前と拡張子を返します。拡張子がない場合は、空の文字列を返します。ドットや空白で始まる名前も機能します。

function basext(name) {
  name = name.trim()
  const match = name.match(/^(\.+)/)
  let prefix = ''
  if (match) {
    prefix = match[0]
    name = name.replace(prefix, '')
  }
  const index = name.indexOf('.')
  const ext = name.substring(index + 1)
  const base = name.substring(0, index) || ext
  return [prefix + base, base === ext ? '' : ext]
}

const [base, ext] = basext('hello.txt')
0
Vidar