JSON

解决PHPCMS使用getJSON调用的地址方法无效

字号+ 作者:H5之家 来源:H5之家 2015-10-04 17:12 我要评论( )

今天遇到一个getJSON的问题,回调函数一直无法执行,检查了生成的json数据的格式绝对没问题,getJSON的js语法也没问题,但就是alert不出来传回的数据。原来是php

今天遇到一个getJSON的问题,回调函数一直无法执行,检查了生成的json数据的格式绝对没问题,getJSON的js语法也没问题,但就是alert不出来传回的数据。原来是phpcms的check_hash()函数对远程调用的方法进行了安全验证,方法名前没public_的都不能通过。

/**
 * 检查hash值,验证用户数据安全性
 */

 代码如下 复制代码

final private function check_hash() {
 if(preg_match('/^public_/', ROUTE_A) || ROUTE_M =='admin' && ROUTE_C =='index' || in_array(ROUTE_A, array('login'))) {
  return true;
 }
 if(isset($_GET['pc_hash']) && $_SESSION['pc_hash'] != '' && ($_SESSION['pc_hash'] == $_GET['pc_hash'])) {
  return true;
 } elseif(isset($_POST['pc_hash']) && $_SESSION['pc_hash'] != '' && ($_SESSION['pc_hash'] == $_POST['pc_hash'])) {
  return true;
 } else {
  showmessage(L('hash_check_false'),HTTP_REFERER);
 }
}

phpcms给函数进行了hash验证,因此,现在方法是这样写的:

 代码如下 复制代码

public function public_mobile_getjson_ids() {//publc是后来加上去的
 $modelid = intval($_GET['modelid']);
 $id = intval($_GET['id']);
 $this->db->set_model($modelid);
 $tablename = $this->db->table_name;
 $this->db->table_name = $tablename.'_data';
 $r = $this->db->get_one(array('id'=>$id),'mobile_type');
 
 if($r['mobile_type']) {
  $relation = str_replace('|', ',', $r['mobile_type']);
  $relation = trim($relation,',');
  $where = "id IN($relation)";
  $infos = array();
  $this->mobile_db = pc_base::load_model ( 'mobile_type_model' );
  $datas = $this->mobile_db->select($where,'id,type_name');
  //$this->db->table_name = $tablename;
  //$datas = $this->db->select($where,'id,title');
  foreach($datas as $_v) {
   $_v['sid'] = 'v'.$_v['id'];
   if(strtolower(CHARSET)=='gbk') $_v['type_name'] = iconv('gbk', 'utf-8', $_v['type_name']);
   $infos[] = $_v;
  }
  echo json_encode($infos);
 }
}

js部分的getJSON是这样写的:

 代码如下 复制代码

//显示添加机型
function show_mobiletype(modelid,id) {
 $.getJSON("?m=content&c=content&a=public_mobile_getjson_ids&modelid="+modelid+"&id="+id, function(json){
  var newrelation_ids = '';
  if(json==null) {
   alert('没有添加相关文章');
   return false;
  }
  $.each(json, function(i, n){
   newrelation_ids += "<li>·<span>"+n.type_name+"</span><a href='javascript:;' onclick="remove_relation('"+n.sid+"',"+n.id+")"></a></li>";
  });
 
  $('#mobile_type_text').html(newrelation_ids);
 });
}

就好了。要注意phpcms里面调用远程地址,方法前加上public啊!!

 原文来自: 感谢 小谈博客

 

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

相关文章
  • 浅谈使用PHP开发微信支付的流程

    浅谈使用PHP开发微信支付的流程

    2016-02-13 15:00

  • Unity3D脚本:Unity3D使用LitJson解析服务器上的JSON

    Unity3D脚本:Unity3D使用LitJson解析服务器上的JSON

    2016-01-31 10:32

  • WebServices中使用JSON

    WebServices中使用JSON

    2016-01-24 18:13

  • 如何使用SBJson

    如何使用SBJson

    2016-01-23 08:01

网友点评