php与ajax上传头像实现实例
以前用到的都是表单上传头像,第一次用到ajax上传头像,所以整理了下。具体代码如下:
var photo = '';
function uploadFile() {
var _file = this;
var data = new FormData();
data.append('file', _file.files[0]);
console.log(data)
URL_fileShareUpload = "{{ path('api_user_photo',{type:1}) }}";
$.ajax({
url:URL_fileShareUpload,
type: 'POST',
dataType: 'json',
processData: false,
contentType: false,
data: data,
success: function (responseText) {
if(responseText.errorCode == 0){
photo = responseText.result;
}
}
});
}
// 触发上传头像函数
$('input[name="file"]').on("change", uploadFile);
<input type="file" class="" name=file" id="file_input" accept="images/*;capture=camera" multiple="multiple">
php处理文件就是普通的文件接受了这里简单给一段代码
<?php
// 允许上传的图片后缀
$allowedExts = array("gif", "jpeg", "jpg", "png");
$temp = explode(".", $_FILES["file"]["name"]);
echo $_FILES["file"]["size"];
$extension = end($temp); // 获取文件后缀名
if ((($_FILES["file"]["type"] == "image/gif")
|| ($_FILES["file"]["type"] == "image/jpeg")
|| ($_FILES["file"]["type"] == "image/jpg")
|| ($_FILES["file"]["type"] == "image/pjpeg")
|| ($_FILES["file"]["type"] == "image/x-png")
|| ($_FILES["file"]["type"] == "image/png"))
&& ($_FILES["file"]["size"] < 204800) // 小于 200 kb
&& in_array($extension, $allowedExts))
{
if ($_FILES["file"]["error"] > 0)
{
echo "错误:: " . $_FILES["file"]["error"] . "<br>";
}
else
{
echo "上传文件名: " . $_FILES["file"]["name"] . "<br>";
echo "文件类型: " . $_FILES["file"]["type"] . "<br>";
echo "文件大小: " . ($_FILES["file"]["size"] / 1024) . " kB<br>";
echo "文件临时存储的位置: " . $_FILES["file"]["tmp_name"] . "<br>";
// 判断当期目录下的 upload 目录是否存在该文件
// 如果没有 upload 目录,你需要创建它,upload 目录权限为 777
if (file_exists("upload/" . $_FILES["file"]["name"]))
{
echo $_FILES["file"]["name"] . " 文件已经存在。 ";
}
else
{
// 如果 upload 目录不存在该文件则将文件上传到 upload 目录下
move_uploaded_file($_FILES["file"]["tmp_name"], "upload/" . $_FILES["file"]["name"]);
echo "文件存储在: " . "upload/" . $_FILES["file"]["name"];
}
}
}
else
{
echo "非法的文件格式";
}
?>