php文件上传formdata,javascript - PHP文件上传,发送formdata对象

我想上传一个文件,将其发送到javascript formData对象,然后通过ajax发送到一些php脚本,该脚本会将文件放入数据库。当我在配置文件php中上传文件,将其发送到javascript中的formData对象并将其发送回profile.php时,它工作正常。问题是,当我想将formData对象发送到不是profile.php的其他其他php脚本时,它不起作用。

这是我的代码:

profile.php

Save

javascript.js

$('#editUserProfile').validate({

submitHandler: function (form) {

var aFormData = new FormData();

aFormData.append("filename", $('#filename').get(0).files[0]);

$.ajax({

type: "POST",

url: "script.php",

data: aFormData,

success: function(data){

window.location.reload(true);

}

})

}

});

并且比我想检查是否有其他php(script.php)脚本是否已上传文件。

if(is_uploaded_file($_FILES['filename']['tmp_name']) && getimagesize($_FILES['filename']['tmp_name']) != false){

$size = getimagesize($_FILES['filename']['tmp_name']);

$type = $size['mime'];

$imgfp = fopen($_FILES['filename']['tmp_name'], 'rb');

$size = $size[3];

$name = $_FILES['filename']['name'];

$maxsize = 99999999;

if($_FILES['userfile']['size'] < $maxsize ){

$dbh = new PDO("mysql:host=localhost;dbname=test", 'root');

$dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

$stmt = $dbh->prepare("INSERT INTO table (image_type ,image, image_size, image_name) VALUES (? ,?, ?, ?)");

$stmt->bindParam(1, $type);

$stmt->bindParam(2, $imgfp, PDO::PARAM_LOB);

$stmt->bindParam(3, $size);

$stmt->bindParam(4, $name);

$stmt->execute();

}else{

throw new Exception("File Size Error");

}

}

最佳答案

已添加到jQuery.ajax,现在可以使用:processData: false,

contentType: false,

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
关于 PHP 微信网页上传图片失败的问题,可能是由于以下原因所导致: 1. 文件上传大小限制:您需要检查 PHP 的配置文件 php.ini 中的 upload_max_filesize 和 post_max_size 的设置是否足够。如果上传的图片文件大小超过了这些限制,就会上传失败。 2. 临时文件夹设置不正确:PHP 在上传文件时需要使用一个临时文件夹来存储上传的文件,如果这个临时文件夹的权限设置不正确,就会导致上传失败。您可以检查 PHP 的配置文件 php.ini 中的 upload_tmp_dir 的设置是否正确。 3. 文件格式不正确:微信上传图片只支持 JPG、PNG、GIF 格式的图片,如果上传的图片格式不正确,也会导致上传失败。 关于 JavaScriptPHP 微信开发中图片上传传的问题,您可以使用 FormData 对象来实现图片上传,具体步骤如下: 1. 在 HTML 页面中,使用 input 标签的 type 属性设置为 file,让用户选择要上传的图片文件。 2. 使用 JavaScript 获取用户选择的图片文件,并使用 FormData 对象将图片文件上传到服务器。 3. 在服务器端使用 PHP 接收上传的图片文件,并进行处理。 以下是一个简单的代码示例: HTML 代码: ```html <form id="uploadForm"> <input type="file" name="imageFile" /> <button type="submit">上传</button> </form> ``` JavaScript 代码: ```javascript var uploadForm = document.getElementById("uploadForm"); uploadForm.addEventListener("submit", function(event) { event.preventDefault(); var formData = new FormData(uploadForm); var xhr = new XMLHttpRequest(); xhr.open("POST", "upload.php"); xhr.send(formData); }); ``` PHP 代码: ```php if ($_FILES["imageFile"]["error"] == UPLOAD_ERR_OK) { $tmp_name = $_FILES["imageFile"]["tmp_name"]; $name = $_FILES["imageFile"]["name"]; $path = "/uploads/" . $name; move_uploaded_file($tmp_name, $path); } ``` 在以上代码中,我们使用了 FormData 对象将用户选择的图片文件上传到服务器,然后在服务器端使用 PHP 进行处理。您可以根据实际需求对代码进行修改和优化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值