gpt4 book ai didi

javascript - Ionic、PHP、MySQL 和 JSONP 与 Angular

转载 作者:行者123 更新时间:2023-11-29 21:52:55 26 4
gpt4 key购买 nike

我试图将参数从我的 php 页面获取到 Android 应用程序,

这里是js.php上的代码

<?php header('content-type: application/json; charset=utf-8');
$rest=$_GET['rest'];

if ($rest=="query"){
$sql = "SELECT * FROM post";
$result = $conn->query($sql);

$emparray = array();
while($row =mysqli_fetch_assoc($result))
{
$emparray['posts'] = $post;
$post[] = str_replace('"', "'", $row);
}
$json = json_encode($emparray);

echo isset($_GET['callback'])
? "{$_GET['callback']}($json)"
: $json;
}
?>

我在我的服务器上使用.htaccess

RewriteEngine On
Options +FollowSymLinks -MultiViews
RewriteRule ^rest/([A-Za-z]+)/?$ js.php?rest=$1 [NC,L]
RewriteCond %{REQUEST_FILENAME} !-f
RewriteRule ^([^\.]+)$ $1.php [NC,L]

RewriteCond %{HTTP_HOST} !^www.domain.com$ [NC]
RewriteRule ^(.*)$ http://www.domain.com/$1 [L,R=301]

最后,我在 ionic 上的 js www\js\app.js

var App = angular.module('App', ['ionic']);


App.service("Robo", ["$http", "$log", Robo])
App.controller("AppCtrl", ["$scope", "Robo", "$log", AppCtrl]);


function AppCtrl($scope, Robo, $log){
$scope.posts = [];
$scope.refresh = function(){
Robo.getBlogs($scope);
}
}
function Robo($http, $log) {
this.getBlogs = function($scope){
$http.jsonp("http://www.domain.com/rest/query?callback=JSON_CALLBACK")
.success(function(result){
$scope.posts = result.posts;
$scope.$broadcast("scroll.refreshComplete");
});
}
}

在index.html

<html lang="en" data-ng-app="App">
<ion-content>
<ion-refresher on-refresh="refresh()"></ion-refresher>
<div data-ng-show="!posts.length">
<br><br>
<center>
<h1>Pull to Refresh</h1>
</center>
</div>
.
.
.

我被困在这里,数组 $scope.posts 上没有数据,所以当我拉刷新时,加载永远不会结束。请帮助并建议我解决这个问题

最佳答案

您没有进行任何类型的正确错误处理。 mysqli::query很可能是FALSE

您最大的问题似乎是您不了解变量的生命周期。一个典型的变量先声明,然后实例化,然后以某种方式使用,最后删除。 PHP 不是强类型的,因此变量通常是同时声明和实例化的。一旦变量超出范围,PHP 也会为您删除该变量。

现在让我们看一下您的代码。我在每行后面添加了每个变量包含的注释:

/* $emparray = NULL */
$emparray = array();
/* $emparray = Array() */
while($row =mysqli_fetch_assoc($result))
{
/* $post = NULL
* $emparray = Array() (1st time) or...
* $emparray = Array( "posts" => NULL )
* $row = Array( content )
*/
$emparray['posts'] = $post;
/* $post = NULL
* $emparray = Array( "posts" => NULL )
* $row = Array( content )
*/
$post[] = str_replace('"', "'", $row);
/* $post = Array( 0 => content_with_quotes_replaced )
* $emparray = Array( "posts" => NULL )
* $row = Array( content )
*/
}
/* $emparray = Array( "posts" => NULL */
$json = json_encode($emparray);

这不是很有用,是吗?您正在为 $post 分配一个值,然后让它超出范围。每次执行循环时,您还将 $emparray 中的关键“posts”替换为 $post 变量的内容。由于 $post 变量未定义,因此此时它的值将始终为 NULL。

您的代码存在的另一个问题是,如果查询不返回任何结果,则循环将不会运行,因此您最终会得到一个完全没有“posts”键的数组。

一个更晦涩的问题是,通过将 $row 中的双引号替换为单引号,您最终可能会得到一些没有意义的内容。您可能想转义引号。

<小时/>

那么,您如何改进这一点呢?首先为$emparray选择一个更好的名称。它没有传达这个变量的含义。将 posts-key 添加到该数组中,并使用空数组作为值。对 $row 执行您需要执行的任何操作,并将结果放入其自己的变量中。然后使用您已使用的语法将其添加到结果数组中 ($variable['posts'][] = ...)。最后将其转换为 json 格式的字符串。

关于javascript - Ionic、PHP、MySQL 和 JSONP 与 Angular,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33459067/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com