微信公众号交互代码的一个问题

微信公众号交互代码的一个问题

往微信公众号发送关键词后可以调用自定义的接口进行处理,

wx微信设计了一套交互的协议,其中有一部分是传递的参数需要signature校验。wx微信本身提供了checkSignature函数。以前用过正常,但不知从什么时候起这部分代码总是返回false。

	private function checkSignature()
	{
		$signature = $_GET["signature"];
		$timestamp = $_GET["timestamp"];
		$nonce =$_GET["nonce"];
		$token =TOKEN;
		$tmpArr = array($token, $timestamp,$nonce);
		sort($tmpArr);
		$tmpStr = implode( $tmpArr);
		$tmpStr = sha1( $tmpStr);
		if($tmpStr == $signature){
			return true;
		}else{
			return false;
		}
	}

解决的方法有2个

1.简单粗暴,直接返回true,不进行校验,快速解决问题

2.找出原因解决它。

试了一下发现居然是sort这个函数,执行sort的结果和要求的不一致。

PHP sort() 函数用来对数组元素进行升序排序,也就是从低到高排序,语法如下:

bool sort ( array &$arr [, int $sort_mode = SORT_REGULAR ] )

参数说明:

  • arr 是要排序的数组。
  • sort_mode 表示排序模式,是一个可选参数。sort_mode 可以使用如下的值:
    • SORT_REGULAR:正常比较元素,不改变元素的类型(默认值)。
    • SORT_NUMERIC:元素被作为数字来比较。
    • SORT_STRING:元素被作为字符串来比较。
    • SORT_LOCALE_STRING:根据当前的区域(locale)设置把元素当作字符串比较,可以用 setlocale() 来改变。
    • SORT_NATURAL:和 natsort() 类似,对每个元素以“自然的顺序”对字符串进行排序,是 PHP 5.4.0 中新增的一个参数。
    • SORT_FLAG_CASE:能够与 SORT_STRING 或 SORT_NATURAL 合并(OR 位运算),不区分大小写排序字符串。


sort() 函数调用结束后, arr 数组元素会按照从低到高的顺序重新排列。

返回值:排序成功返回 TRUE,失败返回 FALSE。

可能和sort的对象的数据类型或者编码格式有关,最终通过指定排序的模式为Sort_STRING解决了问题。建议官方代码里也指明排序类型。

	private function checkSignature()
	{
		$signature = $_GET["signature"];
		$timestamp = $_GET["timestamp"];
		$nonce =$_GET["nonce"];
		$token =TOKEN;
		$tmpArr = array($token, $timestamp,$nonce);
		sort($tmpArr, SORT_STRING);
		$tmpStr = implode( $tmpArr);
		$tmpStr = sha1( $tmpStr);
		if($tmpStr == $signature){
			return true;
		}else{
			return false;
		}
	}

上一篇:class java.lang.RuntimeException/error reading Scala signature of package.class: Scala signature pac


下一篇:【转】微信一次性订阅消息流程