json_encode添加null:null条目

时间:2014-07-31 17:06:43

标签: php json

我有这个代码 - 我没有这样做:s并且没有时间替换已弃用的电话。

<?php

$mageFilename = 'app/Mage.php';
require_once $mageFilename;
umask(0);
Mage::app();

$db=mysql_connect('localhost','carros_mil1','K-Jw)ureB.}M');
mysql_select_db('carros_mil0',$db);
$nombreListModelo = 'modelo_'.str_replace(" ","_",strtolower($_REQUEST['nombreMarca']));

$sql = "SELECT DISTINCT (identificador) AS id
   FROM modelos
   WHERE nombre = '".$nombreListModelo."'";
$rs=mysql_query($sql);
$i=0;
while ($row = mysql_fetch_array($rs)) {
    $vectorModelo[$i] = $row['id'];
    $i++;
}

$sql = "SELECT attribute_id
    FROM eav_attribute
    WHERE attribute_code = '".$nombreListModelo."'";
$rs  = mysql_query($sql);
$row = mysql_fetch_array($rs);
$id1 = $row['attribute_id'];

$sql= "SELECT eao.option_id AS option_id
    FROM eav_attribute_option eao, eav_attribute_option_value eaov
    WHERE eao.option_id=eaov.option_id AND attribute_id = ".$id1." ORDER BY eaov.value";
$rs=mysql_query($sql);

$retorno = array();
$bandera = true;

while ($row = mysql_fetch_array($rs)) {

    $bandera = false;
    $sql2= "SELECT value, option_id
        FROM eav_attribute_option_value
        WHERE option_id = ".$row['option_id']."
        ORDER BY value";
    $rs2=mysql_query($sql2);
    $row2= mysql_fetch_array($rs2);

    if ($_REQUEST['bandera']=='vende') {
        if (!is_null($row2['value'])) $retorno[$row2['value']] = $row2['value'];
    } else {
        $existe=false;
        for($k=0;$k<count($vectorModelo);$k++) {
            if($row2['option_id'] == $vectorModelo[$k]) {
                $existe=true;
                break;
            }
        }
        if($existe) {
            if($_REQUEST['tipo']=='contactenos')
                if (!is_null($row2['value'])) $retorno[$row2['value']] = $row2['value'];
            else
                if (!is_null($row2['option_id'])) $retorno[$row2['option_id']] = $row2['value'];
        }
    }
}

if($bandera)
    $retorno[''] = 'Todos';

header('Content-Type: application/json');
//echo json_encode($retorno);
foreach($retorno as $k => $v) {
    printf("%s => %s\n", $k, $v);
}
print_r($retorno);
echo json_encode($retorno);

由于我在生成的json中发现了一些奇怪的东西,我添加了两种不同的打印数组内容的方法。

JSON方式为我添加了一个null:null条目。奇怪的是我每次添加元素时都会检查!is_null($row2['value'])

当我在某些参数下点击网址时,我得到:

Elantra => Elantra
Getz => Getz
H1 => H1
i-10 => i-10
New Accent => New Accent
Santa Fé => Santa Fé
Tucson => Tucson
Array
(
    [Elantra] => Elantra
    [Getz] => Getz
    [H1] => H1
    [i-10] => i-10
    [New Accent] => New Accent
    [Santa Fé] => Santa Fé
    [Tucson] => Tucson
)
{"Elantra":"Elantra","Getz":"Getz","H1":"H1","i-10":"i-10","New Accent":"New Accent",null:null,"Tucson":"Tucson"}

前6行对应于自定义打印foreach循环。还有一个print_r调用,只显示6个元素。第三种形式 - 这是我需要的实际形式 - 显示空值。

那么:当我事先检查空条件时,为什么$retorno接受空条目? 考虑此脚本已满 - 此处没有遗漏代码。

1 个答案:

答案 0 :(得分:1)

(谢谢@Hammerstein - 不知道你为什么不写这个作为答案)。

问题是其中一个值没有正确编码,因为它不是ANSI值而且没有用UTF8编码。这样,由于“SantaFé”有一个“奇怪的”字符,它被编码为null而不是“Santa F \ u00e9”。

提示:从不假设您的数据库使用 utf8 _ 字符集

解决方案是在编写数组时显式编码值:

...

$bandera = false;
$sql2= "SELECT value, option_id
    FROM eav_attribute_option_value
    WHERE option_id = ".$row['option_id']."
    ORDER BY value";
$rs2=mysql_query($sql2);
$row2= mysql_fetch_array($rs2);

//ENCODE the values to a good charset
$value = utf8_encode($row2['value']);
$option_id = utf8_encode($row['option_id'])

if ($_REQUEST['bandera']=='vende') {
    $retorno[$value] = $value;
} else {
    $existe=false;
    for($k=0;$k<count($vectorModelo);$k++) {
        if($row2['option_id'] == $vectorModelo[$k]) {
            $existe=true;
            break;
        }
    }
    if($existe) {
        if($_REQUEST['tipo']=='contactenos')
            $retorno[$value] = $value;
        else
            $retorno[$option_id] = $value;
    }
}

...