Ajax和PHP API的问题

时间:2018-10-26 13:55:05

标签: javascript php ajax api encoding

我尝试了几个小时才了解为什么会发生,我向自己解释:

我使用FormData向我的api发送ajax请求,此刻每个字段都很好。 当他被发送到我的API时,某些字段(例如$_POST["Description"])看起来有所不同。

我的JavaScript

    document.getElementById("sendAddQuestion").onclick = function () { 
        if (document.getElementById("inputIntitule").value!="" && document.getElementById("inputDescription").value!="" && $("#tagsInputList").val()!="") {

            var lsttags = "";
            var str = $("#tagsInputList").val();
            var res = str.split(",");
            res.forEach(function(element) {
                lsttags= lsttags + "["+element+"]";

            });

            var form = new FormData();
            form.append("intitule",  "\"" + document.getElementById("inputIntitule").value + "\"" );
            form.append("description",  "\"" +document.getElementById("inputDescription").value+ "\"");
            form.append("id_utilisateur",  "2");
            form.append("tags", "\"" +lsttags+ "\"");

            var settings = {
               "async": true,
               "crossDomain": true,
               "url": "http://localhost/FAQ/api.php?action=post_question",
               "method": "POST",
               "headers": {
                 "cache-control": "no-cache",
                 "Postman-Token": "093d95af-25f5-4c51-bfcd-9f74577ad200"
               },
               "processData": false,
               "contentType": false,
               "mimeType": "multipart/form-data",
               "data": form
            }

            $.ajax(settings).done(function (response) {

                document.getElementById("inputIntitule").value="";
                document.getElementById("inputDescription").value="";
                $("#tagsInputList").tagsinput('removeAll');
                $("#myModalAddQuestion").modal("hide")
                location.reload();

                });

        } else {
            alert("Veuillez remplir tout les champs!");
        }
    };

我的PHP API

//je passe en paramètre mon objet PDO précédemment créé afin d'exécuter ma requête
function edit_question($pdo) { 
    $sql = "UPDATE `question` SET `intitule`='".$_POST["intitule"]."',`description`='".$_POST["description"]."' ,`tags`='".$_POST["tags"]."' WHERE `id`=".$_POST["id"];
    //création de la requête Sql pour aller chercher tous les articles
    $exe = $pdo->query($sql); 
    return $_POST["intitule"];
}

我的document.getElementById("inputIntitule").value中有Pourquoi votre site indique-t-il plusieurs disponibilités ?

但是在$_POST["intitule"]中,我有Pourquoi votre site indique-t-il plusieurs disponibilit\u00c3\u00a9s ?

你能给我打电话为什么吗?

0 个答案:

没有答案