| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120 |
- <?php
- namespace Biz\Pay\Payment;
- /**
- * 智付接口
- */
- class DinPayPayment extends \Biz\Pay\BasePayment {
- function init() {
- $this->privateCertPath = '';
- $this->publicCertPath = '';
- $this->sellerInfo = array(
- 'busKey' => openssl_get_privatekey($this->privateCertPath),
- 'busAccount' => '987858', //
- );
- # code...
- }
- protected $getWay = "https://pay.dinpay.com/gateway?input_charset=UTF-8";
- protected $paymentName = "DinPay";
- function toPay() {
- $data = array(
- 'merchant_code' => $this->sellerInfo['busAccount'],
- 'service_type' => 'direct_pay',
- 'interface_version' => 'V3.0',
- 'input_charset' => 'UTF-8',
- 'notify_url' => $this->notifyUrl,
- 'order_no' => $this->dataAccess->orderSn,
- 'order_time' => date('Y-m-d H:i:s', time()), //
- 'order_amount' => $this->dataAccess->money, //
- 'product_name' => '在线充值支付', //
- 'bank_code' => '', //
- 'Return_url' => $this->redirectUrl, //
- 'pay_type' => 'b2c', //
- );
- $sign = $this->sslMcrypt($data, $this->sellerInfo['busKey']);
- $data['sign'] = $sign;
- $data['sign_type'] = 'RSA-S';
- $data = $this->goPay($data);
- }
- function sslMcrypt($data, $key) {
- $data = $this->fileterData($data);
- $str = http_build_query($data);
- $str = urldecode($str);
- openssl_sign($str, $sign_info, $key, OPENSSL_ALGO_MD5);
- $sign = base64_encode($sign_info);
- return $sign;
- }
- function sslcrypt($data, $sign, $key) {
- $data = $this->fileterData($data);
- $str = http_build_query($data);
- $str = urldecode($str);
- return openssl_verify($str, $sign, $key, OPENSSL_ALGO_MD5);
- }
- function fileterData($data) {
- if (is_array($data) && count($data) > 0) {
- ksort($data);
- foreach ($data as $k => $v) {
- if (empty($v)) {
- unset($data[$k]);
- }
- }
- }
- return $data;
- }
- public function notify($order) {
- # code...
- $re = $this->check($order);
- return $re;
- }
- public function redirect($order) {
- $re = $this->check($order);
- return $re;
- }
- public function check($order) {
- $data = array();
- $this->dataAccess->orderSn = $data['order_no'] = $_POST['order_no'];
- $data['order_time'] = $_POST['order_time'];
- $this->dataAccess->money = $data['order_amount'] = $_POST['order_amount'];
- $data['trade_no'] = $_POST['trade_no'];
- $data['trade_time'] = $_POST['trade_time'];
- $data['trade_status'] = $_POST['trade_status'];
- $data['notify_id'] = $_POST['notify_id'];
- $data['notify_type'] = $_POST['notify_type'];
- $data['interface_version'] = $_POST['interface_version'];
- $data['merchant_code'] = $_POST['merchant_code'];
- $sign = base64_decode($_POST["sign"]);
- $data['bank_seq_no'] = $_POST["bank_seq_no"];
- $data['extra_return_param'] = $_POST["extra_return_param"];
- // $data['sign_type'] = $_POST['sign_type'];
- if ($this->sslcrypt($data, $sign, openssl_get_publickey($this->publicCertPath), OPENSSL_ALGO_MD5)) {
- return 1;
- } else {
- return 0;
- }
- }
- function notifyMsg($key) {
- if ($key > 0) {
- echo 'SUCCESS';
- } else {
- echo '';
- }
- }
- public function getPaymentType() {
- # code...
- return array(
- );
- }
- }
|