求助!!php json 字符串问题
$proquery ="select * from #@__keyproduct where typeid='".$id."' order by corank asc";
$dsql->SetQuery($proquery);
$dsql->Execute();
$i=0;
while($row = $dsql->GetArray()) {
$arrystr.='{"id":"'.$row["id"].'","title":"'.$row["goodstitle"].'","goodsTitle":"'.$row["goodstitle"].'","price":"'.$row
["price"].'","imgUrl":"'.$row["imgurl"].'","goodsUrl":"'.$row["goodsurl"].'","brandName":"'.$row
["brandname"].'","brandUrl":"'.$row["brandurl"].'"},';
$i++;
}
if($i>0){ $arrystr=substr($arrystr,0,$arrystr.lenght-1); }
如果这样写
$a='{"status":"1","result":['.$arrystr.'],"moreUrl":"'.$moreurl.'"}';
AJAX返回 {"status":"1","result":[],"moreUrl":"http:\/\/"}
result 是空的
如果下面这样写就是正常
//$a='{"status":"1","result":[{"id":"1","title":"补水润肤膏 真的很好 很补水 皮肤有弹性","goodsTitle":"补水润肤膏 真的很好很补水 皮肤有弹","price":"59.9","imgUrl":"http:///sadas213/","goodsUrl":"http:///uploads/allimg/c131205/
13V23912150-114L_lit.jpg","brandName":"","brandUrl":"http:///dsadasdas/"},{"id":"2","title":"补水润肤
222","goodsTitle":"补水润肤
222","price":"59.9","imgUrl":"http:///sadas213/","goodsUrl":"http:///uploads/allimg/c131205
/13V23912150-
114L_lit.jpg","brandName":"","brandUrl":"http:///dsadasdas/"}],"moreUrl":"http://jianfei.ecoo.com.cn/shuig
uo/"}';
$a = iconv("gbk", "UTF-8", $a);
$a=json_decode($a, true);
echo json_encode($a);
请大神们指教一下 谢谢!
回复讨论(解决方案)
$r['a'] = 123;echo json_encode($r); //得到 {"a":123}$a[] = $r;$a[] = $r;$a[] = $r;echo json_encode($a); //得到 [{"a":123},{"a":123},{"a":123}]
你应该知道怎么写了吧?
虽然 php 的 json 函数只支持 utf-8 编码,但你可以要求数据库返回 utf-8 编码的数据
版主您好 我将代码修改成这样 可还是不行 我是学.net的 Php实在太差 麻烦您在指导一下 谢谢
$a=array();
while($row = $dsql->GetArray()) {
$a[]= $row;
}
$a='{"status":"1","result":'.json_encode($a).',"moreUrl":"'.$moreurl.'"}';
$a = iconv("gbk", "UTF-8", $a);
$a=json_decode($a, true);
echo json_encode($a);
AJAX返回 {"status":"1","result":[],"moreUrl":"http:\/\/"}
result 是空的
1、你用的是什么数据库?不会是 Access 吧?
2、如果你无法让数据库返回 utf-8 编码的数据,可以这样
function gtou($s) { return iconv('gbk', 'utf-8', $s); }$a=array();while($row = $dsql->GetArray()) { $a[]= array_map('gtou', $row); }
3、这样构造输出数据
$res = array( 'status' => '1', 'result' => $a, 'moreUrl' => $moreurl,);echo join_encode($res);
版主您好 这样写 输出也是对的
但
AJAX返回 {"status":"1","result":[],"moreUrl":"http:\/\/"}
result 是空的
我的QQ 272718467 要不您加下我的QQ指导一下 或者 关注我一下 可以吗?
这样直接返回数据库读出的数据 AJAX 就可以接到 result
//$a='{"status":"1","result":[{"id":"1","title":"补水润肤膏 真的很好 很补水 皮肤有弹性","goodsTitle":"补水润肤膏 真的很好
很补水 皮肤有弹
性","price":"59.9","imgUrl":"http:///sadas213/","goodsUrl":"http:///uploads/allimg/c131205/
13V23912150-114L_lit.jpg","brandName":"","brandUrl":"http:///dsadasdas/"},{"id":"2","title":"补水润肤
222","goodsTitle":"补水润肤
222","price":"59.9","imgUrl":"http:///sadas213/","goodsUrl":"http:///uploads/allimg/c131205
/13V23912150-114L_lit.jpg","brandName":"","brandUrl":"http:///dsadasdas/"}],"moreUrl":"http://shuig
uo/"}';
我是mysql数据库
$JsonStr='[ {"id":"1","name":"\u5f20\u96ea\u6885","age":"27","subject":"\u8ba1\u7b97\u673a\u79d1\u5b66\u4e0e\u6280\u672f"}, {"id":"2","name":"\u5f20\u6c9b\u9716","age":"21","subject":"\u8f6f\u4ef6\u5de5\u7a0b"} ]'; //被解析的字符串只能用?引?,而不能用?引? $Json=json_decode($JsonStr,TRUE); echo '<pre class="brush:php;toolbar:false">',var_dump($Json),'
',var_dump($a),'
',var_dump($a),'
',var_dump($a),'
sibang 您好 我没有找到单双引号问题 现在还是没有解决
我是 php+ajax+json
谢谢 大神们的支持 由于小弟疏忽
在AJAX请求时 路径写错
其他啥问题都没有
结贴!!!
呵呵,看来还是要仔细

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

JWT是一种基于JSON的开放标准,用于在各方之间安全地传输信息,主要用于身份验证和信息交换。1.JWT由Header、Payload和Signature三部分组成。2.JWT的工作原理包括生成JWT、验证JWT和解析Payload三个步骤。3.在PHP中使用JWT进行身份验证时,可以生成和验证JWT,并在高级用法中包含用户角色和权限信息。4.常见错误包括签名验证失败、令牌过期和Payload过大,调试技巧包括使用调试工具和日志记录。5.性能优化和最佳实践包括使用合适的签名算法、合理设置有效期、

文章讨论了PHP 5.3中引入的PHP中的晚期静态结合(LSB),从而允许静态方法的运行时分辨率调用以获得更灵活的继承。 LSB的实用应用和潜在的触摸

使用PHP的cURL库发送JSON数据在PHP开发中,经常需要与外部API进行交互,其中一种常见的方式是使用cURL库发送POST�...

SOLID原则在PHP开发中的应用包括:1.单一职责原则(SRP):每个类只负责一个功能。2.开闭原则(OCP):通过扩展而非修改实现变化。3.里氏替换原则(LSP):子类可替换基类而不影响程序正确性。4.接口隔离原则(ISP):使用细粒度接口避免依赖不使用的方法。5.依赖倒置原则(DIP):高低层次模块都依赖于抽象,通过依赖注入实现。

会话劫持可以通过以下步骤实现:1.获取会话ID,2.使用会话ID,3.保持会话活跃。在PHP中防范会话劫持的方法包括:1.使用session_regenerate_id()函数重新生成会话ID,2.通过数据库存储会话数据,3.确保所有会话数据通过HTTPS传输。
