アップロード時にjQueryでファイルタイプを制限するにはどうすればよいですか?


133

jQueryでファイルアップロードフィールドをjpg / jpeg、png、gifのみに制限したいのですが。PHPすでにバックエンドチェックを行っています。私はJavaScriptすでに関数を介して送信ボタンを実行しているので、送信または警告の前にファイルタイプを確認する方法を知る必要があります。

回答:


280

ファイルフィールドの値は、他のフィールドとまったく同じように取得できます。ただし、変更することはできません。

したがって、ファイルの拡張子が適切かどうかを表面的に確認するには、次のようにします。

var ext = $('#my_file_field').val().split('.').pop().toLowerCase();
if($.inArray(ext, ['gif','png','jpg','jpeg']) == -1) {
    alert('invalid extension!');
}

18
そして、それをフォームにバインドします: $("#my_upload_form").bind("submit", function() { // above check });
321X

7
使用できます$('#file_field').change(function(){// above check});
makki

3
$("#my_upload_form").bind("submit", function() { // above check });$("#my_upload_form").submit(function() { // above check }); api.jquery.com/submitを使用してバインドする必要があります。フォームの送信を禁止することもできます$("#my_upload_form").submit(function(e) { // above check e.preventDefault(); });
Liam

1
この場合、ユーザーが".jpg" たとえばMS Wordファイルに追加すると、FileUploadはこのファイルを画像として受け入れます。それは正しくないと思います。
Jeyhun 2014

3
これはばかげた方法ではないことを述べておく価値はあります。1日の終わりに、バックエンドがファイルの最初の数バイトをチェックして、本当に希望するファイルタイプであるかどうかを確認してください。考えるべきもう1つのことは、Linuxとosxでは、実際に必要なタイプの拡張子を持たないファイルを使用できるということです。これも失敗します
chris

39

このタスクだけに必要なプラグインはありません。他のいくつかのスクリプトからこれをまとめました:

$('INPUT[type="file"]').change(function () {
    var ext = this.value.match(/\.(.+)$/)[1];
    switch (ext) {
        case 'jpg':
        case 'jpeg':
        case 'png':
        case 'gif':
            $('#uploadButton').attr('disabled', false);
            break;
        default:
            alert('This is not an allowed file type.');
            this.value = '';
    }
});

ここでの秘訣は、有効なファイルタイプが選択されるまで、そしてそれまではアップロードボタンを無効に設定することです。


6
申し訳ありませんが、それは悪い正規表現です。ファイルの名前にはドットを含めることができます。"giel.asd.aaaaa.jpg.png" .match(/\.(.+)$/)
ティム・クレッチマー

27

jQueryの検証プラグインを使用できます:http : //docs.jquery.com/Plugins/Validation

たまたま、あなたが必要としていることを正確に実行するaccept()ルールがあります:http : //docs.jquery.com/Plugins/Validation/Methods/accept#extension

ファイル拡張子の制御は、ファイルのMIMEタイプとはまったく関係がないため、防弾ではないことに注意してください。したがって、Word文書である.pngと、完全に有効なpng画像である.docを作成できます。したがって、サーバー側でより多くのコントロールを作成することを忘れないでください;)


IE11でplugins.krajee.com/file-input#option-allowedfileextensionsでこれを使用する方法の例を提供できますか
shorif2000

25

フロントエンドの場合、ファイルフィールドを使用している場合は、' accept '属性を指定すると非常に便利です。

例:

<input id="file" type="file" name="file" size="30" 
       accept="image/jpg,image/png,image/jpeg,image/gif" 
/>

いくつかの重要な注意事項:


1
JQueryを使用するよりもはるかに優れている
Christopher Grigg

19

ユーザーが嘘をついている範囲ではなく、MIMEでチェックしたくないですか?もしそうなら、それは1行未満です:

<input type="file" id="userfile" accept="image/*|video/*" required />

彼が必要とするものを手に入れません。異なる拡張子のフォルダから画像を選択することは、より簡単な処理のためです。ご覧の
とおり

IE <10を傷つけず、他のコードも傷つけないので、制限しようとしているものに対する効果的な制限です。
レオ、

4

私の場合、私は次のコードを使用しました:

    if (!(/\.(gif|jpg|jpeg|tiff|png)$/i).test(fileName)) {              
    alert('You must select an image file only');               
    }

3

動作するコード例を書いてみて、それをテストし、すべてが機能します。

うさぎはコードです:

HTML:

<input type="file" class="attachment_input" name="file" onchange="checkFileSize(this, @Model.MaxSize.ToString(),@Html.Raw(Json.Encode(Model.FileExtensionsList)))" />

JavaScript:

 //function for check attachment size and extention match
function checkFileSize(element, maxSize, extentionsArray) {
    var val = $(element).val(); //get file value

    var ext = val.substring(val.lastIndexOf('.') + 1).toLowerCase(); // get file extention 
    if ($.inArray(ext, extentionsArray) == -1) {
        alert('false extension!');
    }

    var fileSize = ($(element)[0].files[0].size / 1024 / 1024); //size in MB
    if (fileSize > maxSize) {
        alert("Large file");// if Maxsize from Model > real file size alert this
    }
}

1

このコードは問題なく機能しますが、唯一の問題は、ファイル形式が指定されたオプション以外の場合、警告メッセージが表示されますが、無視する必要があるファイル名が表示されます。

$('#ff2').change(
                function () {
                    var fileExtension = ['jpeg', 'jpg', 'pdf'];
                    if ($.inArray($(this).val().split('.').pop().toLowerCase(), fileExtension) == -1) {
                        alert("Only '.jpeg','.jpg','.pdf' formats are allowed.");
                        return false; }
});

1

この例では、PNG画像のみをアップロードできます。

HTML

<input type="file" class="form-control" id="FileUpload1" accept="image/png" />

JS

$('#FileUpload1').change(
                function () {
                    var fileExtension = ['png'];
                    if ($.inArray($(this).val().split('.').pop().toLowerCase(), fileExtension) == -1) {
                        alert("Only '.png' format is allowed.");
                        this.value = ''; // Clean field
                        return false;
                    }
                });

画像サイズの制限方法を教えてください。たとえば、10MBサイズの画像は受け入れられません
PDSSandeep

このリンクplsはチェックし@PDSSandeep stackoverflow.com/questions/6575159/...を
開発

0
<form enctype="multipart/form-data">
   <input name="file" type="file" />
   <input type="submit" value="Upload" />
</form>
<script>
$('input[type=file]').change(function(){
    var file = this.files[0];
    name = file.name;
    size = file.size;
    type = file.type;
    //your validation
});
</script>

これは、FFでテストされたファイルタイプとサイズをチェックできません。
Qammar Feroz 2016

0

複数(html 5)のファイルのアップロードを扱っている場合は、提案された上位のコメントを使用して少し修正しました。

    var files = $('#file1')[0].files;
    var len = $('#file1').get(0).files.length;

    for (var i = 0; i < len; i++) {

        f = files[i];

        var ext = f.name.split('.').pop().toLowerCase();
        if ($.inArray(ext, ['gif', 'png', 'jpg', 'jpeg']) == -1) {
            alert('invalid extension!');

        }
    }

0
    $("input[name='btnsubmit']").attr('disabled', true);
    $('input[name="filphoto"]').change(function () {
    var ext = this.value.match(/\.(.+)$/)[1];
    switch (ext) 
    {
    case 'jpg':
    case 'jpeg':
    case 'png':
    case 'bmp':
        $("input[name='btnsubmit']").attr('disabled', false);
    break;
    default:
        alert('This is not an allowed file type.');
        $("input[name='btnsubmit']").attr('disabled', true);
        this.value = '';

-1
function validateFileExtensions(){
        var validFileExtensions = ["jpg", "jpeg", "gif", "png"];
        var fileErrors = new Array();

        $( "input:file").each(function(){
            var file = $(this).value;
            var ext = file.split('.').pop();
            if( $.inArray( ext, validFileExtensions ) == -1) {
                fileErrors.push(file);
            }
        });

        if( fileErrors.length > 0 ){
            var errorContainer = $("#validation-errors");
            for(var i=0; i < fileErrors.length; i++){
                errorContainer.append('<label for="title" class="error">* File:'+ file +' do not have a valid format!</label>');
            }
            return false;
        }
        return true;
    }

-1

JavaScript検証の簡単なコードを次に示します。検証後、入力ファイルをクリーンアップします。

<input type="file" id="image" accept="image/*" onChange="validate(this.value)"/>

function validate(file) {
    var ext = file.split(".");
    ext = ext[ext.length-1].toLowerCase();      
    var arrayExtensions = ["jpg" , "jpeg", "png", "bmp", "gif"];

    if (arrayExtensions.lastIndexOf(ext) == -1) {
        alert("Wrong extension type.");
        $("#image").val("");
    }
}
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.