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で画像の拡張子を取得するにはどうすればよいですか?
次の方法でファイル名の拡張子を取得できると思います。
var path = require('path')
path.extname('index.html')
// returns
'.html'
更新
元の回答 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);
}
// you can send full url here
function getExtension(filename) {
return filename.split('.').pop();
}
エクスプレスを使用している場合は、ミドルウェア(bodyParser)を構成するときに次の行を追加してください。
app.use(express.bodyParser({ keepExtensions: true}));
このソリューションはクエリ文字列をサポートしています!
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'
substr()
とsplit()
の代わりにpop()
メソッドを使用する方がはるかに効率的です
ここでパフォーマンスの違いを見てください: http://jsperf.com/remove-first-character-from-string
// returns: 'html'
var path = require('path');
path.extname('index.html').substr(1);
複数期間の延長問題を解決する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'
ファイルにも拡張子があることをテストしてください。
リクエスト内の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検索を行ったときの上位の結果です
また、その使用方法も簡単です。
app.post('/upload2', function (req, res) {
console.log(mime.extension(req.files.image.type));
}
上記のスニペットは、コンソールにpngを出力します。
var fileName = req.files.upload.name;
var arr = fileName.split('.');
var extension = arr[length-1];
ほとんどの場合、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
ではまったく機能しないことに注意してください。
次の関数は、文字列を分割し、拡張子にドットがいくつあっても名前と拡張子を返します。拡張子がない場合は、空の文字列を返します。ドットや空白で始まる名前も機能します。
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')