我想在我的内联网页面上实现一个简单的文件上传,尽可能使用最小的设置.

这是我的HTML部分:

<input id="sortpicture" type="file" name="sortpic" />
<button id="upload">Upload</button>

这是我的JS jquery脚本:

$("#upload").on("click", function() {
    var file_data = $("#sortpicture").prop("files")[0];   
    var form_data = new FormData();
    form_data.append("file", file_data);
    alert(form_data);
    $.ajax({
        url: "/uploads",
        dataType: 'script',
        cache: false,
        contentType: false,
        processData: false,
        data: form_data,                         
        type: 'post',
        success: function(){
            alert("works"); 
        }
    });
});

在网站的根目录中有一个名为"uploads"的文件夹,对"用户"和"IIS_用户"具有更改权限.

当我用文件表单 Select 一个文件并按下上传按钮时,第一个alert 返回"[object FormData]".第二个alert 没有被调用,"上传"文件夹也是空的!?

有人能帮我找出出了什么问题吗?

下一步应该是,使用服务器端生成的名称重命名文件.也许有人也能给我一个解决办法.

推荐答案

您需要一个在服务器上运行的脚本来将文件移动到uploads目录.jQuery ajax方法(在浏览器的客户端上运行)将表单数据发送到服务器,然后服务器上运行的脚本处理上传.

您的HTML没有问题,但请将您的JS jQuery脚本更新为如下所示:

(在// <--后寻找 comments )

$('#upload').on('click', function() {
    var file_data = $('#sortpicture').prop('files')[0];   
    var form_data = new FormData();                  
    form_data.append('file', file_data);
    alert(form_data);                             
    $.ajax({
        url: 'upload.php', // <-- point to server-side PHP script 
        dataType: 'text',  // <-- what to expect back from the PHP script, if anything
        cache: false,
        contentType: false,
        processData: false,
        data: form_data,                         
        type: 'post',
        success: function(php_script_response){
            alert(php_script_response); // <-- display response from the PHP script, if any
        }
     });
});

现在是服务器端脚本,在本例中使用PHP.

upload.php:位于服务器上并在服务器上运行的PHP脚本,将文件定向到uploads目录:

<?php

    if ( 0 < $_FILES['file']['error'] ) {
        echo 'Error: ' . $_FILES['file']['error'] . '<br>';
    }
    else {
        move_uploaded_file($_FILES['file']['tmp_name'], 'uploads/' . $_FILES['file']['name']);
    }

?>

此外,还有关于目标目录的几件事:

  1. 确保您有correct server path,即从PHP脚本位置开始上传目录的路径是什么,并且
  2. 确定是writeable.

还有一点关于upload.php脚本中使用的PHP函数move_uploaded_file:

move_uploaded_file(

    // this is where the file is temporarily stored on the server when uploaded
    // do not change this
    $_FILES['file']['tmp_name'],

    // this is where you want to put the file and what you want to name it
    // in this case we are putting in a directory called "uploads"
    // and giving it the original filename
    'uploads/' . $_FILES['file']['name']
);

$_FILES['file']['name']是上传时的文件名.你不必用这个.您可以为文件指定任何名称(与服务器文件系统兼容):

move_uploaded_file(
    $_FILES['file']['tmp_name'],
    'uploads/my_new_filename.whatever'
);

最后,请注意PHPupload_max_filesizepost_max_size配置值,并确保测试文件不超过这两个值.这里有一些帮助,帮助你如何check PHP configuration和如何set max filesize and post settings.

Php相关问答推荐

在WooCommerce中处理客户总支出中的退款

如何优化-PHP 7.3.14+Laravel 6

累加平面数组中数字子集的所有组合,以生成组合及其乘积的二维数组

根据产品类型显示或隐藏WooCommerce管理产品自定义字段

这是在可召回的背景下吗?

移动应用:在PHP中忽略Cookie?

从字符串转换日期和/或时间时,Laravel转换失败

用GUZLE模拟Read_Timeout

Laravel 10中的Validator类

使用HPOS过滤WooCommerce中的订单列表

为什么WooCommerce的动作钩子';woocommerce_checkout_update_order_review';包含旧信息?

Shopware 6 插件:如何删除/迁移布尔配置到多选配置

我不明白为什么我收到未定义的数组键异常错误 - Laravel 9 PHP 8

Woocommerce 中为空时隐藏显示变体自定义字段数据

Laravel的Storage::exists返回false,而file_exists返回true.

在 Symfony 测试中何时使用 TestCase 而不是 KernelTestCase

如何在 laravel 中的同一个 slug 上显示不同的内容?

如何使用 WhatsApp Cloud API 向 WhatsApp 发送消息,而无需在发送消息之前注册收件人号码?

PHP 合并/合并多维数组

如何在运行 update_post_meta 后更新 wp_wc_product_attributes_lookup 表?