public function login() { $para = array('action' => 'PPLOGIN', 'username' => 'username', 'password' => $this->encrypt('abcdefghijk'), 'iphone' => '18658170800', 'time' => NOW_TIME); include_once APP_PATH . '/BaoyiPay/BaoyiPay.php'; $key = '62def3a609f535dbc4ba6ac0471942dc'; $xml = to_xmlstring($para); $mac = hash('sha256', $xml . $key); $para = array('xml' => $xml, 'mac' => $mac); $url = 'http://test.dreammove.cn/test/callback.html'; $curl = curl_init($url); curl_setopt($curl, CURLOPT_HEADER, 0); // 过滤HTTP头 curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1); // 显示输出结果 curl_setopt($curl, CURLOPT_POST, true); // post传输数据 curl_setopt($curl, CURLOPT_POSTFIELDS, $para); // post传输数据 $responseText = curl_exec($curl); curl_close($curl); echo $responseText; }
public function querycard() { if (IS_POST) { $uid = is_login(); $head = $this->inithead('QP0007'); //6228480328608732074 $cardNo = $_POST['cardNo']; $merorderid = $_POST['merOrderId']; $card_id = $this->encrypt($head['clientDate'], $cardNo); $body = array('cardNo' => $card_id); $message = array('head' => $head, 'body' => $body); include_once APP_PATH . '/BaoyiPay/BaoyiPay.php'; $xml = to_xmlstring($message); $mac = md5($xml . $this->config['KEY']); $para = array('xml' => $xml, 'mac' => $mac); D('AccountLog')->record($head, $xml, $mac, 0); $text = getHttpResponsePost($this->config['PAY_URL'], $para); $para = md5Response($text, $this->config['KEY']); if (!$para) { $this->ajaxReturn(array('status' => 0, 'info' => '信息错误')); exit; } $data = xml2arr($para['xml']); $head = $data['head']; $body = $data['body']; D('AccountLog')->record($head, $para['xml'], $para['mac'], 1); if ($head['respCode'] == 'C000000000') { $info = M('ProductPay')->where(array('merorderid' => $merorderid))->find(); // 验证订单是否允许使用信用卡 if ($info['allow_creditcard'] == 0) { if ($body['cardType'] == '0') { $this->error('该订单不允许使用信用卡支付。'); } } $card = M('QuickcardList')->where(array('uid' => $uid, 'cardNo' => $cardNo))->find(); $bankinfo = $data['body']; if (!$card) { //所属银行编号 $bankNo = $body['bankNo']; $bankNm = $body['bankNm']; if ($info['allow_creditcard'] == 0) { $is_quick = M('BankInfo')->where(array('is_quick' => 1, 'bank_code' => $bankNo))->find(); //不存在 if (!$is_quick) { $this->error('快捷支付暂不支持' . $bankNm . '的借记卡。'); } } $storableCardNo = substr($cardNo, 0, 6) . substr($cardNo, strlen($cardNo) - 4); $id = M('QuickcardList')->add(array('uid' => $uid, 'cardNo' => $cardNo, 'bankNo' => $bankinfo['bankNo'], 'cardType' => $bankinfo['cardType'], 'bankNm' => $bankinfo['bankNm'], 'storableCardNo' => $storableCardNo)); $this->success('查询成功!', U('addstep2', array('id' => $id, 'merorderid' => $merorderid))); } else { if ($card['status'] == 1) { $this->error('您已经绑定了该银行卡。'); } else { $this->success('查询成功!', U('addstep2', array('id' => $card['id'], 'merorderid' => $merorderid))); return; } } } else { $this->error($head['respMsg']); } } }
private function savecheck($name, $cardid) { $config = C('SAVE_CHECK'); $clientDate = time_format(NOW_TIME, 'YmdHis'); $head = array('version' => '01', 'msgType' => '0001', 'chanId' => '99', 'merchantNo' => $config['MERCHANTID'], 'clientDate' => time_format(NOW_TIME, 'YmdHis'), 'tranFlow' => $config['MERCHANTID'] . $clientDate . rand(10000, 999999), 'tranCode' => 'SC0002', 'respCode' => '', 'respMsg' => ''); $body = array('idName' => $name, 'idNum' => $cardid); include_once APP_PATH . '/BaoyiPay/BaoyiPay.php'; $xml = to_xmlstring(array('head' => $head, 'body' => $body)); $mac = md5($xml . $config['MERKEY']); $this->checklog($xml . '&' . $mac, 1); $para = array('xml' => $xml, 'mac' => $mac); $text = getHttpResponsePost($config['URL'], $para); $this->checklog($text, 2); $para = md5Response($text, $config['MERKEY']); if (!$para) { //$this->ajaxReturn(array('status'=>0, 'info'=>'信息错误')); return array('status' => 0, 'info' => '信息错误'); } $data = xml2arr($para['xml']); if ($data['head']['respCode'] == 'C000000000') { return array('status' => 1, 'info' => ''); } else { return array('status' => 0, 'info' => $data['head']['respMsg']); } }