찾다
php教程php手册支付宝扫码支付模型 附OpenSSL工具windows编译版本

支付宝扫码支付模型 附OpenSSL工具windows编译版本 ThinkPHP3.2.3
代码只是实现了功能,不是太严谨,比如接收异步通知,没有验证通知是否来自支付宝
支付宝扫码支付<?php <br /> namespace Common\Model;<br> use Think\Model;<br> <br> /*支付宝扫码支付模型<br>  *author zheng.wang(4995952@qq.com)<br>  *date 2015-12-15<br>  */<br>  <br>  // +----------------------------------------<br>  //    | 打发士大夫的<br>  // +----------------------------------------<br>  // | 大法师<br>  // +----------------------------------------<br> class PayModel extends Model {<br>     private $ali_app_id = '20151210000000000';   //APPID<br>     private $ali_notify_url = 'http://www.19981.com/Home/Notify/aliNotify'; //支付宝结果异步通知<br>     private $wx_notify_url = 'http://www.19981.com/Home/Notify/aliNotify'; //支付宝结果异步通知<br> <br>     <br>     /*支付宝扫码支付<br>      *param $data=array('out_trade_no'=>'订单号','total_amount'=>'商品金额','subject'=>'商品名称','time_expire'=>'支付过期时间');<br>      *author zheng.wang(4995952@qq.com)<br>      *date 2015-12-15<br>      */<br>     public function aliPay($data){<br>         $url = "https://openapi.alipay.com/gateway.do"; //支付宝网关<br>         $params['app_id'] = $this->ali_app_id ; <br>         //biz_content 业务参数需要使用json格式<br>             $biz_content['out_trade_no'] = $data['out_trade_no'];  //网站订单号<br>             $biz_content['total_amount'] =  $data['total_amount']; //订单金额<br>             $biz_content['subject'] = $data['subject'];            //商品名称<br>             $biz_content['time_expire'] = date('Y-m-d H:i:s',$data['time_expire']); //订单过期时间<br>         $params['biz_content'] = json_encode($biz_content);    <br>         // $time_expire = date('Y-m-d H:i:s',$data['time_expire']); //订单过期时间<br>         // $params['biz_content']="{\"out_trade_no\":\"" . $data['out_trade_no'] . "\",";<br>         // $params['biz_content'].="\"total_amount\":\"" . $data['total_amount']. "\",";<br>         // $params['biz_content'].="\"subject\":\"" . $data['subject'] . "\",";<br>         // $params['biz_content'].="\"time_expire\":\"" . $time_expire . "\"}";        <br>         $params['charset'] = 'utf-8' ;        <br>         $params['method'] = 'alipay.trade.precreate' ;<br>         $params['notify_url'] =  $this->ali_notify_url ;<br>         $params['sign_type'] = 'RSA' ;<br>         $params['timestamp'] = date('Y-m-d H:i:s',time()) ;<br>         $params['version'] = '1.0' ;<br>         //生成签名 A-Z排序<br>         // $rsaString = 'app_id='.$params['app_id'].'&biz_content='.$params['biz_content'].'&charset='.$params['charset'].'&method='.$params['method'].'¬ify_url='.$params['notify_url'].<br>                 // '&sign_type='.$params['sign_type'].'×tamp='.$params['timestamp'].'&version='.$params['version'];<br>         <br>         $rsaString = $this->getSignContent($params);<br>         $params['sign'] = $this->rsa_sign($rsaString);<br>         //支付请求<br>         $callback = self::sendPostRequst($url, $params);<br>         $callback = json_decode(iconv("GBK", "UTF-8", "$callback"),true); //编码转为utf-8<br>         //返回结果<br>         if($callback['alipay_trade_precreate_response']['code'] == '10000'){<br>             $msg['code'] = 1;<br>             $msg['message'] = $callback['alipay_trade_precreate_response']['msg'];<br>             $msg['qr_code'] = $callback['alipay_trade_precreate_response']['qr_code'];<br>         }else{<br>             $msg['code'] = 2;<br>             $msg['message'] = $callback['alipay_trade_precreate_response']['sub_msg'];<br>         }<br>         return $msg;<br>     }<br>     <br>     /*签名排序*/    <br>     public function getSignContent($params) {<br>         ksort ( $params );<br>         <br>         $stringToBeSigned = "";<br>         $i = 0;<br>         foreach ( $params as $k => $v ) {<br>             if (false === $this->checkEmpty ( $v ) && "@" != substr ( $v, 0, 1 )) {<br>                 if ($i == 0) {<br>                     $stringToBeSigned .= "$k" . "=" . "$v";<br>                 } else {<br>                     $stringToBeSigned .= "&" . "$k" . "=" . "$v";<br>                 }<br>                 $i ++;<br>             }<br>         }<br>         unset ( $k, $v );<br>         return $stringToBeSigned;<br>     }    <br> <br>     /*校验$value是否非空*/<br>     public function checkEmpty($value) {<br>         if (! isset ( $value ))<br>             return true;<br>         if ($value === null)<br>             return true;<br>         if (trim ( $value ) === "")<br>             return true;<br>         <br>         return false;<br>     }<br> <br>     /*支付宝rsa签名方法*/<br>     public function rsa_sign($data) {<br>         $private_key = VENDOR_PATH.'Alipay/Key/rsa_private_key.pem'; //私钥路径*********************<br>         $priKey = file_get_contents ($private_key);<br>         $res = openssl_get_privatekey ( $priKey );<br>         openssl_sign ( $data, $sign, $res );<br>         openssl_free_key ( $res );<br>         $sign = base64_encode ( $sign );<br>         return $sign;<br>     }<br> <br>     /*支付宝发送请求*/<br>     public static function sendPostRequst($url, $data) {<br>         $postdata = http_build_query ( $data );<br>         //print_r($postdata);<br>         $opts = array (<br>                 'http' => array (<br>                         'method' => 'POST',<br>                         'header' => 'Content-type: application/x-www-form-urlencoded',<br>                         'content' => $postdata <br>                 ) <br>         );<br>         <br>         <br>         $context = stream_context_create ( $opts );<br>         <br>         $result = file_get_contents ( $url, false, $context );<br>         return $result;<br>     }<br>     <br>     <br>     /*支付宝退款<br>      ¶m $pay_sn(支付宝流水号),$price(退款金额),$batch_no(退款订单号)<br>      *author zheng.wang(4995952@qq.com)<br>      *date 2015-12-15    <br>      */<br>     public function aliRefund($pay_sn,$price,$batch_no){<br>         $url = "https://openapi.alipay.com/gateway.do";<br>         $params['app_id'] = $this->ali_app_id ; <br>             //biz_content 业务参数需要使用json格式<br>             // $biz_content['trade_no'] = $pay_sn;  //支付宝订单号<br>             // $biz_content['total_amount'] =  $price; //退款金额<br>             // $biz_content['out_request_no'] = $batch_no; //退款订单号<br>         $params['biz_content'] = $biz_content = "{\"trade_no\":\"". $pay_sn . "\",\"refund_amount\":\""<br>                                 . $price<br>                                 . "\",\"out_request_no\":\""<br>                                 . $batch_no<br>                                 . "\",\"refund_reason\":\"reason\",\"store_id\":\"store001\",\"terminal_id\":\"terminal001\"}";<br>         $params['charset'] = 'utf-8' ;        <br>         $params['method'] = 'alipay.trade.refund';<br>         $params['sign_type'] = 'RSA' ;<br>         $params['timestamp'] = date('Y-m-d H:i:s',time()) ;<br>         $params['version'] = '1.0' ;<br>         //生成签名<br>         $data = 'app_id='.$params['app_id'].'&biz_content='.$params['biz_content'].'&charset='.$params['charset'].'&method='.$params['method'].<br>         '&sign_type='.$params['sign_type'].'×tamp='.$params['timestamp'].'&version='.$params['version'];<br>         <br>         $params['sign'] = $this->rsa_sign($data);<br>         //支付请求<br>         $callback = self::sendPostRequst($url, $params);<br>         $callback = json_decode(iconv("GBK", "UTF-8", "$callback"),true);        <br>         //退款成功返回结果给<br>         //return $callback;<br>         var_dump($callback);<br>     }    <br>     <br> }支付宝异步通知
没有写通知验证,可以自己写哈<?php <br /> /**<br>  * Created by zheng.wang.<br>  * Date: 2015-10-26<br>  * Time: 15:29<br>  */<br> <br> namespace Home\Controller;<br> use Think\Controller;<br> <br> class NotifyController extends Controller{<br> <br>     /**<br>      * 支付宝异步通知<br>      * @param unknown $order_sn 订单号<br>      * @param unknown $type 支付类型 ALI/WEIXIN<br>      * @param unknown $result 支付结果      SUCCESS/FAIL<br>      * @param array $data <br>      *              支付成功时  $data['pay_time'] 支付完成时间<br>      *              支付成功时  $data['pay_sn'] 支付流水号<br>      *              <br>      *              支付失败时  $data['pay_time'] 支付完成时间<br>      *              支付失败时  $data['pay_sn'] 支付流水号     <br>      */    <br>     public function aliNotify(){<br>         //接收支付异步通知post数据<br>         $callBackData = $_POST;<br>         //订单记录日志<br>         file_put_contents('./Application/Runtime/Logs/xs_pay_alipay_notify.log', json_encode($callBackData), FILE_APPEND );<br>         if($_POST['trade_status'] == 'TRADE_SUCCESS'){<br>             //支付成功<br>             $data['pay_time'] = strtotime($_POST['gmt_payment']);<br>             $data['pay_sn'] = $_POST['trade_no'];<br>             $res = D('Common/XsOrder')->payCallback($_POST['out_trade_no'], 'ALI', 'SUCCESS', $data);<br>             if($res !== false){<br>                 //处理完完成后通知支付宝<br>                 echo "success";    <br>             }<br>         }<br>     }<br> <br>     <br> }

附件 thinkphp支付宝扫码支付.zip ( 1.27 MB 下载:45 次 )

AD:真正免费,域名+虚机+企业邮箱=0元

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는