我有一個基於PHP瘦客戶端的API,並希望爲我的網站生成JSONP。當我致電網站時:'http://api.mangayurdu.com/users?callback=JSON_CALLBACK'。它返回一個帶有JSON CALLBACK()的空白頁面。登錄到控制檯時,它是未定義的。未定義的JSONP跨域
API的index.php文件:
<?php
require 'vendor/autoload.php';
$app = new \Slim\Slim();
$app->contentType('application/json');
$app->get('/users', 'getUsers');
$app->run();
function getConnection() {
$dbhost="localhost";
$dbuser="";
$dbpass="";
$dbname="";
$dbh = new PDO("mysql:host=$dbhost;dbname=$dbname;mysql:charset=utf8mb4", $dbuser, $dbpass);
$dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
return $dbh;
}
function getUsers() {
$sql = "select * FROM manga";
try {
$db = getConnection();
$stmt = $db->query($sql);
$users = $stmt->fetchAll(PDO::FETCH_OBJ);
$db = null;
echo $_GET['callback'] . '('.json_encode($users).')';
}
catch(PDOException $e) {
echo $_GET['callback'] . '('.json_encode($e->getMessage()).')';
}
}
的Javascript:
.factory('MY', function($http){
var fax= {};
var url = 'http://api.mangayurdu.com/users?callback=JSON_CALLBACK';
fax.isimler = $http.jsonp(url);
return fax;
})
.controller('indexCtrl', function($scope, MY) {
MY.isimler.success(function(alHemen){
$scope.mangas = alHemen;
});
})
@JamesThorpe - 「它的空白頁上寫有JSON CALLBACK()」。 - 回調函數的參數未定義。 – Quentin
@Quentin所以我的用戶變量是空的?它沒有連接到數據庫? – Nasuh
@Nasuh - 不知道。自從添加PDO之前,我還沒有使用過PHP。我不知道它如何對連接失敗做出反應。 – Quentin