评论

微信小程序客服消息回复开发

微信提供了客服能力,本文记录了接入微信客服能力的两种方法,并且提供了代码片段。

概述

微信小程序为了提高小程序的服务质量,提供了客服消息能力,目的是为了让用户快捷地与小程序服务提供方进行沟通。小程序的客服消息回复有两种方式:一种是接入用户消息到微信公众平台网页版客服工具和客服小助手小程序进行客服消息回复,接入后客服可以看到用户留言,根据用户问题进行专门解答。一种是开启消息推送,当客服无法及时回复的时候能够指导用户联系客服人员或者解决问题。
如果需要接入微信公众平台网页版客服工具和客服小助手,只需要在小程序后台->客服里头添加客服人员就可以,客服人员就可以实时接收到用户消息并且与用户沟通。
如果需要开启消息推送可以参考下文的接入过程。

消息推送开发准备条件

  1. 在小程序中设置button组件并且把open-type属性设置为contact
  2. 前往小程序后台开发->开发设置->消息推送配置相关信息,可在此指定消息加密方式和数据格式。注意当开启了消息推送,普通微信用户向小程序客服发消息时,微信服务器会先将消息 POST 到开发者填写的 URL 上。在此处的填写我选择的是明文模式和JSON数据格式。

开发过程

处理初次验证

  1. 填写完消息推送的配置并且提交后,微信服务器将发送GET请求到填写的URL地址进行校验。因此首先要进行的就是针对微信服务器的初次校验做处理。微信官方在消息推送章节已经提出了校验代码此处便不再重复。
//微信服务器验证处理
if (isset($_GET['echostr'])) {
    //调用微信提供的校验代码
    if ($this->checkSignature() == false) { 
        exit();
    }
    $echoStr = $_GET['echostr'];
    echo $echoStr;
    exit;
}

处理消息

  1. 校验成功后,微信服务器会将用户在客服会话中的消息转发到开发者的服务器上,针对微信服务器传入的消息的类型,开发者们可以编写不同的业务逻辑处理。以用户在客服会话中写入文本为例:根据选择的数据格式JSON或者XML,微信服务器会传入相应格式的数据包。根据"MsgType"可以分辨微信服务器转发的是何种类型消息,并编写不同的业务逻辑。
//1接受微信推送消息
$message = $GLOBALS["HTTP_RAW_POST_DATA"];
$message = json_decode($message, true); 
//2判定用户发送消息的类型
if (!empty($message['MsgType']) && $message['MsgType'] == 'text') {
    //do something
}
  1. 在处理完微信转发的消息之后,开发者可以根需要调用服务端的客服消息发送接口发送消息给用户。
$fromUsername = $message['FromUserName'];   //发送者openid
$url = "https://api.weixin.qq.com/cgi-bin/message/custom/send?access_token=$access_token";//根据需要获取access_token
$data = array(
     "touser" => $fromUsername,
     "msgtype" => "text",
     "text" => array(
         "content" => "客服消息推送测试"
     )
);
$data = json_encode($data, JSON_UNESCAPED_UNICODE);
$result = httpRequest($url, "post", $data);
$result = json_decode($result, true);
if ($result['errcode'] == 0) { //当处理成功之后返回空字符串或者success都可以防止微信服务器重新发起请求
    echo "";
    exit;
}

转发客服消息

  1. 小程序设置了推送消息之后,还可以接入到网页版客服工具中,只需要设置返回数据的MsgType为transfer_customer_service返回给微信服务器。
//设置转发数据
$transferData = array(
    "ToUserName" => $message['FromUserName'],//用户的OpenID
    "FromUserName" => $message['ToUserName'],//小程序原始id
    "CreateTime" => $message['CreateTime'],//创建时间
    "MsgType" => "transfer_customer_service",//指定为transfer_customer_service 消息将会转发到客服工具中
);
$transferData = json_encode($transferData, JSON_UNESCAPED_UNICODE);

完整代码演示

