Передача нескольких переменных PHP после вызова формы ajax - PullRequest
0 голосов
/ 14 января 2019

Я передаю файл в файл php через ajax и возвращаю только 1 $ переменную, используя die ($ var) в файле php после успешного запуска ...

проблема, с которой я сейчас сталкиваюсь, заключается в передаче более 1 переменной обратно в функцию ajax sucess. Я пытался использовать кодирование JSON, но он не работает. я думаю, может быть, это связано с формой данных ajax.

Я надеюсь, что есть простой способ передать несколько переменных обратно в функцию sucess.

Любая помощь очень ценится

var form_data = new FormData(); // Creating object of FormData class
form_data.append("image", file , newimagesrc) // Appending parameter named file with properties of file_field to form_data
form_data.append("oldimagesrc", oldimagesrc) // to re-write over with new image 
form_data.append("email", email)
form_data.append("imagext", fileNameSub)


$.ajax({
url: "UploadProfileImage.php",
type: "POST",
data: form_data,
processData: false,
contentType: false,
success: function(newimagesrc){ 


   //how do i pass back from php these variables
var out1=out1;
var out2=out2;
alert(out1 , out2);
  //help appreciated


var newimagesrc = newimagesrc;
//alert(newimagesrc); alert recieved message

imagename=input.files[0].name;
$('#imageupdate').css('color','green');
$('#imageupdate').text(newimagesrc);


var refreshimage = "Profileimagerefresh.php?avatar="+newimagesrc+"&email="+email;
$('#imagerefresh').load(refreshimage);


}//success 1 messagereturn1

});//ajax1

PHP FILE ('UploadProfileImage.php')

if(file_exists($oldimagelocation) && is_readable($oldimagelocation)){


$new=$rnd.$accountname.".".$extension;
if ($stat->execute(array("$new","$email"))){

unlink($oldimagelocation);
die($oldimagesrc);      //HERE I PASS 1 $ BACK  - I NEED TO RETURN MORE
exit();
}
else{
die("Failed replace image with image and rename");
exit();
}
 }

Ответы [ 2 ]

0 голосов
/ 14 января 2019

Недавно я столкнулся с подобной проблемой и решил ее с помощью JSON.

В PHP вы можете поместить переменные в массив, а затем использовать json_encode : и затем вернуть это на веб-страницу.

Теперь, используя ваш jQuery, вы можете использовать $. ParseJSON , который затем превращает его в массив в jQuery.

Вот пример:

PHP:

die(json_encode(array('Hello', 'world!')));

JQuery:

$.ajax({
type: 'POST',
url: 'test.php',
}).done(function(result){
var array = $.parseJSON(result);
alert(array[0]);
});
0 голосов
/ 14 января 2019

Использование JSON-кодирования - лучший выбор. Я бы порекомендовал что-то вроде этого:

if (file_exists($oldimagelocation) && is_readable($oldimagelocation)) {
    $new = $rnd.$accountname.".".$extension;
    if ($stat->execute([$new, $email])) {
        unlink($oldimagelocation);

        echo json_encode([
            'out1' => $oldimagelocation, 
            'out2' => $oldimagesrc, 
        ], JSON_FORCE_OBJECT);

    } else {
        die("Failed replace image with image and rename");
    }
}

Тогда в JS просто проанализируйте ответ как JSON

$.ajax({
    url: "UploadProfileImage.php",
    type: "POST",
    data: form_data,
    processData: false,
    contentType: false,
    success: function(newimagesrc){ 
        let jsonObj = JSON.parse(newimagesrc);
        console.log(jsonObj.out1);
    }
});
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...