2015-02-19 12 views
6

I zostały próbuje pobierać dane JSON z moich file.Its php dając mi twarde Zjawisko to mój kodPobieranie danych JSON odpowiedzieć w CodeIgniter

Kod moim zdaniem:

var productDetails = {'id':ISBNNumber,'qty':finalqty,'price':finalprice,'name':bookTitle}; 

     var base_url = '<?php echo site_url() ?>'; 
     $.ajax({ 
      url: "<?php echo base_url() ?>index.php/user/Add_to_cart/addProductsToCart", 
      type: 'POST', 
      data:productDetails, 
      dataType:'JSON', 
     }); 

Próbując do pobrania w moim kontrolerze:

echo $this->input->post("productDetails"); 

Nic nie wychodzi.

Oto moje nagłówki:

Remote Address:[::1]:80 
Request URL:http://localhost/CI/index.php/user/Add_to_cart/addProductsToCart 
Request Method:POST 
Status Code:200 OK 
Request Headersview source 
Accept:application/json, text/javascript, */*; q=0.01 
Accept-Encoding:gzip, deflate 
Accept-Language:en-US,en;q=0.8,fr;q=0.6 
Connection:keep-alive 
Content-Length:52 
Content-Type:application/x-www-form-urlencoded; charset=UTF-8 
Cookie:ci_session=3E5SPro57IrJJkjs2feMNlmMrTqEXrTNN8UyEfleeothNnHwNxuCZDSx4a7cJZGjj7fyr2KLpj%2BPNJeGRSzSPVmcFHVEdhSk4D47ziOl4eZcTUAZlQrWa3EYIeQJVWxMpiGZS26MEfbSXNmfel9e8TcsJTreZHipvfisrJovbXEAW4Uv%2BwrJRep1KCi1MMaDCVJb9UEinRVcDtYe%2F86jhn7kOj4kraVmVzx%2FsOaO0rAxLyAUtez%2Feaa4zBwpN3Td153sAoIb3WxVHoEj2oKyH5prVHigbIhIBR6XZqjBkM6hjBuoD2OSZ2wgLbp9DEENMoqui4WYyHROBuS2DYiJajblcS0KiFga5k%2FQOODvE7p6n%2BozN5ciDliVjJ4PnJ5PD1GaPEmec5%2FbQSlOHYWZk%2F2Blzw3Nw0EtLL7wKDzzQY%3Df645c36bb3548eb8de915b73f8763d97a47783ce 
Host:localhost 
Origin:http://localhost 
Referer:http://localhost/CI/index.php/user/view_available_books/viewAvailableBooks/5 
User-Agent:Mozilla/5.0 (Windows NT 6.3; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/40.0.2214.111 Safari/537.36 
X-Requested-With:XMLHttpRequest 
**Form Dataview** sourceview URL encoded 
id:234 
qty:1 
price:0.00 
name:[email protected][email protected]@ 

moja odpowiedź który widzę w narzędziach dla programistów:

Array 
(
    [id] => 234 
    [qty] => 1 
    [price] => 0.00 
    [name] => [email protected][email protected]@ 
) 

Ale w przeglądarce, wyjście jest niczym. Próbuję rozwiązać go przez ponad 4 godziny, ale na próżno.

print_r($_POST); // outputs nothing 
echo $data = file_get_contents('php://input'); //outputs nothing 
echo $id = $this->input->post('productDetails');// outputs nothing 

moim zdaniem Kod:

<script> 
    $('#addtoCart').on('click',function(event){ 
     event.preventDefault(); 
     $(this).attr('disabled',"disabled"); 
     finalprice = $.trim($('#price').val()); 
     finalqty = $.trim($('#quantity').val()); 

     var productDetails = JSON.stringify({'id':ISBNNumber,'qty':finalqty,'price':finalprice,'name':bookTitle}); 

     var base_url = '<?php echo site_url() ?>'; 
     // console.log($); 
     $.ajax({ 
      url: "<?php echo base_url() ?>index.php/user/Add_to_cart/addProductsToCart", 
      type: 'POST', 
      contentType: "application/json; charset=utf-8", 
      data:productDetails, 
      dataType:'html', 
     }); 


    }); 
</script> 

Kod Kontroler:

function addProductsToCart(){ 
     var_dump(json_decode(file_get_contents("php://input"))); 
     print_r($_POST); 
     // $data = json_decode($_POST["productDetails"]); 
     // var_dump($data); 
     // echo $data = file_get_contents('php://input'); 
// print_r(json_decode($data)); 
     // $id = $this->input->post('id'); 
     // $qty = $this 

    } 
+0

dwie rzeczy, które zrobiłeś źle 1. Dane: {informacje szczegółowe: informacje szczegółowe}, 2. $ data = json_decode ($ _ POST ["productDetails"]); –

+0

Nie działa – Abhinav

+0

możesz pokazać kod, co chcesz zrobić po otrzymaniu danych w zmiennej $ data. Druga rzecz, którą musisz zwrócić, lub echo wyjść coś, aby uzyskać dane z kontrolera i przetwarzać za pomocą jquery. –

Odpowiedz

-1

ogólnego sposobu używam dla mojego Ajax Rozmowy w CI:

JS:

post_array = 
{ 
    "myvar" : "value1", 
    "myvar2": "value2" 
} 

$.post(baseUrl + "/AjaxController/my_function", post_array, 
    function(data) 
    { 
     var res = jQuery.parseJSON(data); 
     alert(res.property); 
    } 

kontrolera:

public function my_function() 
{ 
    $myvar = $this->input->post('myvar'); 
    $myvar2 = $this->input->post('myvar2'); 

    //Stuff 

    echo json_encode($myobject); 
} 
+0

Co powiesz na echo lub umieszczenie tych danych w tabeli pliku widoku? Jak mam to zrobić @AdrienXL? Jaki byłby mój sukces javascript: funkcja wyglądałaby? – Eli

+0

Skąd pochodzi $ myobject? –

+0

@ logic-unit to obiekt, który zbudowałeś w zależności od tego, co musisz zrobić w części '// stuff '. – AdrienXL

2

Trzeba tylko swoją odpowiedź.

print_r($_POST);

Powrót:

Array 
(
    [id] => 234 
    [qty] => 1 
    [price] => 0.00 
    [name] => [email protected][email protected]@ 
) 

Więc jak dostaniesz: echo $id = $this->input->post('productDetails');

Dostaniesz id przez echo $id = $this->input->post('id');

+0

Ta tablica wyników jest wyświetlana tylko w narzędziach programistycznych po kliknięciu karty wyników, ale nie na tej stronie – Abhinav

+0

print_r ($ _ POST); musisz napisać w php poprawny kod? –

+0

, więc jeśli $ _POST ma wartość, to $ this-> input-> post() będzie mieć tę samą wartość –

6

miałem dokładnie ten sam problem. CodeIgniter nie wie, jak pobrać JSON. Najpierw myślałem o kodowaniu, ponieważ używam fetch.js, a nie jQuery. Cokolwiek robiłem, dostaję notting. $_POST był pusty, a także $this->input->post(). Oto, jak rozwiązałem problem.

Wysłać prośbę (jako obiektu prop - bo swoimi js lib może się różnić):

method: 'POST', 
headers: { 
    'Accept': 'application/json', 
    'Content-Type': 'application/json' 
}, 
body: JSON.stringify({ 
    ready: 'ready' 
}) 

Node: zakodować moich danych typu object do json.jQuery robi to samodzielnie przez po ustawieniu opcji dataType: 'JSON'.

CodeIgniter (3.1 w moim przypadku):

$stream_clean = $this->security->xss_clean($this->input->raw_input_stream); 
$request = json_decode($stream_clean); 
$ready = $request->ready; 

Uwaga: Trzeba oczyścić $this->input->raw_input_stream. Jesteś nie używając $this->input->post(), co oznacza, że ​​nie jest to wykonywane automatycznie przez CodeIgniter za pomocą .

Co do odpowiedzi:

$response = json_encode($request); 
header('Content-Type: application/json'); 
echo $response; 

Alternatywnie można zrobić:

echo $stream_clean; 

Uwaga: Nie jest wymagane, aby ustawić header('Content-Type: application/json') ale myślę, że jest to dobra praktyka aby to zrobić. Model request ustawił już nagłówek 'Accept': 'application/json'.

Sztuczka polega na użyciu $this->input->raw_input_stream i samodzielnym dekodowaniu danych.

0

Chociaż OP wydaje się być usatysfakcjonowany, wybrana odpowiedź nie podaje nam przyczyny ani rzeczywistego rozwiązania. (przy okazji, że pole post_array nie jest tablicą, to rzeczywiście obiekt) @ jimasun's answer ma właściwe podejście. Po prostu wyjaśnię sprawę i dodam rozwiązanie wykraczające poza CI.

Powodem problemu jest;

Nie CI lub PHP, ale twój serwer nie wie, jak obsłużyć żądanie, które ma typ aplikacji/json. Więc nie będziesz miał danych $ _POST. Php nie ma z tym nic wspólnego. Przeczytaj więcej na: Reading JSON POST using PHP

A rozwiązaniem jest; Albo nie wysyłaj żądania jako aplikacji/json lub organu żądania procesu, aby pobrać dane pocztowe.

Dla odpowiedzi CI @ jimasun jest to dokładny sposób.

Możesz także uzyskać treść żądania za pomocą czystego PHP, takiego jak ten.

$json_request_body = file_get_contents('php://input'); 
0

Miałem ten sam problem, ale znalazłem rozwiązanie.

Jest to JSON, który przesyłam [{"name":"JOSE ANGEL", "lastname":"Ramirez"}]

$data = json_decode(file_get_contents('php://input'), true); 
echo json_encode($data); 

Ten kod został przetestowany i wynik jest [{"name":"JOSE ANGEL","lastname":"Ramirez"}]

+3

Proszę przetłumaczyć odpowiedź w języku angielskim. Witamy w społeczności SO. – Nilesh

+0

SO jest specjalnie dla angielskiego Q/A. Sieć StackExchange * ma * inne witryny dla języka hiszpańskiego i innych języków. W przyszłości możesz wypróbować publikację na siostrzanej stronie w swoim języku lub przetłumaczyć ją za pomocą przycisku 'edit'. Tak jak jest, twoje pytanie jest w kolejce do usunięcia. – SherylHohman

+0

Przepraszam, jest już edytowany –