Я пытаюсь загрузить изображение и вставить его в базу данных вместе с данными пользователя в виде изображения профиля. В настоящее время я получаю вывод: {"current_field": null, "field_count": null, "lengths": null, "num_rows": null, "type": null} Как мне решить эту проблему? Я также пытался использовать локальное хранилище, так как это для приложения Cordova. В базе данных у меня есть 'Imagename' 'varchar (50)' null = yes
HTML
<img src="img/profilepic.png" alt="profilepic" style="width:200px;height:200px;">
<form id="imageForm" method="POST" enctype="multipart/form-data" class="imageform">
Select image to upload:
<input type="file" name="fileToUpload" id="fileToUpload">
<input type="submit" value="Upload Image" name="submit">
</form>
<p id="error" class="errormessage"></p>
<p id="image" class="imagemessage"></p>
JS
// When upload image button is clicked
$(document).ready(function() {
var imageform = $("#imageForm");
$("#imageForm").on('submit', function(event) {
event.preventDefault();
var imageValue = document.getElementById("fileToUpload").value;
//Set Local Store for Image
window.localStorage.setItem("fileToUpload", fileToUpload);
var imageform = new FormData(this);
var formData = new FormData($('#imageForm')[0]);
//Get Storage
var username = window.localStorage.getItem("username");
imageform.append('username', username);
var image = window.localStorage.getItem("fileToUpload");
//imageform.append('fileToUpload', fileToUpload);
// Call AJAX
$.ajax({
type: 'POST',
url: 'image.php',
data: imageform,
processData: false,
contentType: false,
success: function(data) {
if(data == "Success"){
document.getElementById("image").innerHTML = "Image Change Successful";
var image = window.localStorage.getItem("fileToUpload");
console.log(data);
} else {
console.log(data);
document.getElementById("error").innerHTML = "Error Uploading Image";
}
}
});
$("#fileToUpload").on("change", function() {
$("imageForm").submit();
});
});
});
PHP
<?php
require_once('checklog.php');
require_once("functions.php");
require_once("db_connect.php");
$username = $_POST['username'];
$image = $_POST['fileToUpload'];
session_start();
if($_POST['submit'] == "Upload Image"){
$target_dir = "images/";
$target_file = $target_dir . basename($_FILES["fileToUpload"]["name"]);
$uploadOk = 1;
$imageFileType = strtolower(pathinfo($target_file,PATHINFO_EXTENSION));
// Check if image file is a actual image or fake image
if(isset($_POST["submit"])) {
$check = getimagesize($_FILES["fileToUpload"]["tmp_name"]);
if($check !== false) {
$message = "File is an image - " . $check["mime"] . ".";
$uploadOk = 1;
} else {
$message = "File is not an image.";
$uploadOk = 0;
}
}
// Check if file already exists
if (file_exists($target_file)) {
$message = "Sorry, file already exists.";
$uploadOk = 0;
}
// Check file size
if ($_FILES["fileToUpload"]["size"] > 500000) {
$message = "Sorry, your file is too large.";
$uploadOk = 0;
}
// Allow certain file formats
if($imageFileType != "jpg" && $imageFileType != "png" && $imageFileType != "jpeg"
&& $imageFileType != "gif" ) {
$message = "Sorry, only JPG, JPEG, PNG & GIF files are allowed.";
$uploadOk = 0;
}
// Check if $uploadOk is set to 0 by an error
if ($uploadOk == 0) {
$message = "Sorry, your file was not uploaded.";
// if everything is ok, try to upload file
} else {
if (move_uploaded_file($_FILES["fileToUpload"]["tmp_name"], $target_file)) {
$uploadedfilename= basename( $_FILES["fileToUpload"]["name"]);
$query = "UPDATE users SET imagename='$uploadedfilename' WHERE username='$username'";
mysqli_query($db_server, $query) or die("Insert failed. ". mysqli_error($db_server));
$message = "<strong>Image $uploadedimage upload successful!</strong>";
} else {
$message = "Sorry, there was an error uploading your file.";
}
}
}
$currentimagename = "profilepic.png";
$query="SELECT imagename FROM users WHERE username='$username'";
$result = mysqli_query($db_server, $query) or die("image load failed. ". mysqli_error($db_server));
if($row = mysqli_fetch_array($result)){
if($row['imagename']<>""){
$currentimagename = $row['imagename'];
}
}
mysqli_free_result($result);
echo $message;
echo json_encode($result);
?>