php генерирует массив json, затем javascript отображает его - PullRequest
2 голосов
/ 03 апреля 2012


я работаю с JSON для отправки данных на сервер и с него, но обычно я работаю с отправкой по одной информации за раз, теперь я хочу:
извлечь все строки из таблицы (база данных mysql) -> php поместить его в массив JSON + обратный вызов ---> javascript извлекает его и отображает, просматривая данные.

Вот мой javascript (jQuery):

$.getJSON(domain_path + 'generate.php?table=' +  tbname + '&callback=?', function(data) {
});

Как видите, в таблице указано имя таблицы. для того, чтобы php знал, из какой таблицы извлечь данные.

Но для части php я не уверен, что использовать для создания массива JSONP.

<?php
//connects to database
  include 'connect.php';

$tbname = mysql_real_escape_string($_GET['table']);
$callback = $_GET['callback'];

//some mysql commands
//after mysql commands
//i would use this to output data but this is only for one line of data.

    $output = array('error'=>'0');
    $out_string =  json_encode($output);
    echo $callback.'('.$out_string.');';    

?>

Структура таблицы Mysql:
Название таблицы: пользователи
имя, ссылка, электронная почта

Как мне получить все строки из таблицы пользователей, которая содержит их имя, ссылку и адрес электронной почты, и вывести их в массив JSON.
И как бы я отобразить его с помощью JavaScript (JQuery)? Используется ли функция for в javascript

Ответы [ 2 ]

4 голосов
/ 03 апреля 2012

Распечатать массив JSON на PHP:

$query = mysql_query("SELECT * FROM ".$tbname."");
$rows = array();
while($r = mysql_fetch_assoc($query)) {
   $rows[] = $r;
}
print json_encode($rows);

Результат захвата и зацикливания в jQuery:

    $.getJSON(domain_path + 'generate.php?table=' +  tbname + '&callback=?', function(data) {
         $.each(data, function() {
           $.each(this, function(k, v) {
           /// do stuff
           });
         });
    });

Сначала каждый цикл проходит по вашим строкам / объектам; второй цикл перебирает ваши атрибуты / столбцы.

0 голосов
/ 03 апреля 2012

Вы подходите к использованию именованного обратного вызова - все неправильно, функциональность обратного вызова уже предоставлена ​​jQuery - обратите внимание, что вы передали пустую функцию в качестве последнего аргумента getJSON()?Ну, это ваш обратный вызов.

Вы хотите сделать что-то вроде этого:

PHP:

<?php

  //connects to database
  include 'connect.php';

  // mysql_real_escape_string() doesn't help, we need to do something like this:
  if (strpos($_GET['table'], '`') !== FALSE) {
    header('HTTP/1.1 400 Bad Request');
    exit;
  }

  // Build/make the query
  $query = "SELECT * FROM `{$_GET['table']}`";
  if (!$result = mysql_query($query)) {
    header('HTTP/1.1 500 Internal Server Error');
    exit;
  }

  // Fetch the returned data into an array of objects:
  $data = array();
  while ($row = mysql_fetch_assoc($result)) {
    $data[] = (object) $row;
  }

  // Send the final data back as JSON
  exit(json_encode($output));

Javascript:

$.getJSON(domain_path + 'generate.php?table=' +  tbname, function(data, status, xhr) {
  // First check the response is a success:
  if (xhr.status != 200) {
    console.log('Server responded with error code '+xhr.status);
    return;
  }
  // Now iterate over the data:
  $.each(data, function(key, item) {
    // Do something with the data here, for example:
    console.log('Name: '+item.name+', Link: '+item.link+', Email: '+item.email);
  });      
});
...