//接受微信服务器转发的请求。
public function getMessage()
{
    // 判断是否为微信验证消息
    if (isset($_GET['echostr'])) {
        if ($this->checkSignature() == false) {
            exit();
        }
        $echoStr = $_GET['echostr'];
        echo $echoStr;
        exit;
    }
    //接受微信推送消息
    $message = $GLOBALS["HTTP_RAW_POST_DATA"];
    if (!empty($message)) {
        $access_token = $this->getAccess();//根据需要获取小程序对应的 access_token
        //设置转发客服消息
        $fromUsername = $message['FromUserName'];//消息发起用户的open_id
        $transferData = array(
           "ToUserName" => $fromUsername,//接收方帐号(用户的OpenID)
           "FromUserName" => $message['ToUserName'],//小程序原始id
           "CreateTime" => $message['CreateTime'],//创建时间
           "MsgType" => "transfer_customer_service",//指定为transfer_customer_service 消息将会转发到客服工具中
         );
        $transferData = json_encode($transferData, JSON_UNESCAPED_UNICODE);
        $message = json_decode($message, true);
          //判定消息类型并处理
        if (!empty($message['MsgType']) && $message['MsgType'] == 'text') {
             //调用send接口发送相对应的消息
            $url = "https://api.weixin.qq.com/cgi-bin/message/custom/send?access_token=$access_token";
            $data = array(
                 "touser" => $fromUsername,
                 "msgtype" => "text",
                 "text" => array(
                     "content" => "客服消息推送测试"
                 )
            );
            $data = json_encode($data, JSON_UNESCAPED_UNICODE);
            $result = httpRequest($url, "post", $data);
            $result = json_decode($result, true);
            //回复消息之后 不转发消息到客服系统 返回success 或者空字符串 避免微信提示严重错误 
            if ($result['errcode'] == 0) {
                echo "";
                exit;
            }
            //回复消息之后 转发客服消息到客服系统 将$transferData['MsgType']设置为transfer_customer_service
            //if ($result['errcode'] == 0) {
            //echo $transferData;
            //exit;
            //}
        }
    }
}
/**
 * 处理微信验证函数
 */
public function checkSignature()
{
    $signature = $_GET['signature'];
    $timestamp = $_GET['timestamp'];
    $nonce = $_GET['nonce'];
    $token = "customer12"; //填写在后台配置的Token(令牌)
    $tmpArr = array($token, $timestamp, $nonce);
    sort($tmpArr, SORT_STRING);
    $tmpStr = implode($tmpArr);
    $tmpStr = sha1($tmpStr); //加密
    if ($tmpStr == $signature) {
        return true;
    } else {
        return false;
    }
}

/**
 * CURL请求
 * @param $url 请求url地址
 * @param $method 请求方法 get post
 * @param null $postfields post数据数组
 * @param array $headers 请求header信息
 * @param bool|false $debug 调试开启 默认false
 * @return mixed
 */
function httpRequest($url, $method, $postfields = null, $headers = array(), $debug = false)
{
    $method = strtoupper($method);
    $ci = curl_init();
    curl_setopt($ci, CURLOPT_HTTP_VERSION, CURL_HTTP_VERSION_1_0);
    curl_setopt($ci, CURLOPT_USERAGENT, "Mozilla/5.0 (Windows NT 6.2; WOW64; rv:34.0) Gecko/20100101 Firefox/34.0");
    curl_setopt($ci, CURLOPT_CONNECTTIMEOUT, 60); /* 在发起连接前等待的时间,如果设置为0,则无限等待 */
    curl_setopt($ci, CURLOPT_TIMEOUT, 7); /* 设置cURL允许执行的最长秒数 */
    curl_setopt($ci, CURLOPT_RETURNTRANSFER, true);
    switch ($method) {
        case "POST":
            curl_setopt($ci, CURLOPT_POST, true);
            if (!empty($postfields)) {
                $tmpdatastr = is_array($postfields) ? http_build_query($postfields) : $postfields;
                curl_setopt($ci, CURLOPT_POSTFIELDS, $tmpdatastr);
            }
            break;
            default:
            curl_setopt($ci, CURLOPT_CUSTOMREQUEST, $method); /* //设置请求方式 */
            break;
    }
    $ssl = preg_match('/^https:\/\//i', $url) ? TRUE : FALSE;
    curl_setopt($ci, CURLOPT_URL, $url);
    if ($ssl) {
        curl_setopt($ci, CURLOPT_SSL_VERIFYPEER, FALSE); // https请求 不验证证书和hosts
        curl_setopt($ci, CURLOPT_SSL_VERIFYHOST, FALSE); // 不从证书中检查SSL加密算法是否存在
    }
    curl_setopt($ci, CURLOPT_FOLLOWLOCATION, 1);
    curl_setopt($ci, CURLOPT_MAXREDIRS, 2);/*指定最多的HTTP重定向的数量,这个选项是和CURLOPT_FOLLOWLOCATION一起使用的*/
    curl_setopt($ci, CURLOPT_HTTPHEADER, $headers);
    curl_setopt($ci, CURLINFO_HEADER_OUT, true);
    $response = curl_exec($ci);
    $requestinfo = curl_getinfo($ci);
    $http_code = curl_getinfo($ci, CURLINFO_HTTP_CODE);
    if ($debug) {
        echo "=====post data======\r\n";
        var_dump($postfields);
        echo "=====info===== \r\n";
        print_r($requestinfo);
        echo "=====response=====\r\n";
        print_r($response);
    }
    curl_close($ci);
    return $response;
}

