Mam problem z przesyłaniem danych JSON z klasy php do AJAXA. Problem w tym, że gdy używam zwykłego pliku php wszystko działa poprawnie:
<?php
header("Content-Type: application/json; charset=UTF-8");
$pdo = new PDO('mysql:host=localhost;dbname=database', 'root', '');
$pdo -> query ('SET NAMES utf8');
$pdo -> query ('SET CHARACTER_SET utf8_unicode_ci');
$stmt = $pdo->prepare("SELECT id, name FROM table");
$stmt->execute();
$stmt = $stmt->fetchAll(PDO::FETCH_CLASS);
echo json_encode($stmt);
?>
var xmlhttp = new XMLHttpRequest();
xmlhttp.onreadystatechange = function() {
if (this.readyState == 4 && this.status == 200) {
myObj = JSON.parse(this.responseText);
console.log(myObj);
document.getElementById("par").innerHTML = myObj[4].id;
}
};
xmlhttp.open("GET", "http://localhost/project/app/models/json.php", true);
xmlhttp.send();
ale jeżeli spróbuje pobrać dane z bazy danych w kontrolerze w silexie:
namespace AI\models;
use Silex\Application;
use Silex\Api\ControllerProviderInterface;
class Ajax implements ControllerProviderInterface
{
public function connect(Application $app){
$controllers = $app['controllers_factory'];
$controllers->get('/', 'AI\models\Ajax::home');
return $controllers;
}
public function home(Application $app){
header("Content-Type: application/json; charset=UTF-8");
$result = $app['db']->prepare("SELECT id, name FROM table");
$result->execute();
$result = $result->fetchAll(\PDO::FETCH_CLASS, \AI\models\Ajax::class);
echo json_encode($result);
return $app['twig']->render('ajax.twig');
}
}
var xmlhttp = new XMLHttpRequest();
xmlhttp.onreadystatechange = function() {
if (this.readyState == 4 && this.status == 200) {
myObj = JSON.parse(this.responseText);
console.log(myObj);
document.getElementById("par").innerHTML = myObj[4].id;
}
};
xmlhttp.open("GET", "http://localhost/project/app/models/Ajax.php", true);
xmlhttp.send();
Błąd w konsoli: Uncaught SyntaxError: Unexpected token < in JSON at position 0
at JSON.parse (<anonymous>)
at XMLHttpRequest.xmlhttp.onreadystatechange (main.js:5)
Znając życie rozwiązanie jest proste ale już za długo mnie zatrzymuje ten problem dlatego proszę o pomoc jak ktoś wie jak sobie z tym poradzić.