@@ -36,8 +36,8 @@ discard block |
||
| 36 | 36 | * @param $ext array |
| 37 | 37 | * @return string |
| 38 | 38 | */ |
| 39 | - public function getPrepayId($body,$out_trade_no,$total_fee,$spbill_create_ip,$ext = null) { |
|
| 40 | - $data = ($ext && is_array($ext))?$ext:array(); |
|
| 39 | + public function getPrepayId($body, $out_trade_no, $total_fee, $spbill_create_ip, $ext = null) { |
|
| 40 | + $data = ($ext && is_array($ext)) ? $ext : array(); |
|
| 41 | 41 | $data["body"] = $body; |
| 42 | 42 | $data["out_trade_no"] = $out_trade_no; |
| 43 | 43 | $data["total_fee"] = $total_fee; |
@@ -62,7 +62,7 @@ discard block |
||
| 62 | 62 | $data["timestamp"] = time(); |
| 63 | 63 | $data["noncestr"] = $this->getNonceStr(); |
| 64 | 64 | $data["appid"] = $this->config["app_id"]; |
| 65 | - $data["sign"] = $this->sign($data); |
|
| 65 | + $data["sign"] = $this->sign($data); |
|
| 66 | 66 | return $data; |
| 67 | 67 | } |
| 68 | 68 | } |
| 69 | 69 | \ No newline at end of file |
@@ -8,7 +8,7 @@ discard block |
||
| 8 | 8 | namespace zhangv\wechat\pay\util; |
| 9 | 9 | |
| 10 | 10 | class WechatOAuth { |
| 11 | - const TICKETTYPE_JSAPI = 'jsapi',TICKETTYPE_WXCARD = 'wx_card'; |
|
| 11 | + const TICKETTYPE_JSAPI = 'jsapi', TICKETTYPE_WXCARD = 'wx_card'; |
|
| 12 | 12 | public $responseJSON = null; |
| 13 | 13 | public $errCode = null; |
| 14 | 14 | public $errMsg = null; |
@@ -18,46 +18,46 @@ discard block |
||
| 18 | 18 | private $httpClient = null; |
| 19 | 19 | private $accessToken = null; |
| 20 | 20 | |
| 21 | - public function __construct($appId,$appSecret) { |
|
| 21 | + public function __construct($appId, $appSecret) { |
|
| 22 | 22 | $this->appId = $appId; |
| 23 | 23 | $this->appSecret = $appSecret; |
| 24 | 24 | $this->httpClient = new HttpClient(); |
| 25 | 25 | } |
| 26 | 26 | |
| 27 | - public function setHttpClient($httpClient){ |
|
| 27 | + public function setHttpClient($httpClient) { |
|
| 28 | 28 | $this->httpClient = $httpClient; |
| 29 | 29 | } |
| 30 | 30 | |
| 31 | - public function authorizeURI($redirectURI,$scope = 'snsapi_userinfo',$state = ''){ |
|
| 31 | + public function authorizeURI($redirectURI, $scope = 'snsapi_userinfo', $state = '') { |
|
| 32 | 32 | $redirectURI = urlencode($redirectURI); |
| 33 | 33 | return "https://open.weixin.qq.com/connect/oauth2/authorize?appid={$this->appId}&redirect_uri={$redirectURI}&response_type=code&scope=$scope&state=$state#wechat_redirect"; |
| 34 | 34 | } |
| 35 | 35 | |
| 36 | - public function authorize($code){ |
|
| 36 | + public function authorize($code) { |
|
| 37 | 37 | $url = "https://api.weixin.qq.com/sns/oauth2/access_token?appid={$this->appId}&secret={$this->appSecret}&code=$code&grant_type=authorization_code"; |
| 38 | 38 | $this->responseJSON = $this->httpClient->get($url); |
| 39 | 39 | return json_decode($this->responseJSON); |
| 40 | 40 | } |
| 41 | 41 | |
| 42 | - public function getUserInfo($openId){ |
|
| 42 | + public function getUserInfo($openId) { |
|
| 43 | 43 | $url = "https://api.weixin.qq.com/sns/userinfo?access_token={$this->accessToken}&openid=$openId&lang=zh_CN"; |
| 44 | 44 | $this->responseJSON = $this->httpClient->get($url); |
| 45 | 45 | return json_decode($this->responseJSON); |
| 46 | 46 | } |
| 47 | 47 | |
| 48 | - public function refreshToken($refreshToken){ |
|
| 48 | + public function refreshToken($refreshToken) { |
|
| 49 | 49 | $url = "https://api.weixin.qq.com/sns/oauth2/refresh_token?appid={$this->appId}&grant_type=refresh_token&refresh_token=$refreshToken"; |
| 50 | 50 | $this->responseJSON = $this->httpClient->get($url); |
| 51 | 51 | return json_decode($this->responseJSON); |
| 52 | 52 | } |
| 53 | 53 | |
| 54 | - public function verifyToken($accessToken,$openId){ |
|
| 54 | + public function verifyToken($accessToken, $openId) { |
|
| 55 | 55 | $url = "https://api.weixin.qq.com/sns/auth?access_token=$accessToken&openid=$openId"; |
| 56 | 56 | $this->responseJSON = $this->httpClient->get($url); |
| 57 | 57 | return json_decode($this->responseJSON); |
| 58 | 58 | } |
| 59 | 59 | |
| 60 | - public function getAccessToken(){ |
|
| 60 | + public function getAccessToken() { |
|
| 61 | 61 | $url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid={$this->appId}&secret={$this->appSecret}"; |
| 62 | 62 | $this->responseJSON = $this->httpClient->get($url); |
| 63 | 63 | $json = json_decode($this->responseJSON); |
@@ -65,27 +65,27 @@ discard block |
||
| 65 | 65 | return $this->accessToken; |
| 66 | 66 | } |
| 67 | 67 | |
| 68 | - public function getTicket($type = WechatOAuth::TICKETTYPE_JSAPI, $accessToken = null){ |
|
| 69 | - if(!$accessToken) $accessToken = $this->getAccessToken(); |
|
| 68 | + public function getTicket($type = WechatOAuth::TICKETTYPE_JSAPI, $accessToken = null) { |
|
| 69 | + if (!$accessToken) $accessToken = $this->getAccessToken(); |
|
| 70 | 70 | // $url = "https://qyapi.weixin.qq.com/cgi-bin/get_jsapi_ticket?access_token=$accessToken"; |
| 71 | 71 | $url = "https://api.weixin.qq.com/cgi-bin/ticket/getticket?type={$type}&access_token=$accessToken"; |
| 72 | 72 | $this->responseJSON = $this->httpClient->get($url); |
| 73 | 73 | return json_decode($this->responseJSON); |
| 74 | 74 | } |
| 75 | 75 | |
| 76 | - public function getSession($code){ |
|
| 76 | + public function getSession($code) { |
|
| 77 | 77 | $url = "https://api.weixin.qq.com/sns/jscode2session?appid={$this->appId}&secret={$this->appSecret}&js_code=$code&grant_type=authorization_code"; |
| 78 | 78 | $this->responseJSON = $this->httpClient->get($url); |
| 79 | 79 | return json_decode($this->responseJSON); |
| 80 | 80 | } |
| 81 | 81 | |
| 82 | - public function getSignPackage($url = null, $ticket = null){ |
|
| 83 | - if(!$url){ |
|
| 82 | + public function getSignPackage($url = null, $ticket = null) { |
|
| 83 | + if (!$url) { |
|
| 84 | 84 | $url = (!empty($_SERVER['HTTPS']) && $_SERVER['HTTPS'] !== 'off' || |
| 85 | 85 | (!empty($_SERVER['SERVER_PORT']) && $_SERVER['SERVER_PORT'] == 443)) ? "https://" : "http://"; |
| 86 | 86 | $url .= "{$_SERVER['HTTP_HOST']}{$_SERVER['REQUEST_URI']}"; |
| 87 | 87 | } |
| 88 | - if(!$ticket) $ticket = $this->getTicket(); |
|
| 88 | + if (!$ticket) $ticket = $this->getTicket(); |
|
| 89 | 89 | $timestamp = time(); |
| 90 | 90 | $nonceStr = $this->getNonceStr(); |
| 91 | 91 | $rawString = "jsapi_ticket=$ticket&noncestr=$nonceStr×tamp=$timestamp&url=$url"; |
@@ -103,6 +103,6 @@ discard block |
||
| 103 | 103 | } |
| 104 | 104 | |
| 105 | 105 | private function getNonceStr() { |
| 106 | - return substr(str_shuffle("abcdefghijklmnopqrstuvwxyz0123456789"),0,32); |
|
| 106 | + return substr(str_shuffle("abcdefghijklmnopqrstuvwxyz0123456789"), 0, 32); |
|
| 107 | 107 | } |
| 108 | 108 | } |
@@ -66,7 +66,9 @@ discard block |
||
| 66 | 66 | } |
| 67 | 67 | |
| 68 | 68 | public function getTicket($type = WechatOAuth::TICKETTYPE_JSAPI, $accessToken = null){ |
| 69 | - if(!$accessToken) $accessToken = $this->getAccessToken(); |
|
| 69 | + if(!$accessToken) { |
|
| 70 | + $accessToken = $this->getAccessToken(); |
|
| 71 | + } |
|
| 70 | 72 | // $url = "https://qyapi.weixin.qq.com/cgi-bin/get_jsapi_ticket?access_token=$accessToken"; |
| 71 | 73 | $url = "https://api.weixin.qq.com/cgi-bin/ticket/getticket?type={$type}&access_token=$accessToken"; |
| 72 | 74 | $this->responseJSON = $this->httpClient->get($url); |
@@ -85,7 +87,9 @@ discard block |
||
| 85 | 87 | (!empty($_SERVER['SERVER_PORT']) && $_SERVER['SERVER_PORT'] == 443)) ? "https://" : "http://"; |
| 86 | 88 | $url .= "{$_SERVER['HTTP_HOST']}{$_SERVER['REQUEST_URI']}"; |
| 87 | 89 | } |
| 88 | - if(!$ticket) $ticket = $this->getTicket(); |
|
| 90 | + if(!$ticket) { |
|
| 91 | + $ticket = $this->getTicket(); |
|
| 92 | + } |
|
| 89 | 93 | $timestamp = time(); |
| 90 | 94 | $nonceStr = $this->getNonceStr(); |
| 91 | 95 | $rawString = "jsapi_ticket=$ticket&noncestr=$nonceStr×tamp=$timestamp&url=$url"; |
@@ -7,9 +7,9 @@ discard block |
||
| 7 | 7 | */ |
| 8 | 8 | namespace zhangv\wechat\pay\util; |
| 9 | 9 | |
| 10 | -class HttpClient{ |
|
| 10 | +class HttpClient { |
|
| 11 | 11 | |
| 12 | - const GET = 'get',POST = 'post', DELETE = 'delete',PUT = 'put'; |
|
| 12 | + const GET = 'get', POST = 'post', DELETE = 'delete', PUT = 'put'; |
|
| 13 | 13 | private $instance = null; |
| 14 | 14 | private $errNo = null; |
| 15 | 15 | private $info = null; |
@@ -19,8 +19,8 @@ discard block |
||
| 19 | 19 | $this->initInstance($timeout); |
| 20 | 20 | } |
| 21 | 21 | |
| 22 | - public function initInstance($timeout){ |
|
| 23 | - if(!$this->instance) { |
|
| 22 | + public function initInstance($timeout) { |
|
| 23 | + if (!$this->instance) { |
|
| 24 | 24 | $this->instance = curl_init(); |
| 25 | 25 | curl_setopt($this->instance, CURLOPT_TIMEOUT, intval($timeout)); |
| 26 | 26 | curl_setopt($this->instance, CURLOPT_RETURNTRANSFER, true); |
@@ -29,26 +29,26 @@ discard block |
||
| 29 | 29 | } |
| 30 | 30 | } |
| 31 | 31 | |
| 32 | - public function get($url,$params = array(),$headers = array(),$opts = array()) { |
|
| 32 | + public function get($url, $params = array(), $headers = array(), $opts = array()) { |
|
| 33 | 33 | if (!$this->instance) $this->initInstance($this->timeout); |
| 34 | - if($params && count($params) > 0) $url .= '?' . http_build_query($params); |
|
| 34 | + if ($params && count($params) > 0) $url .= '?'.http_build_query($params); |
|
| 35 | 35 | curl_setopt($this->instance, CURLOPT_URL, $url); |
| 36 | 36 | curl_setopt($this->instance, CURLOPT_HTTPGET, true); |
| 37 | 37 | curl_setopt($this->instance, CURLOPT_HTTPHEADER, $headers); |
| 38 | - curl_setopt_array($this->instance,$opts); |
|
| 38 | + curl_setopt_array($this->instance, $opts); |
|
| 39 | 39 | $result = $this->execute(); |
| 40 | 40 | curl_close($this->instance); |
| 41 | 41 | $this->instance = null; |
| 42 | 42 | return $result; |
| 43 | 43 | } |
| 44 | 44 | |
| 45 | - public function post($url, $params = array(),$headers = array(),$opts = array()) { |
|
| 45 | + public function post($url, $params = array(), $headers = array(), $opts = array()) { |
|
| 46 | 46 | if (!$this->instance) $this->initInstance($this->timeout); |
| 47 | 47 | curl_setopt($this->instance, CURLOPT_URL, $url); |
| 48 | 48 | curl_setopt($this->instance, CURLOPT_POST, true); |
| 49 | 49 | curl_setopt($this->instance, CURLOPT_POSTFIELDS, $params); |
| 50 | 50 | curl_setopt($this->instance, CURLOPT_HTTPHEADER, $headers); |
| 51 | - curl_setopt_array($this->instance,$opts); |
|
| 51 | + curl_setopt_array($this->instance, $opts); |
|
| 52 | 52 | $result = $this->execute(); |
| 53 | 53 | curl_close($this->instance); |
| 54 | 54 | $this->instance = null; |
@@ -62,7 +62,7 @@ discard block |
||
| 62 | 62 | return $result; |
| 63 | 63 | } |
| 64 | 64 | |
| 65 | - public function getInfo(){ |
|
| 65 | + public function getInfo() { |
|
| 66 | 66 | return $this->info; |
| 67 | 67 | } |
| 68 | 68 | } |
| 69 | 69 | \ No newline at end of file |
@@ -28,8 +28,12 @@ discard block |
||
| 28 | 28 | } |
| 29 | 29 | |
| 30 | 30 | public function get($url,$params = array(),$headers = array(),$opts = array()) { |
| 31 | - if (!$this->instance) $this->initInstance($this->timeout); |
|
| 32 | - if($params && count($params) > 0) $url .= '?' . http_build_query($params); |
|
| 31 | + if (!$this->instance) { |
|
| 32 | + $this->initInstance($this->timeout); |
|
| 33 | + } |
|
| 34 | + if($params && count($params) > 0) { |
|
| 35 | + $url .= '?' . http_build_query($params); |
|
| 36 | + } |
|
| 33 | 37 | curl_setopt($this->instance, CURLOPT_URL, $url); |
| 34 | 38 | curl_setopt($this->instance, CURLOPT_HTTPGET, true); |
| 35 | 39 | curl_setopt($this->instance, CURLOPT_HTTPHEADER, $headers); |
@@ -41,7 +45,9 @@ discard block |
||
| 41 | 45 | } |
| 42 | 46 | |
| 43 | 47 | public function post($url, $params = array(),$headers = array(),$opts = array()) { |
| 44 | - if (!$this->instance) $this->initInstance($this->timeout); |
|
| 48 | + if (!$this->instance) { |
|
| 49 | + $this->initInstance($this->timeout); |
|
| 50 | + } |
|
| 45 | 51 | curl_setopt($this->instance, CURLOPT_URL, $url); |
| 46 | 52 | curl_setopt($this->instance, CURLOPT_POST, true); |
| 47 | 53 | curl_setopt($this->instance, CURLOPT_POSTFIELDS, $params); |
@@ -38,16 +38,16 @@ |
||
| 38 | 38 | * @return string |
| 39 | 39 | * @throws \Exception |
| 40 | 40 | */ |
| 41 | - public function getPrepayId($body,$out_trade_no,$total_fee,$openid,$spbill_create_ip = null,$ext = null) { |
|
| 42 | - $data = ($ext && is_array($ext))?$ext:array(); |
|
| 41 | + public function getPrepayId($body, $out_trade_no, $total_fee, $openid, $spbill_create_ip = null, $ext = null) { |
|
| 42 | + $data = ($ext && is_array($ext)) ? $ext : array(); |
|
| 43 | 43 | $data["body"] = $body; |
| 44 | 44 | $data["out_trade_no"] = $out_trade_no; |
| 45 | 45 | $data["total_fee"] = $total_fee; |
| 46 | - $data["spbill_create_ip"] = $spbill_create_ip?:$_SERVER["REMOTE_ADDR"]; |
|
| 46 | + $data["spbill_create_ip"] = $spbill_create_ip ?: $_SERVER["REMOTE_ADDR"]; |
|
| 47 | 47 | $data["notify_url"] = $this->config["notify_url"]; |
| 48 | 48 | $data["trade_type"] = WechatPay::TRADETYPE_JSAPI; |
| 49 | - if(!$openid) throw new Exception('openid is required when trade_type is JSAPI'); |
|
| 50 | - $data["openid"] = $openid; |
|
| 49 | + if (!$openid) throw new Exception('openid is required when trade_type is JSAPI'); |
|
| 50 | + $data["openid"] = $openid; |
|
| 51 | 51 | $result = $this->unifiedOrder($data); |
| 52 | 52 | return $result["prepay_id"]; |
| 53 | 53 | } |
@@ -46,7 +46,9 @@ |
||
| 46 | 46 | $data["spbill_create_ip"] = $spbill_create_ip?:$_SERVER["REMOTE_ADDR"]; |
| 47 | 47 | $data["notify_url"] = $this->config["notify_url"]; |
| 48 | 48 | $data["trade_type"] = WechatPay::TRADETYPE_JSAPI; |
| 49 | - if(!$openid) throw new Exception('openid is required when trade_type is JSAPI'); |
|
| 49 | + if(!$openid) { |
|
| 50 | + throw new Exception('openid is required when trade_type is JSAPI'); |
|
| 51 | + } |
|
| 50 | 52 | $data["openid"] = $openid; |
| 51 | 53 | $result = $this->unifiedOrder($data); |
| 52 | 54 | return $result["prepay_id"]; |
@@ -24,8 +24,8 @@ discard block |
||
| 24 | 24 | * @return array |
| 25 | 25 | * @throws Exception |
| 26 | 26 | */ |
| 27 | - public function transferWallet($partner_trade_no,$openid,$amount,$desc,$spbill_create_ip = null,$re_user_name = null,$check_name = WechatPay::CHECKNAME_FORCECHECK){ |
|
| 28 | - if($check_name == WechatPay::CHECKNAME_FORCECHECK && !$re_user_name) throw new Exception('Real name is required'); |
|
| 27 | + public function transferWallet($partner_trade_no, $openid, $amount, $desc, $spbill_create_ip = null, $re_user_name = null, $check_name = WechatPay::CHECKNAME_FORCECHECK) { |
|
| 28 | + if ($check_name == WechatPay::CHECKNAME_FORCECHECK && !$re_user_name) throw new Exception('Real name is required'); |
|
| 29 | 29 | $data = [ |
| 30 | 30 | "mch_appid" => $this->config["app_id"], |
| 31 | 31 | "mchid" => $this->config["mch_id"], |
@@ -33,11 +33,11 @@ discard block |
||
| 33 | 33 | "openid" => $openid, |
| 34 | 34 | "amount" => $amount, |
| 35 | 35 | "desc" => $desc, |
| 36 | - 'spbill_create_ip' => $spbill_create_ip?:$_SERVER['SERVER_ADDR'], |
|
| 36 | + 'spbill_create_ip' => $spbill_create_ip ?: $_SERVER['SERVER_ADDR'], |
|
| 37 | 37 | "check_name" => $check_name, |
| 38 | 38 | "re_user_name" => $re_user_name |
| 39 | 39 | ]; |
| 40 | - return $this->post(self::URL_TRANSFER_WALLET,$data,true); |
|
| 40 | + return $this->post(self::URL_TRANSFER_WALLET, $data, true); |
|
| 41 | 41 | } |
| 42 | 42 | |
| 43 | 43 | /** |
@@ -45,13 +45,13 @@ discard block |
||
| 45 | 45 | * @param $partner_trade_no |
| 46 | 46 | * @return array |
| 47 | 47 | */ |
| 48 | - public function queryTransferWallet($partner_trade_no){ |
|
| 48 | + public function queryTransferWallet($partner_trade_no) { |
|
| 49 | 49 | $data = [ |
| 50 | 50 | "appid" => $this->config["app_id"], |
| 51 | 51 | "mch_id" => $this->config["mch_id"], |
| 52 | 52 | "partner_trade_no" => $partner_trade_no |
| 53 | 53 | ]; |
| 54 | - return $this->post(self::URL_QUERY_TRANSFER_WALLET,$data,true); |
|
| 54 | + return $this->post(self::URL_QUERY_TRANSFER_WALLET, $data, true); |
|
| 55 | 55 | } |
| 56 | 56 | |
| 57 | 57 | /** |
@@ -65,8 +65,8 @@ discard block |
||
| 65 | 65 | * @return array |
| 66 | 66 | * @throws Exception |
| 67 | 67 | */ |
| 68 | - public function transferBankCard($partner_trade_no,$bank_no,$true_name,$bank_code,$amount,$desc){ |
|
| 69 | - if(!in_array($bank_code,array_values(self::$BANKCODE))) throw new Exception("Unsupported bank code: $bank_code"); |
|
| 68 | + public function transferBankCard($partner_trade_no, $bank_no, $true_name, $bank_code, $amount, $desc) { |
|
| 69 | + if (!in_array($bank_code, array_values(self::$BANKCODE))) throw new Exception("Unsupported bank code: $bank_code"); |
|
| 70 | 70 | $data = [ |
| 71 | 71 | "partner_trade_no" => $partner_trade_no, |
| 72 | 72 | "enc_bank_no" => $this->rsaEncrypt($bank_no), |
@@ -75,14 +75,14 @@ discard block |
||
| 75 | 75 | "desc" => $desc, |
| 76 | 76 | "amount" => $amount |
| 77 | 77 | ]; |
| 78 | - return $this->post(self::URL_TRANSFER_BANKCARD,$data,true); |
|
| 78 | + return $this->post(self::URL_TRANSFER_BANKCARD, $data, true); |
|
| 79 | 79 | } |
| 80 | 80 | |
| 81 | - public function rsaEncrypt($data,$pubkey = null){ |
|
| 82 | - if(!$pubkey) $pubkey = $this->getPublicKey(); |
|
| 81 | + public function rsaEncrypt($data, $pubkey = null) { |
|
| 82 | + if (!$pubkey) $pubkey = $this->getPublicKey(); |
|
| 83 | 83 | $encrypted = null; |
| 84 | 84 | $pubkey = openssl_get_publickey($pubkey); |
| 85 | - if (@openssl_public_encrypt($data, $encrypted, $pubkey,OPENSSL_PKCS1_OAEP_PADDING)) |
|
| 85 | + if (@openssl_public_encrypt($data, $encrypted, $pubkey, OPENSSL_PKCS1_OAEP_PADDING)) |
|
| 86 | 86 | $data = base64_encode($encrypted); |
| 87 | 87 | else |
| 88 | 88 | throw new Exception('Unable to encrypt data'); |
@@ -94,13 +94,13 @@ discard block |
||
| 94 | 94 | * @param $partner_trade_no |
| 95 | 95 | * @return array |
| 96 | 96 | */ |
| 97 | - public function queryTransferBankCard($partner_trade_no){ |
|
| 97 | + public function queryTransferBankCard($partner_trade_no) { |
|
| 98 | 98 | $data = [ |
| 99 | 99 | "appid" => $this->config["app_id"], |
| 100 | 100 | "mch_id" => $this->config["mch_id"], |
| 101 | 101 | "partner_trade_no" => $partner_trade_no |
| 102 | 102 | ]; |
| 103 | - return $this->post(self::URL_QUERY_TRANSFER_WALLET,$data,true); |
|
| 103 | + return $this->post(self::URL_QUERY_TRANSFER_WALLET, $data, true); |
|
| 104 | 104 | } |
| 105 | 105 | |
| 106 | 106 | /** |
@@ -110,18 +110,18 @@ discard block |
||
| 110 | 110 | * @return string |
| 111 | 111 | * @throws Exception |
| 112 | 112 | */ |
| 113 | - public function getPublicKey($refresh = false){ |
|
| 114 | - if(!$this->publicKey) { |
|
| 113 | + public function getPublicKey($refresh = false) { |
|
| 114 | + if (!$this->publicKey) { |
|
| 115 | 115 | if (!$refresh && file_exists($this->config["rsa_pubkey_path"])) { |
| 116 | 116 | $this->publicKey = file_get_contents($this->config["rsa_pubkey_path"]); |
| 117 | - }else{ |
|
| 117 | + }else { |
|
| 118 | 118 | $data = array(); |
| 119 | 119 | $data["mch_id"] = $this->config["mch_id"]; |
| 120 | 120 | $data["sign_type"] = $this->config["sign_type"]; |
| 121 | 121 | $result = $this->post(self::URL_GETPUBLICKEY, $data, true); |
| 122 | 122 | $pubkey = $result['pub_key']; |
| 123 | 123 | $this->publicKey = $this->convertPKCS1toPKCS8($pubkey); |
| 124 | - if($fp = @fopen($this->config["rsa_pubkey_path"], "w")) { |
|
| 124 | + if ($fp = @fopen($this->config["rsa_pubkey_path"], "w")) { |
|
| 125 | 125 | fwrite($fp, $this->publicKey); |
| 126 | 126 | fclose($fp); |
| 127 | 127 | } |
@@ -130,16 +130,16 @@ discard block |
||
| 130 | 130 | return $this->publicKey; |
| 131 | 131 | } |
| 132 | 132 | |
| 133 | - public function setPublicKey($publicKey){ |
|
| 133 | + public function setPublicKey($publicKey) { |
|
| 134 | 134 | $this->publicKey = $publicKey; |
| 135 | 135 | } |
| 136 | 136 | |
| 137 | - private function convertPKCS1toPKCS8($pkcs1){ |
|
| 137 | + private function convertPKCS1toPKCS8($pkcs1) { |
|
| 138 | 138 | $start_key = $pkcs1; |
| 139 | 139 | $start_key = str_replace('-----BEGIN RSA PUBLIC KEY-----', '', $start_key); |
| 140 | 140 | $start_key = trim(str_replace('-----END RSA PUBLIC KEY-----', '', $start_key)); |
| 141 | - $key = 'MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8A' . str_replace("\n", '', $start_key); |
|
| 142 | - $key = "-----BEGIN PUBLIC KEY-----\n" . wordwrap($key, 64, "\n", true) . "\n-----END PUBLIC KEY-----"; |
|
| 141 | + $key = 'MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8A'.str_replace("\n", '', $start_key); |
|
| 142 | + $key = "-----BEGIN PUBLIC KEY-----\n".wordwrap($key, 64, "\n", true)."\n-----END PUBLIC KEY-----"; |
|
| 143 | 143 | return $key; |
| 144 | 144 | } |
| 145 | 145 | |
@@ -25,7 +25,9 @@ discard block |
||
| 25 | 25 | * @throws Exception |
| 26 | 26 | */ |
| 27 | 27 | public function transferWallet($partner_trade_no,$openid,$amount,$desc,$spbill_create_ip = null,$re_user_name = null,$check_name = WechatPay::CHECKNAME_FORCECHECK){ |
| 28 | - if($check_name == WechatPay::CHECKNAME_FORCECHECK && !$re_user_name) throw new Exception('Real name is required'); |
|
| 28 | + if($check_name == WechatPay::CHECKNAME_FORCECHECK && !$re_user_name) { |
|
| 29 | + throw new Exception('Real name is required'); |
|
| 30 | + } |
|
| 29 | 31 | $data = [ |
| 30 | 32 | "mch_appid" => $this->config["app_id"], |
| 31 | 33 | "mchid" => $this->config["mch_id"], |
@@ -66,7 +68,9 @@ discard block |
||
| 66 | 68 | * @throws Exception |
| 67 | 69 | */ |
| 68 | 70 | public function transferBankCard($partner_trade_no,$bank_no,$true_name,$bank_code,$amount,$desc){ |
| 69 | - if(!in_array($bank_code,array_values(self::$BANKCODE))) throw new Exception("Unsupported bank code: $bank_code"); |
|
| 71 | + if(!in_array($bank_code,array_values(self::$BANKCODE))) { |
|
| 72 | + throw new Exception("Unsupported bank code: $bank_code"); |
|
| 73 | + } |
|
| 70 | 74 | $data = [ |
| 71 | 75 | "partner_trade_no" => $partner_trade_no, |
| 72 | 76 | "enc_bank_no" => $this->rsaEncrypt($bank_no), |
@@ -79,13 +83,16 @@ discard block |
||
| 79 | 83 | } |
| 80 | 84 | |
| 81 | 85 | public function rsaEncrypt($data,$pubkey = null){ |
| 82 | - if(!$pubkey) $pubkey = $this->getPublicKey(); |
|
| 86 | + if(!$pubkey) { |
|
| 87 | + $pubkey = $this->getPublicKey(); |
|
| 88 | + } |
|
| 83 | 89 | $encrypted = null; |
| 84 | 90 | $pubkey = openssl_get_publickey($pubkey); |
| 85 | - if (@openssl_public_encrypt($data, $encrypted, $pubkey,OPENSSL_PKCS1_OAEP_PADDING)) |
|
| 86 | - $data = base64_encode($encrypted); |
|
| 87 | - else |
|
| 88 | - throw new Exception('Unable to encrypt data'); |
|
| 91 | + if (@openssl_public_encrypt($data, $encrypted, $pubkey,OPENSSL_PKCS1_OAEP_PADDING)) { |
|
| 92 | + $data = base64_encode($encrypted); |
|
| 93 | + } else { |
|
| 94 | + throw new Exception('Unable to encrypt data'); |
|
| 95 | + } |
|
| 89 | 96 | return $data; |
| 90 | 97 | } |
| 91 | 98 | |
@@ -114,7 +121,7 @@ discard block |
||
| 114 | 121 | if(!$this->publicKey) { |
| 115 | 122 | if (!$refresh && file_exists($this->config["rsa_pubkey_path"])) { |
| 116 | 123 | $this->publicKey = file_get_contents($this->config["rsa_pubkey_path"]); |
| 117 | - }else{ |
|
| 124 | + } else{ |
|
| 118 | 125 | $data = array(); |
| 119 | 126 | $data["mch_id"] = $this->config["mch_id"]; |
| 120 | 127 | $data["sign_type"] = $this->config["sign_type"]; |