0

首先我要告诉你,这是我在 php 和 JSON 上的第一步。

我决定使用 JSON 从客户 SQL 表中获取价值。

我使用这个脚本得到我的结果:

mysql_connect($config['mysql_host'],$config['mysql_user'],$config['mysql_pass']);
//select database
@mysql_select_db($config['db_name']) or die( "Unable to select database");


mysql_query('SET CHARACTER SET utf8');

$fet=mysql_query('select * from  vehicule');

$json = array();

while($r=mysql_fetch_array($fet)){
    $json[] = $r;
}

header('Content-Type: application/json');


echo $json_data=json_encode($json);

一切都很好,除了我的 JSON 结果如下所示:

        0 = 462;
        1 = "Hyundai ix20 crdi 115 panoramic sunsation";
        10 = 1346450400;
        11 = "462-Hyundai-ix20-crdi-115-panoramic-sunsation";
        12 = 462;
...

       id = 462;
        kilometrage = 14400;
        marque = 4;
        modele = 137;
        motorisation = 2;
        ordre = 462;
        prix = 17500;
        puissance = 6;
        titre = "Hyundai ix20 crdi 115 panoramic sunsation";
        url = "462-Hyundai-ix20-crdi-115-panoramic-sunsation";

...

我有 2 个版本的表格结果:一个带有 0:value、1:value、2...,另一个使用 table 键,我怎样才能只打印第二个?

顺便说一句,有人可以给我链接,这样我就可以知道我必须更换哪些认为过时的 mysql ?(我是使用 PHP 几个小时的初学者)

非常感谢 !

4

1 回答 1

1

你有两个不同的问题发生在这里。一个是直接导致你所看到的问题,另一个是一个糟糕的实践错误,从长远来看会让你面临麻烦。

第一个问题是您要询问的问题。mysql_fetch_array 函数(请参阅此处的文档)需要您提供的至少一个输入(结果输入)。它还有第二个可选输入。该可选输入默认为 MYSQL_BOTH,它返回一个关联数组,其结果可通过键(列名)及其索引获得。也就是说,如果您选择列 'id',您将在 $array[0] 和 $array['id'] 中获得它的值。它是重复的,因此 JSON 过程会继承重复。您需要为函数提供第二个值,MYSQL_ASSOC 以获取 $array['id'] 或 MYSQL_NUM 以获取 $array[0]。

您的第二个问题是功能的选择。您正在使用“原始”mysql 函数。这些已被贬值,这是一个技术术语,意思是“不再支持这些功能,但我们已将它们保留下来,以便您有时间修复遗留代码”。对于遗产,请阅读“旧”。这些函数很快就会消失,您需要升级到更好的选择——mysqli 函数或 PDO 类。我强烈推荐 PDO 课程,因为一旦你学会了它,它就很容易学习并且具有更便携的优势。无论您使用哪种设置,您都需要学习使用准备好的语句作为性能和安全问题。目前,您正在处理“原始”语句,这些语句很容易通过所谓的“ 注入攻击”。您可以看到此类攻击的虚构示例在这里,网上有很多关于它的文章。这些攻击可能非常复杂且难以对抗,因此强烈建议使用准备好的语句(为您处理它)。在您在这里使用的特定示例中,您无需担心它,因为您没有包含任何用户输入,但这是一个重要的习惯。

于 2013-09-11T23:12:47.777 回答