原因: json_encode($str) 中的字符串 必须是 utf-8的格式:

--------------------------------

问题描述:

返回的json数据:

 <?php
$array = array();
$rows = $parameter["list"];
$User = $parameter["User"];
$userId = $parameter["userId"];
$data = '';
$data.= '
<table class="table table-striped table-hover">
<tbody>';
foreach ($rows["rows"] as $row){
$data.= '<tr>
<td width="40px"><input type="checkbox" name="checkItem" value="'.$row->id.'" /></td>';
$data.= '<td width="200px">'.BaseUtil::setEntities($row->title).'</td>';
$User->getDataById($row->userId);
$data.= '<td width="200px">'.BaseUtil::setEntities($User->userName).'</td>';
$data.= '<td width="200px">'.'<img style="width:100px;" src="'.UPLOAD_HTTP.$row->icon.'"/>'.'</td>';
$data.= '<td width="200px">'.BaseUtil::setEntities($row->orderBy).'</td>';
$data.= '<td width="200px">'.BaseUtil::setEntities($row->isOpenEnum[$row->isOpen]).'</td>';
$data.= '<td width="200px">
<button type="button" class="btn btn-success btn-sm" onclick="base.addTab(\'知识点管理\',\'action.php?c=KnowledgeProxy&a=index&courseId='.$row->id.'\',\'课程管理\')">
<span class="glyphicon glyphicon-pencil" style="color:#fff; cursor:pointer;"></span>&nbsp;
知识点管理
</button>
</td>';
$data.= '<td width="100px">
<span class="table-list-btn glyphicon glyphicon-edit" title="编辑" style="color:#2e6da4; cursor:pointer;" onclick="base.showCourseUpdate('.$row->id.')"></span>&nbsp;
<span class="table-list-btn glyphicon glyphicon-trash" title="删除" style="color:#d43f3a; cursor:pointer;" onclick="base.removeCourse('.$row->id.')"></span>&nbsp;
</td>
</tr>';
}
$data.= '</tbody></table>';
$array ["data"] = $data;
$array ["total"] = $rows ["total"];
echo BaseUtil::toJson($array);
?>
setEntities 方法:
 /**
* 转字符换为实体
*
* @param unknown $string
* @return string
*/
public static function setEntities($string) {
return htmlentities ( $string);
}

出现的问题是 :

1)在公司里面 返回的json数据是正常的 . 例如:

  

2) 但是如果 是在家里 ,就出现错误. data 是null

{data: null , total:3}

同样的代码 ,只是因为在公司和 家中的php环境不同 就出现了不同的结果.

-----------

测试如果不使用:BaseUtil::setEntities($User->userName) 处理数据 ,直接用$User->userName 的话,在家中 就可以正常使用了.

BaseUtil::setEntities 是对函数 htmlentities的封装.

 /**
* 转字符换为实体
*
* @param unknown $string
* @return string
*/
public static function setEntities($string) {
return htmlentities ( $string );
}

查阅php手册中关于 htmlentities的描述:

可见,htmlentities 是要设置转换的格式的, 如果没有设置, 默认读取 php配置文件中的 default_charset;

同时在 php 5.4 之后  ,默认的转码为 utf-8 .

同时 ,json_encode 要求 字符串必须是utf-8的.

-------

所以问题 就是 我公司的电脑的php版本大于 5.4 ,使用 封装的BaseUtil::setEntities 自动转为 utf-8 ; 家中的电脑的php版本 低于5.4

----

解决办法:

第一: 将家中电脑的php.ini  的 default_charset 设置为 utf-8 , 但是没有起作用.

第二: 重写 BaseUtil::setEntities ,指定格式 . 此时家中 可以正常使用了.

 /**
* 转字符换为实体
*
* @param unknown $string
* @return string
*/
public static function setEntities($string) {
return htmlentities ( $string, ENT_COMPAT , 'utf-8' );
}

