privateDecrypt($content); print_r($content);die; } public function query() { # 查看当前余额 $sid = Dever::input('sid'); $cash = $this->query_action($sid); return $cash; } public function query_action($sid) { $class = new Chinaums(); $data = $class->query($sid); return $data; } public function record() { # 查看提现记录 $sid = Dever::input('sid'); $start = Dever::input('start'); $end = Dever::input('end'); $log = $this->record_action($sid, $start, $end); return $log; } public function record_action($sid, $start, $end) { $class = new Chinaums(); $log = $class->record($sid, $start, $end); return $log; } public function act() { $order = Dever::order(); $result = $this->action('89810007372107C', $order, -1, 2, 127); return $result; } public function action($mid, $order, $order_id, $type, $cash, $order_info = array()) { $class = new Chinaums(); $notify = Dever::url('yspay.notify?order=' . $order, 'shop'); $result = $class->act($mid, $order, $order_id, $type, $cash, $notify, $order_info); return $result; } public function notify() { $msg = Dever::input(); Dever::log($msg, 'yspay'); $order = $msg['order']; if (!$order) { echo 'FAILED';die; } if (strstr($order, 'SD')) { $log = Dever::db('shop/yspay_tixian_log')->one(array('order_num' => $order)); if ($log) { Dever::db('shop/yspay_tixian_log')->update(array('where_id' => $log['id'], 'status' => 2, 'response' => Dever::json_encode($content))); $account = Dever::db('shop/yspay_account')->one(array('shop_id' => $log['shop_id'])); if ($account) { Dever::db('shop/yspay_account')->dec(array('where_id' => $account['id'], 'set_cash' => $log['cash'])); } } echo 'SUCCESS';die; } $where['order_num'] = $order; $order = Dever::db('shop/sell_order')->find($where); $class = new Chinaums(); if ($order && $order['withdraw'] == 1) { $content = $msg['content']; $content = $class->privateDecrypt($content); $log = Dever::db('shop/yspay_tixian_log')->one(array('order_num' => $order, 'shop_id' => $order['shop_id'])); if ($content && isset($content['responseCode']) && ($content['responseCode'] == '000000' || $content['responseCode'] == '000001')) { Dever::db('shop/sell_order')->update(array('where_id' => $order['id'], 'withdraw' => 2)); if ($log) { Dever::db('shop/yspay_tixian_log')->update(array('where_id' => $log['id'], 'status' => 2, 'response' => Dever::json_encode($content))); $account = Dever::db('shop/yspay_account')->one(array('shop_id' => $log['shop_id'])); if ($account) { Dever::db('shop/yspay_account')->dec(array('where_id' => $account['id'], 'set_cash' => $log['cash'])); } } echo 'SUCCESS';die; } else { Dever::load('shop/lib/cron')->yspayOne($order); } } echo 'FAILED';die; } } /** * 银联商务代付 * Class Chinaums */ class Chinaums { //测试地址 protected $test_host = 'https://mobl-test.chinaums.com/'; //正式地址 protected $host = 'https://managefree.chinaums.com/'; //系统编号(sysId) protected $sys_id = '10119'; //商户号 protected $mch_id = '89810007372106N'; //外部平台私钥 protected $private_key = 'MIIEowIBAAKCAQEApzpOtvWGclmdw+/aEzAxwyTgUwnC9qjQEhL+qfMWDBIbFR8N4q6GQ8fRKZ9Zyvm0voFhgpH44Y6sh2U7rF9HQOuw2puywvU8kk5JAUxpxykbH7QqW/ijH1gBG3Ck/Ip/5I4co+q9K/CjQRmId5nSJ8ffnaiAOogNZycrP+AgEEU8vL1eNtnagVxT3EC1LEh0wBwecT9Tkyi0tMD0sMeIUl9POrnh7YADJtUzGf+TTNrqK6DhoT9mE3Plw0pqxKSk4/tHNx1ZIXf4I/UeYSEAreXHWVfLQ/if1C9HRYhEGB57mmqn0JdmsSRD7DX7eU7Oja+RqtWfQ/KH+2fnjq9uSwIDAQABAoIBABACUvrM8nwL/EB/u77OhFUMOLV6X8HBU3oHe33Fmby6FwGkoW2sC4p9nJaBfNUjppv+Qtl/I/Zj9DxaAqZz0Jx0c8/Zy/lCBPR0riSDrjS0yLX2R3/ag7NCd4iq9gB/OdMlj7RZipakSNy4lwnsHeRVDCFJukzgLXhMlaVdzXQBJTdERP3G8A9vwxuvbOE3q3kHCTWepVYd3KdEQ5rDPrYh/HwfVB2tWSne7Z/NurutW5qLA6aiJGcDoF7H41Fit8zw1QDnwJNvsUeR/POFFD0zog7+ZpMX3OiJwFKBZfTNvzJtH3mkqnN62JJwpJNqTTMWdfSziFlQNJ6GrCqhaxECgYEA1STJz0GAC7tho/l6O13BYlnyjS15bSCrr23XXUY3Sa7s6JiNFAUkIFq57XzEEdZhqOmgQlJQmGKJmmRVSshnSH7HohRdjisnjAbK1O0qABe3tP3IIuKCrPY+q1zb+PpYkFMiWUr3+1JYKU8o5tQCWQhRLVPN8Gbl6K0ffr3sJzcCgYEAyNoS4oWNeKnAJyK7rkDq7iMkf4eDMEUl1VPunZOTsZDkycf3bIKJJK+KW/HNpCt5M+DdhgZPtbuvpPVZFsscbM/q2q4vIBxp2riS94o+Aoijc8U5FzkhE+a5+qTJpykMBOVXaHENVvZzeh9TysoRROiI3c4IibKsP2NdwxnRU40CgYACozjoGqxl+MSljdHIaEmbWPeabaSiCBR30Eko+1R10fdWjYS5abLfv5+rY67ddaSxvWphR7l9mUKQqYswqLg2enMn+06JEtmjbvYVmnW5mJGKaNWQMPNjBo0R+80xEJAGATFcn4PgFU3H/RXJfXgl9+dhQzc6MVvI/FN2cw04EwKBgQCp3uaB9vpDxy3g65tYMUeAyPAhe/cUaCcrWaVCWIJdd3JIxnsYpv5erKiUQtnts2b63X/9znCz/1z6YxdKE9aioOa8tPzeZ6mPdvO1sJHpiq7TR0aVwZecQVOiDKUQX8LukRlwF810c1QPQVeY93XLle/LyGmoLBlKMzwlujw0MQKBgDZT/egpnQM3x4TR9ERrk0o5GOLHNFiNkSfkzzZ3D2nRGT+6GRlmb40LtPzBy5+vAgLqBlfEEfToaMGZ+Vrl2CePBBoR/j/q8nlziqZ3H5b8plqHSbX85zONT6tF+YZ2nRMxpI2gQtecRzoozm+ilELCNSd6V7pAzpl14KRU2V5l'; //外部平台PKCS1私钥(银联商务提供的PKCS8格式需转为PKCS1格式) protected $private_key_pkcs1 = 'MIIEvQIBADANBgkqhkiG9w0BAQEFAASCBKcwggSjAgEAAoIBAQCnOk629YZyWZ3D79oTMDHDJOBTCcL2qNASEv6p8xYMEhsVHw3iroZDx9Epn1nK+bS+gWGCkfjhjqyHZTusX0dA67Dam7LC9TySTkkBTGnHKRsftCpb+KMfWAEbcKT8in/kjhyj6r0r8KNBGYh3mdInx9+dqIA6iA1nJys/4CAQRTy8vV422dqBXFPcQLUsSHTAHB5xP1OTKLS0wPSwx4hSX086ueHtgAMm1TMZ/5NM2uoroOGhP2YTc+XDSmrEpKTj+0c3HVkhd/gj9R5hIQCt5cdZV8tD+J/UL0dFiEQYHnuaaqfQl2axJEPsNft5Ts6Nr5Gq1Z9D8of7Z+eOr25LAgMBAAECggEAEAJS+szyfAv8QH+7vs6EVQw4tXpfwcFTegd7fcWZvLoXAaShbawLin2cloF81SOmm/5C2X8j9mP0PFoCpnPQnHRzz9nL+UIE9HSuJIOuNLTItfZHf9qDs0J3iKr2AH850yWPtFmKlqRI3LiXCewd5FUMIUm6TOAteEyVpV3NdAElN0RE/cbwD2/DG69s4TereQcJNZ6lVh3cp0RDmsM+tiH8fB9UHa1ZKd7tn826u61bmosDpqIkZwOgXsfjUWK3zPDVAOfAk2+xR5H884UUPTOiDv5mkxfc6InAUoFl9M2/Mm0feaSqc3rYknCkk2pNMxZ19LOIWVA0noasKqFrEQKBgQDVJMnPQYALu2Gj+Xo7XcFiWfKNLXltIKuvbdddRjdJruzomI0UBSQgWrntfMQR1mGo6aBCUlCYYomaZFVKyGdIfseiFF2OKyeMBsrU7SoAF7e0/cgi4oKs9j6rXNv4+liQUyJZSvf7UlgpTyjm1AJZCFEtU83wZuXorR9+vewnNwKBgQDI2hLihY14qcAnIruuQOruIyR/h4MwRSXVU+6dk5OxkOTJx/dsgokkr4pb8c2kK3kz4N2GBk+1u6+k9VkWyxxsz+rari8gHGnauJL3ij4CiKNzxTkXOSET5rn6pMmnKQwE5VdocQ1W9nN6H1PKyhFE6IjdzgiJsqw/Y13DGdFTjQKBgAKjOOgarGX4xKWN0choSZtY95ptpKIIFHfQSSj7VHXR91aNhLlpst+/n6tjrt11pLG9amFHuX2ZQpCpizCouDZ6cyf7TokS2aNu9hWadbmYkYpo1ZAw82MGjRH7zTEQkAYBMVyfg+AVTcf9Fcl9eCX352FDNzoxW8j8U3ZzDTgTAoGBAKne5oH2+kPHLeDrm1gxR4DI8CF79xRoJytZpUJYgl13ckjGexim/l6sqJRC2e2zZvrdf/3OcLP/XPpjF0oT1qKg5ry0/N5nqY9287WwkemKrtNHRpXBl5xBU6IMpRBfwu6RGXAXzXRzVA9BV5j3dcuV78vIaagsGUozPCW6PDQxAoGANlP96CmdAzfHhNH0RGuTSjkY4sc0WI2RJ+TPNncPadEZP7oZGWZvjQu0/MHLn68CAuoGV8QR9OhowZn5WuXYJ48EGhH+P+ryeXOKpncflvymWodJtfznM41Pq0X5hnadEzGkjaBC15xHOijOb6KUQsI1J3pXukDOmXXgpFTZXmU='; //银商系统公钥 protected $public_key = 'MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAhTzN8wxdXYr+/+t8iX0mlol8wFy+0pGtxnyB6PjyrIRjGHrZJA7grZPvy7MOK6PqihqTZh6SO7tX9StxVmTQo+PuibAY/p2i08UxkIBUcucHVvHN8gkM3GBFBqD0uJgUc03cerEI7gNeaKYfCVs0/hMo6CKbdXVKqaE987kXYK209uFcte+Y8YofQ2AYamImpzSf7pXomAu+8D98HIOs5bKITHTk30vPdNhrQdpDRO1TuX0x8bwhCykcwAEdB/Z9YGXkLU5S3QJY2qvCZJY08YdNqIpbDqifSRvOg0sqeKFXPfI2M0GsOh6PArTEmh0QHxDht9xjPPt11aVgh8kgkQIDAQAB'; private function host() { return $this->host; } # 查询余额 public function query($mid) { $url = $this->host() . 'uisouterfront/qrywithdrawbalance/process'; $mid = $mid ? $mid : $this->mch_id; //整理内容信息 $content = [ 'sysId' => $this->sys_id, 'mchntNo' => $mid, 'timestamp' => date('YmdHis'), ]; //设置签名并加密 $body['content'] = $this->createSignature($content); $result = Dever::curl($url, $body, 'post'); $decryptData = $this->privateDecrypt($result); if (isset($decryptData['tzWithdrawAmtPublic'])) { return $decryptData['tzWithdrawAmtPublic']; } elseif (isset($decryptData['t0WithdrawAmtPublic'])) { return $decryptData['t0WithdrawAmtPublic']; } return 0; } # 查询提现记录 public function record($mid, $start, $end, $page = '1') { $url = $this->host() . 'uisouterfront/withdraw/qryWithDrawLog'; $mid = $mid ? $mid : $this->mch_id; //整理内容信息 $content = [ 'sysId' => $this->sys_id, 'mchntNo' => $mid, 'timestamp' => date('YmdHis'), 'page' => (string) $page, 'beginDate' => $start, 'endDate' => $end, ]; //设置签名并加密 $body['content'] = $this->createSignature($content); $result = Dever::curl($url, $body, 'post'); $result = Dever::json_decode($result); $decryptData = $this->privateDecrypt($result['result']); if (isset($decryptData['recordList']) && $decryptData['recordList']) { $data = Dever::json_decode($decryptData['recordList']); if ($page == 1 && isset($decryptData['totalPage']) && $decryptData['totalPage'] > 1) { for ($i = 2; $i <= $decryptData['totalPage']; $i++) { $temp = $this->record($mid, $start, $end, $i); if ($temp) { $data = array_merge($data, $temp); } } } return $data; } return array(); } # 提现 public function act($mid, $order, $order_id, $type = 2, $cash = 1, $notify = '', $order_info = array()) { $url = $this->host() . 'uisouterfront/withdrawback/process'; $mid = $mid ? $mid : $this->mch_id; $type = (string) $type; $cash = (string) $cash; //整理内容信息 $content = [ 'sysId' => $this->sys_id, 'mchntNo' => $mid, 'timestamp' => date('YmdHis'), 'sysOrderId' => $order, 'responseUrl' => $notify, 'withdrawType' => $type, 'withdrawAmt' => $cash, ]; Dever::log($content, 'yspay_act'); $data['shop_id'] = $order_info['shop_id']; $data['mid'] = $mid; $data['order_num'] = $order; $data['type'] = $type; $data['cash'] = $cash; $data['tdate'] = time(); $data['status'] = 1; $data['desc'] = $order_info['desc']; $data['mtype'] = $order_info['mtype']; Dever::db('shop/yspay_tixian_log')->insert($data); //设置签名并加密 $body['content'] = $this->createSignature($content); $result = Dever::curl($url, $body, 'post'); $decryptData = $this->privateDecrypt($result); if (isset($decryptData['responseCode']) && ($decryptData['responseCode'] == '000000' || $decryptData['responseCode'] == '000001')) { return 'ok'; } else { if ($decryptData['responseDesc'] == '订单号已存在' && $order_id > 0) { Dever::db('shop/sell_order')->update(array('where_id' => $order_id, 'withdraw' => 2)); } return $decryptData['responseDesc']; } } /** * 私钥解密 * @Author Abnermouke * @Originate in Abnermouke's MBP * @Time 2021-08-26 16:36:58 * @param $encryptData * @return string */ public function privateDecrypt($encryptData) { $content = pack('H*', $encryptData); $result = ''; foreach (str_split($content, 256) as $block) { openssl_private_decrypt($block, $dataDecrypt, $this->formatRsaKey($this->private_key_pkcs1), OPENSSL_PKCS1_PADDING); $result .= $dataDecrypt; } $result = Dever::json_decode($result); return $result; } /** * 创建签名 * @Author Abnermouke * @Originate in Abnermouke's MBP * @Time 2021-08-26 16:34:49 * @param $body * @return false|string */ private function createSignature($body) { //重新排序信息 ksort($body); //整理加密字符串 $signature_string = ''; //循环数据 foreach ($body as $key => $value) { //整合字符串 $signature_string .= $key.'='.$value.'&'; } //整理加密字符串 $signature_string = rtrim($signature_string, '&'); //echo $signature_string; //获取加密数组 $array_json = $this->rsaEncrypt($signature_string); //设置签名 $body['sign'] = bin2hex($array_json); //print_r($body); //json序列化 $json_data = json_encode($body); //加密RSA $json_rsa = $this->publicRsa($json_data); //返回结果 return $json_rsa; } /** * 私钥加密 * @Author Abnermouke * @Originate in Abnermouke's MBP * @Time 2021-08-26 16:35:08 * @param string $str * @return false */ private function rsaEncrypt($str=''){ $charSet = mb_detect_encoding($str, ["UTF-8", "GB2312", "GBK"]); $str = mb_convert_encoding($str, "UTF-8", $charSet); $pri_key = $this->private_key; $pri_key = $this->formatRsaKey($pri_key, 'RSA PRIVATE'); $pi_key = openssl_pkey_get_private($pri_key); if(!$pi_key) return false; $algo = "SHA256"; openssl_sign($str, $binary_signature, $pi_key, $algo); return $binary_signature; } /** * 公钥加密 * @Author Abnermouke * @Originate in Abnermouke's MBP * @Time 2021-08-26 16:35:14 * @param string $str * @return false|string */ private function publicRsa($str='') { $charSet = mb_detect_encoding($str, ["UTF-8", "GB2312", "GBK"]); $str = mb_convert_encoding($str, "UTF-8", $charSet); $pub_key = $this->public_key; $pub_key = $this->formatRsaKey($pub_key, 'PUBLIC'); $pu_key = openssl_pkey_get_public($pub_key); if(!$pu_key) return false; $result = ''; foreach (str_split($str,245) as $chunk) { if(openssl_public_encrypt($chunk,$encryptData, $pub_key)){ $result .= $encryptData; } } $result = bin2hex($result); openssl_free_key($pu_key); return $result; } /** * 格式化密钥 * @Author Abnermouke * @Originate in Abnermouke's MBP * @Time 2021-08-26 16:36:36 * @param $key * @param string $alias * @param int $length * @return string */ private function formatRsaKey($key, $alias = 'RSA PRIVATE', $length = 64) { //拆分格式 $key = chunk_split($key, (int)$length, "\n"); //生成pem $pem = "-----BEGIN $alias KEY-----\n".$key."-----END $alias KEY-----"; //返回pem return $pem; } }