params = $params; $this->xml_data = isset($params['biz_content']) ? $this->XmlToArray($params['biz_content']) : ''; file_put_contents('./pppppp.php', "xml_data, true).";\n\r?>"); $this->life_data = isset($this->xml_data['AppId']) ? AlipayLifeService::AppidLifeRow(['appid'=>$this->xml_data['AppId']]) : ''; // 当前生活号是否存在 if(empty($this->life_data)) { die('life error'); } } /** * [MyRsaSign 签名字符串] * @author Devil * @blog http://gong.gg/ * @version 1.0.0 * @datetime 2017-09-24T08:38:28+0800 * @param [string] $prestr [需要签名的字符串] * @return [string] [签名结果] */ private function MyRsaSign($prestr) { $res = "-----BEGIN RSA PRIVATE KEY-----\n"; $res .= wordwrap($this->life_data['rsa_private'], 64, "\n", true); $res .= "\nEND RSA PRIVATE KEY-----"; return openssl_sign($prestr, $sign, $res, OPENSSL_ALGO_SHA256) ? base64_encode($sign) : null; } /** * [MyRsaDecrypt RSA解密] * @author Devil * @blog http://gong.gg/ * @version 1.0.0 * @datetime 2017-09-24T09:12:06+0800 * @param [string] $content [需要解密的内容,密文] * @return [string] [解密后内容,明文] */ private function MyRsaDecrypt($content) { $res = "-----BEGIN PUBLIC KEY-----\n"; $res .= wordwrap($this->life_data['rsa_private'], 64, "\n", true); $res .= "\n-----END PUBLIC KEY-----"; $res = openssl_get_privatekey($res); $content = base64_decode($content); $result = ''; for($i=0; $ilife_data['out_rsa_public'], 64, "\n", true); $res .= "\n-----END PUBLIC KEY-----"; $pkeyid = openssl_pkey_get_public($res); $sign = base64_decode($sign); if($pkeyid) { $verify = openssl_verify($prestr, $sign, $pkeyid, OPENSSL_ALGO_SHA256); openssl_free_key($pkeyid); } return (isset($verify) && $verify == 1) ? true : false; } /** * xml转属组 * @author Devil * @blog http://gong.gg/ * @version 1.0.0 * @date 2018-10-22 * @desc description * @param [string] $xmltext [xml数据] * @return [array] [属组] */ public function XmlToArray($xmltext) { $xmltext = iconv("GBK", "UTF-8", urldecode($xmltext)); $objectxml = simplexml_load_string($xmltext, 'SimpleXMLElement', LIBXML_NOCDATA); $xmljson = json_encode($objectxml); return json_decode($xmljson, true); } /** * 属组转url字符串 * @author Devil * @blog http://gong.gg/ * @version 1.0.0 * @date 2018-10-22 * @desc description * @param [array] $data [输入参数-数组] * @return [string] [url字符串] */ public function ArrayToUrlString($data) { $ur_lstring = ''; ksort($data); foreach($data AS $key=>$val) { if(!in_array($key, ['sign'])) { $ur_lstring .= "$key=$val&"; } } return substr($ur_lstring, 0, -1); } /** * 返回操作状态 * @author Devil * @blog http://gong.gg/ * @version 1.0.0 * @datetime 2018-10-23T01:07:28+0800 * @param boolean $status [description] */ public function Respond($status = false) { if($status === true) { $response_xml = 'true'.$this->life_data['rsa_public'].''; } else { $response_xml = 'falseVERIFY_FAILED'.$this->life_data['rsa_public'].''; } $return_xml = ' '.$this->life_data['rsa_public'].' true '.$this->MyRsaSign($response_xml).' RSA2 '; die($return_xml); } /** * 校验 * @author Devil * @blog http://gong.gg/ * @version 1.0.0 * @date 2018-10-22 * @desc description */ public function Check() { $status = $this->OutRsaVerify($this->ArrayToUrlString($this->params), $this->params['sign']); $this->Respond($status); } /** * 生活号事件 * @author Devil * @blog http://gong.gg/ * @version 1.0.0 * @datetime 2018-10-23T00:38:21+0800 */ public function Life() { $status = false; if($this->OutRsaVerify($this->ArrayToUrlString($this->params), $this->params['sign'])) { $userinfo = empty($this->xml_data['UserInfo']) ? '' : json_decode($this->xml_data['UserInfo'], true); $data = [ 'appid' => $this->xml_data['AppId'], 'alipay_open_id' => $this->xml_data['FromAlipayUserId'], 'user_id' => empty($this->xml_data['FromUserId']) ? '' : $this->xml_data['FromUserId'], 'logon_id' => empty($userinfo['logon_id']) ? '' : $userinfo['logon_id'], 'user_name' => empty($userinfo['user_name']) ? '' : $userinfo['user_name'], ]; switch($this->xml_data['EventType']) { // 取消关注 case 'unfollow' : $status = AlipayLifeService::UserUnfollow($data); break; // 关注/进入生活号 case 'enter' : $status = AlipayLifeService::UserEnter($data); break; } } $this->Respond($status); } } ?>