json_encode 处理后的数据是null的更多相关文章

  1. SqlServer触发器判断对表操作类型(增、删、改)并将修改后的数据映射到新表

    该文章为原创,日后可能会根据实际开发经验和网友评论,进行相应地方修改,为获得最新博客动态,望在转发博客的时候注明出处. 触发器要实现的功能: (1)获取对表Table1数据操作操作类型(insert. ...

  2. GDAL 遥感图像处理后的数据保存为图像文件的实现方法

    在遥感图像处理中,GDAL库不仅能读取和处理大部分的遥感图像数据,而且还能够实现图像处理后将数据保存为图像的功能. 本文就详细介绍如何将内存中的图像数据保存为.tif格式. 首先,遥感数据处理完,保存 ...

  3. opencv face-detection 代码分析 (1)人脸识别后的数据

    2014,3,16   老师的工作建议如下:   1. 与四民沟通下,把openCV这边的源代码和调用接口发给四民同时抄送给我. 2. 根据openCV的实时检测结果,实现对屏幕的调整(下周一前基本实 ...

  4. SQLSERVER中返回修改后的数据

    在公司看到同事写了个SQL2005的新特性的文章,觉得很实用,在这里和大家分享下. 这种技术主要是用到了inserted和deleted虚拟表,这两张表相信大家都很熟悉.以前我们主要是在触发器中使用. ...

  5. servlet 表单加上multipart/form-data后request.getParameter获取NULL(已解决)

    先上结论(可能不对,因为这是根据实践猜测而来,欢迎指正) 表单改为multipart/form-data传值后,数据就不能通过普通的request.getParameter获取. 文件和文件名通过Fi ...

  6. php数组使用json_encode函数中文被编码成null的原因和解决办法

    大写的囧,提客户处理问题,前端的APP一直在叽叽咂咂,说收到的值是null,弄了半天原来是这个问题,记录下吧 json格式在开发中用的十分广泛.在php中json_encode函数可以直接将数组转成 ...

  7. PDA手持扫描资产标签,盘点完成后将数据上传到PC端,固定资产系统查看盘点结果

    固定资产管理系统介绍: 致力于研发条码技术.集成条码系统的专业性公司,针对客户的不同需求,提供一站式的企业条码系统解决方案:包括功能强大的软件系统.安全可靠的无线网络.坚固耐用的硬件系统.灵活易用的管 ...

  8. 如何用perl将表格中不同列的数据进行拼凑,然后将拼凑后的数据用“|”连接在一起

    最近写了一个perl脚本,实现的功能是将表格中其中两列的数据进行拼凑,然后将拼凑后的数据用“|”连接在一起. 表格内容如下: 员工号码 员工姓名 职位 入职日期 1001 张三 销售 1980/12/ ...

  9. 【转】hive导入数据出现NULL

    在把hdfs上数据迁移到hive中的表时,若出现数据位NULL,是因为没有指定列分隔符. 由于hive默认的分隔符是/u0001(Ctrl+A),为了平滑迁移,需要在创建表格时指定数据的分割符号,语法 ...

随机推荐

  1. Pascal's Triangle 2(leetcode java)

    问题描述: Given an index k, return the kth row of the Pascal's triangle. For example, given k = 3,Return ...

  2. Remove Duplicates From Sorted Array leetcode java

    算法描述: Given a sorted array, remove the duplicates in place such that each element appear only once a ...

  3. 第一阶段——站立会议总结DAY08

    补发:因为第八次也就是第八天,那天有一个更重要的东西,看懂一个电商的系统.所以,未有进展.

  4. Js replace() 方法笔记

    最近捣鼓着学习Js,发现replace()真的很有用,替换功能杠杠的棒. 接下来看看我遇到的问题: 有两个随机给出的字符串,字符串1'xxxxxx',字符串2'====T'(这两个用作示例,其他为随机 ...

  5. 专题[vjudge] - 数论0.1

    专题[vjudge] - 数论0.1 web-address : https://cn.vjudge.net/contest/176171 A - Mathematically Hard 题意就是定义 ...

  6. Django信息安全相关之CSRF和XSS

    什么是xss攻击 xss攻击:黑客把恶意的JS脚本提交到后端,后端把恶意脚本渲染显示出来     什么是CSRF? 1.你登录建行官网后 你的浏览器就保存了建行网站的cokie,(如果不关闭这个页面c ...

  7. SSL证书读取

    证书内容: MIIDhDCCAmygAwIBAgIFAV0Imw0wDQYJKoZIhvcNAQELBQAwXDEnMCUGA1UEAwweczUwLTYyLTEzNS0xNS5zZWN1cmVzZX ...

  8. 整合elk(1)(十二)

    elk 简介 Elasticsearch是个开源分布式搜索引擎,它的特点有:分布式,零配置,自动发现,索引自动分片,索引副本机制,restful风格接口,多数据源,自动搜索负载等. Logstash是 ...

  9. 小程序证书申请FAQ

    1. 帮别人开发小程序, 先把你的微信号加到成员里, 并给予开发者权限,体验者权限,登录,数据分析,开发管理,开发设置 2. 需要https, 不能用windows2003,必须2008以上,用IIS ...

  10. js string对象方法

    substr(start,length) substring(start,end) 返回子串,原字符串不改变.