最后一次编辑于  2019-05-29  
点赞 6
收藏
评论

18 个评论

  • ㅤ ㅤ ㅤ ㅤ
    ㅤ ㅤ ㅤ ㅤ
    2019-11-18

    我设置了客服人员我的服务器接不到用户发的任何消息了

    大神这是怎么回事

    2019-11-18
    赞同 3
    回复 2
    • Bingo
      Bingo
      2020-02-16
      有办法解决这个问题吗
      2020-02-16
      回复
    • 我                     ༽
      我   ༽
      2020-03-11
      可能是你微信客服界面已经接待了这个客户,取消接待就好了
      2020-03-11
      回复
  • 铭锋科技
    铭锋科技
    2019-06-03

    写得不错,能看懂

    2019-06-03
    赞同 2
    回复
  • 罗梅光
    罗梅光
    2019-09-23

    你好。真机无法打开客服,也不报错。<button open-type="contact"> 进入客服 </button>

    2019-09-23
    赞同 1
    回复 3
    • 痛快科技
      痛快科技
      2019-09-24
      换一个手机试试,或者重启试试
      2019-09-24
      回复
    • 罗梅光
      罗梅光
      2019-09-24回复痛快科技
      不可以。
      2019-09-24
      回复
    • 痛快科技
      痛快科技
      2019-09-24
      可以提供一个可以复现的代码片段
      2019-09-24
      回复
  • 2019-08-13

    你好 我用你的代码试了一下 但发现取到的 $GLOBALS["HTTP_RAW_POST_DATA"];  只有两个元素,一个ToUserName 和一个  Encrypt 。请问呢这个可能是什么原因造成的呢

    2019-08-13
    赞同 1
    回复 2
    • 痛快科技
      痛快科技
      2019-08-14
      看上面的回复,你用的是php7?
      2019-08-14
      回复
    • 2019-08-14回复痛快科技
      不是php7 5.4.45
      2019-08-14
      回复
  • !
    08-07

    php代码

    $data = json_encode($data, JSON_UNESCAPED_UNICODE); 

    python代码

    json_data = json.dumps(data, ensure_ascii=False

    为什么我发送的中文内容总是被编码了

    08-07
    赞同
    回复
  • 水云间
    水云间
    2022-02-17

    如果是加密模式呢?回复的信息需要加密吗

    2022-02-17
    赞同
    回复
  • for no reason
    for no reason
    2021-06-23

    你好,小程序客服接入服务端设置自动回复图片信息之后,是否可以再转回人工客服?之前听说接入服务端后,人工客服就收不到消息了

    2021-06-23
    赞同
    回复
  • 🎉 Teb
    🎉 Teb
    2020-03-19

    我按您这样写,当发送消息给公众号时,显示该公众号提供的服务出现故障,请稍后再试,求解答

    2020-03-19
    赞同
    回复
  • 2019-11-25

    有没有大神教学的 我出钱 只想学做微信客服聊天程序

    2019-11-25
    赞同
    回复
  • 周生雪
    周生雪
    2019-11-14

    接收到的消息json格式里面都有哪些属性,如果是小程序类型的消息有办法取到path里面的参数吗

    2019-11-14
    赞同
    回复

正在加载...

登录 后发表内容