使用jQuery上传非拉丁文名称文件

时间:2015-04-08 15:38:12

标签: javascript php jquery

我有简单的表格将ajax上传文件发送到服务器。

这是输入事件监听器:

$(document).on('change', '.js-file', function(event){

    sendFile(event);
});

以下是实际上传文件的功能:

function sendFile (event) {
    var files = event.target.files;


    var action = '/ajax-upload-files/';
    var data = new FormData();

    $.each(files, function(key, value)
    {
        data.append(key, value);
    });

    $.ajax({
        url: action,
        type: 'POST',
        data: data,
        cache: false,
        dataType: 'json',
        processData: false,
        contentType: false,
        success: function(data){

        },
        complete: function(data) {
        }
    });
}

除了文件名中包含非拉丁字符的文件外,所有文件都适用。 Максим.jpg

正如我在Chrome网络中看到的那样,数据正在发送到服务器。但是当我尝试在服务器上转储$ _FILES时,它似乎是空的。

var_dump($_FILES) //array(0) {}

我真的不明白什么是错的 - 请求标题的contentLength要小得多 - 看起来文件由于某种原因没有附加到表单。

2 个答案:

答案 0 :(得分:2)

我终于设法上传了非拉丁文名称文件。 必须将其读作二进制文件并以二进制形式发送。

HTML:

<input class="js-file" name="filename" type="file">

和js

//Handler in input
$(document).on('change', '.js-file', function(event){
            var file_name = $(this).attr('name');


            var reader = new FileReader();
            var f = event.target.files[0],
                nameArr = event.target.files[0]['name'].split('.'),
                extension = nameArr[nameArr.length-1]; //here we can check if extension is allowed

            reader.onload = function(e) {
                var contents = e.target.result;
                contents = contents.split('base64,')[1]; //we need only encoded part

                sendFileAsBinary(file_name, extension, contents);
            };

            reader.readAsDataURL(f);


        });

发件人:

function sendFileAsBinary(file_name, extension, img) {

    $.ajax({
        url: '/ajax-upload-files/',
        type: 'POST',
        data: {
            name: file_name,
            img: img,
            extension: extension
        },
        dataType: 'json',
        success: function(data){


        },
        complete: function(data) {

        }

    })

}

用于解码图像的PHP代码:

 $name = $this->_getParam('name');
 $extension = $this->_getParam('extension');
 $computedName = $name . '.' . $extension;

 $fileContent = base64_decode($this->_getParam('img'));

 file_put_contents($fileContent, $computedName);

答案 1 :(得分:0)

这是我使用的代码(您的代码):

HTML文件

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>Untitled Document</title>
<script src="jquery.min.js"></script>
<script>
$(document).on('change', '#fileToUpload', function(event){
    sendFile(event);
});

function sendFile (event) {
    var files = event.target.files;
    var myAction = 'test.php';
    var myData = new FormData();

    $.each(files, function(key, value){
        myData.append(key, value);
    });

    $.ajax({
        url: myAction,
        type: 'POST',
        data: myData,
        cache: false,
//        dataType: 'json',
        processData: false,
        contentType: false,
        success: function(data){
                    console.log(data);
        },
        complete: function(data) {
        }
    });
}
</script>
</head>

<body>

<form action="test.php" method="post" enctype="multipart/form-data">
    Select image to upload:
    <input type="file" name="fileToUpload" id="fileToUpload">
    <input type="submit" value="Upload Image" name="submit">
</form>
</body>
</html>

<强> test.php的

<?php
echo var_dump($_FILES);
?>

导致console.log()

<pre class='xdebug-var-dump' dir='ltr'>
<b>array</b> <i>(size=1)</i>
  0 <font color='#888a85'>=&gt;</font> 
    <b>array</b> <i>(size=5)</i>
      'name' <font color='#888a85'>=&gt;</font> <small>string</small> <font color='#cc0000'>'Максим.jpg'</font> <i>(length=16)</i>
      'type' <font color='#888a85'>=&gt;</font> <small>string</small> <font color='#cc0000'>'image/jpeg'</font> <i>(length=10)</i>
      'tmp_name' <font color='#888a85'>=&gt;</font> <small>string</small> <font color='#cc0000'>'C:\wamp\tmp\phpE01A.tmp'</font> <i>(length=23)</i>
      'error' <font color='#888a85'>=&gt;</font> <small>int</small> <font color='#4e9a06'>0</font>
      'size' <font color='#888a85'>=&gt;</font> <small>int</small> <font color='#4e9a06'>951214</font>
</pre>

所以,正如您所看到的,我的代码上传文件和服务器可以看到它。你的机器上有不同的结果吗?