先吐一下槽,微信官方的api文档,写的真TM的绕,真是刚爬出一个坑,然后又掉进另一个坑。

正文:

遇到问题:微信第三方平台全网发布检测失败,提示“返回Api文本信息 失败”。

第三方 返回后session丢失_python

 

官方测试要求

先看一下微信官方文档对第三方平台的“返回Api文本消息”功能的检测要求(下图):

第三方 返回后session丢失_php_02

也就是这个检测要求的目的是:检测第三方平台,是否实现了,调用已授权的的公众号的api(这里是公众号的客服消息接口)的功能——也就是第三方平台代替公众号回复消息给粉丝的功能。

实现过程是:

1、微信往第三方平台的“公众号消息与事件接收URL” ,转发一条来自粉丝的发给授权公众号的文本消息(xml格式)。这条文本消息有些特殊,特殊在 Content字段的内容固定为: QUERY_AUTH_CODE:$query_auth_code$ (见下图的xml信息)。注意这里的$query_auth_code$,我们稍后要获取到这个值,进行下一步操作。

第三方 返回后session丢失_php_03

2、第三方平台接收到这条消息后,首先要先解密,然后获取FromUserName,Content的内容,因为FromUserName的值就是粉丝的openid,下一步就是要回复消息给这个openid。至于Content的值,我们要从里面截获$query_auth_code$。

    1.  $openid= $xml->getElementsByTagName('FromUserName')->item(0)->nodeValue;   
    2.  $Content= $xml->getElementsByTagName('Content')->item(0)->nodeValue;   
    3.  $query_auth_code = trim(str_replace("QUERY_AUTH_CODE:","",$Content));

    3、第三方平台拿着获取到的$query_auth_code,调用获取公众号授权的Api(下图),获取到该公众号的授权信息——也就是为了获取公众号的 authorizer_access_token 。我一直出错就是在此处。注意下面要post给接口的数据里authorization_code,就是第二步里拿到的$query_auth_code

    https://api.weixin.qq.com/cgi-bin/component/api_query_auth?component_access_token=xxxx

    POST数据示例:

    {
     "component_appid":"appid_value" ,
     "authorization_code": $query_auth_code
    }

    4、第三方平台使用第三步获取到的authorizer_access_token来调用公众号的“客服消息接口”(见下面的url),回复消息给粉丝$openid。要注意发送的消息是固定的: $query_auth_code$_from_api ,也就是将第二步里获取的 $query_auth_code和“_from_api”拼接成字符串。



    http请求方式: POST
    https://api.weixin.qq.com/cgi-bin/message/custom/send?access_token=authorizer_access_token



    发送文本消息



    {
        "touser":$openid,
        "msgtype":"text",
        "text":
        {
             "content":$query_auth_code$_from_api
        }
    }


    基本上按照上面的步骤做,就可以获得检测通过