>  Q&A  >  본문

javascript - 添加多条数据组织为一个对象并传给php,php如何接收参数并解析为正常数据并插入到表中?

做了个增删改查的表,新增的数据有多条,我现在都是在URL中以 ? 后加参数的形式传给php,然后,php用$_GET['']接收传过来的参数。这是可以实现新增数据的方法,我想问的是,如果新增数据特别多的情况下,php怎么接收解析传过来的参数呢?
下面是我的代码?
php:

//新增方法
    function add_row(){
        /*获取从客户端传过来的数据*/
        $userName = $_GET['user_name'];
        $userAge = $_GET['user_age'];
        $userSex = $_GET['user_sex'];
        
        $sql = "INSERT INTO t_users (user_name,user_age,user_sex) VALUES ('$userName','$userAge','$userSex')";
        if(query_sql($sql)){
            echo "ok!";
        }else{
            echo "新增成功!";
        }
    }

    function query_sql(){
        $mysqli = new mysqli("127.0.0.1", "root", "root", "crud");
        $sqls = func_get_args();
        foreach($sqls as $s){
            $query = $mysqli->query($s);
        }
        $mysqli->close();
        return $query;
    }

js:

$(function() {
                
    $('#save').click(function(){
        addData();
    });
});
function addData(){
    var userName = $('#userName').val();
    var userAge = $("#userAge").val();
    var userSex = $('#user-sex').val() == '0' ? '男' : '女';
                
    var addUrl = "./php/data.php?action=add_row&user_name=" + userName + "&user_age=" + userAge + "&user_sex=" + userSex;
                
                $.ajax({
                    type:"post",
                    url:addUrl,
                    dataType:'json',
                    contentType:'application/json;charset=utf-8',
                    success:function(data){
                        console.log("success");
                    },
                    error:function(data){
                        console.log("data");
                        //添加成功后隐蒧modal框并重新加载页面
                        setTimeout(function(){
                            $('#exampleModal').modal('hide');
                        },500);
                        setTimeout(function(){
                            //新增成功后,重新加载数据
                            searchData();
                        },700);
                    }
                });
            }

上面写的可能不太明白,我想要表达的意思是,如果php的代码不变,变的仅是js新增这个方法中的数据组织,如果有多条数据需要新增,我把这多条数据组织为一个对象并把这个对象给解析为一个字符串传给php。那么这个php如何解析数据呢?

function addData(){
                var userName = $('#userName').val();
                var userAge = $("#userAge").val();
                var userSex = $('#user-sex').val() == '0' ? '男' : '女';
                
                /*var addUrl = "./php/data.php?action=add_row&user_name=" + userName + "&user_age=" + userAge + "&user_sex=" + userSex;*/
                var addUrl = "./php/data.php?action=add_row";
                var addData = {
                    'user_name':userName,
                    'user_age':userAge,
                    'user_sex':userSex
                };
                
                var jsonData = JSON.stringify(addData);
                
                $.ajax({
                    type:"post",
                    url:addUrl,
                    data:jsonData,//传给php
                    dataType:'json',
                    contentType:'application/json;charset=utf-8',
                    success:function(data){
                        console.log("success");
                    },
                    error:function(data){
                        console.log("data");
                        //添加成功后隐蒧modal框并重新加载页面
                        setTimeout(function(){
                            $('#exampleModal').modal('hide');
                        },500);
                        setTimeout(function(){
                            searchData();
                        },700);
                    }
                });
            }

求大侠解答一下,非常感谢!

阿神阿神2737일 전530

모든 응답(7)나는 대답할 것이다

  • 黄舟

    黄舟2017-05-16 13:01:35

    새로운 작업의 경우 Ajax가 json(data:{a:'',b:'',c:''}) 데이터를 보내고, PHP가 이를 수신한 후 POST 메서드를 사용합니다. )

    회신하다
    0
  • phpcn_u1582

    phpcn_u15822017-05-16 13:01:35

    모든 매개변수를 json 번호에 넣고 백그라운드로 전달합니다. {'username': xxx, 'age': xxx}, 코드의 설명과 논리에 따라 해당 코드는 오류 대신 성공으로 작성되어야 합니다

    회신하다
    0
  • PHP中文网

    PHP中文网2017-05-16 13:01:35

    무슨 말씀인지 이해가 되지 않습니다. Ajax는 이를 수신한 후 바로 반환하며 기본값은 dataType:'json'입니다. 즉, PHP에서 반환된 데이터가 json 형식이 아닌 한 오류는 다음과 같습니다. 보고되었습니다. 위의 //echo "Add 성공적으로!"를 살펴보세요. 이로 인해 Ajax 오류가 직접 보고됩니다.

    으아아아

    회신하다
    0
  • PHPz

    PHPz2017-05-16 13:01:35

    성공조건은 (xmlHttp.readyState == 4) && (xmlHttp.status == 200)
    요청한 주소에서 반환된 상태코드가 200인지 확인해보세요?

    파라미터가 많은 경우 $_GET은 배열이므로 변수에 직접 $_GET을 할당할 수 있습니다.

    회신하다
    0
  • 我想大声告诉你

    我想大声告诉你2017-05-16 13:01:35

    $_GET 배열을 수신한 다음 순회합니다

    회신하다
    0
  • 为情所困

    为情所困2017-05-16 13:01:35

    사용 POST

    회신하다
    0
  • 漂亮男人

    漂亮男人2017-05-16 13:01:35

    1. Ajax 제출 방법은 teyp: "post"이지만 php에서 받은 매개변수는 $_GET 입니다.
    2. ajax에서 받은 데이터 형식은 dataType: 'json'이지만 php에서 반환되는 결과는 text입니다.
    3.ajax 요청 콘텐츠 형식 contentType:'application/json;charset=utf-8', 요청된 데이터는 json 문자열이어야 합니다. PHP를 사용하여 백그라운드에서 수신하는 경우 $data = file_get_contents(" php://input "); json_decode($data, true), 이는 요청 매개변수입니다. (HttpRequest(전송)의 4가지 공통 ContentType)
    4.sql은 주입으로부터 보호되어야 합니다

    회신하다
    0
  • 취소회신하다