当前位置: 首页 > 后端技术 > PHP

一个PHP文件搞定支付宝系列当面支付(扫码支付)

时间:2023-03-29 19:42:55 PHP

网上很多PHP支付宝支付接入教程比较复杂,需要配置导入文件较多。整理后给出一个单文件版本,希望能给大家想接入支付宝支付带来一些帮助和参考。扫码支付是指用户在支付宝钱包中打开“扫一扫”功能,在某个收银场景中扫描商户展示的二维码,进行支付的方式。该模式适用于线下实体店支付、当面支付等场景。运行以下php文件代码,生成支付二维码图片,使用支付宝扫码支付。支付宝系列PHP文件:https://github.com/dedemao/al...微信支付系列PHP文件:https://github.com/dedemao/we...环境依赖PHP5.0或以上,并且需要开启CURL服务和SSL服务。注意事项1.文件开头的配置信息必须完整。2、商户私钥需要填写签名算法类型对应的私钥。如何生成密钥引用:2.1https://docs.open.alipay.com/...2.2https://docs.open.alipay.com/...Code密钥管理->打开平台密钥,填写APPID$notifyUrl='http://www.xxx.com/alipay/notify.php';//支付成功后的异步回调地址$outTradeNo=uniqid();//自己的产品订单号$payAmount=0.01;//支付金额,单位:元$orderName='paymenttest';//订单标题$signType='RSA2';//签名算法类型,支持RSA2和RSA,推荐使用RSA2//商户私钥,填写签名算法类型对应的私钥,如何生成密钥参考:https://docs.open.alipay。com/291/105971和https://docs.open.alipay.com/200/105310$saPrivateKey='MIIEpAIBAAKCAQEA1MV+OY6MvGfXPM0MkpjT+FdzGmPOvVmX2wF3gjwQpeHBEUP9jLXhVS32fZ1iXI1e7WUGQ5tvXn28P8190kpOn/c/G5t2CAksUvemvF7uJN/N3Z1HFMdt3omvCd14K05lgcFYz7Z4c+A7ZJF5bPCB6oshjjUmbCY3hibuWzX/1j8AgsoD9lLy1oFqxLj98k5ZrYIhk900gMQs/WJ3A1FC09Dln9fuhBUyjtPHaml+4w+sdkdzxPktxdFrMcI7M7rNEwg25XtST5Z49oFpE84AlXM7+oC9jYvIpTGE00WomsgtakN039ucT/59Bup6pLkO08Rv85UXbqzGTcYAhNHLfQIDAQABAoIBAQCbuPM58s+j8KgB8ty5yiqRPoeaj+O2h4Txn7A02/sfPQvNtCI0w3TpT5twsihULo+EVYTxJCitUn7df2sP5pyGzTEd5njLRtNu4Zvhj+Thjf8grERiu9b4oXI/WRzjLRxzi+uREi40OK+fWi0xgxDCdROY/eNiEdJfV8zpaqsUxG7VdwZIJQ/8d3Mi31OWv30kr9jfEd15DBInGJgSqR+qwrAB4pBSMcW8hL6PYlzoPi1ygceFjRrnbeMG40zt0OUPSexQIgAmFvGqxTl5xo3dFEziGHdfWYsBKZ2M8ubAe+R6LcndxI+o2Hw4TNcC1tDeNMtjw7+h9S5aef5A8uWBAoGBAPxCLWPhUHCYlIXUz0D1SoolZs9WK7Kz1YSWnzqrpegN+foS5/ji93YylGE+KL31TwbnGQLAwknwMX3qTzmkvTovmy8jevXBsCSEFm81q0wG/35e1SKkTXL66RqB2y0xFLdcF3f9s8ZiEclqkYwNSHh0nqzREfIxMMAsj+3n2vHdAoGBANftYkZYrbs4iI/ZcjmBYguYikNfNmrD+Ta6ckOGZqsHfwXJCAz1rF4/XCqVAc9nxuzJR/72qkn9z07uH6qSZCqlZDRkiiKaK2UVqFDB+0abMk/TGHXuMmdvMkyj2jEZxG2rkg0kmg4qYkkg/5tGG1On/2GeZNVPu8JpsFr1pDYhAoGBANr8pCTKC6fDfWP1C3qrtmrY7zhc6RB4d4pjq5UmP5+EypaiZQi2F/dfD1qfuIS3eURXyGmQZtoDDyPtDZvP/ImPnFs+pNbFryD0HfmrEKquhIvyzXoGQknnsgbV5iyEKCTJaII9FxzINAKzZei7+0a+jqUd1kN3Gogp50Sze2ltAoGARaM5Xpaa8RZ6dGocfI9Nn4/Ch5fdZPFvHkdjMoPV+LKiNKtw/Tz+KiclAlasDsfZT+RaY9AJe3NvuHTzoX807swIVR1Xr3EpLaCed+0XrN3AjB34dZAskU87WZw+cjdtMjFzGOoFBSyGJi+OP/WMOp6jo/YBbwoX88tCJROzsgECgYAT8pHHIyPt5Y/5pDb8EDvD3XNES1fBkfZffSoAodsrkeoKgrsKl+9M3rcGX+S9dscyoH0ur3BFTMHtIOOhC5qytt+BhMHIP5mAs4di4u/joQCWQbUyrUggVK5it+6BFgAT+jeB7zTAUtgGpTVFq3kLbV0NZ+XQyEHVlnoJnHYpQg==';$aliPay=newAlipayService($appid,$returnUrl,$notifyUrl,$saPrivateKey);$result=$aliPay->doPay($payAmount,$outTradeNo,$orderName,$returnUrl,$notifyUrl);$result=$result['alipay_trade_precreate_response'];if($result['code']&&$result['code']=='10000'){//生成二维码$url='http://pan.baidu.com/share/qrcode?w=300&h=300&url='.$result['qr_code'];echo"
";echo'二维码内容:'.$result['qr_code'];}else{echo$result['msg'].':'.$result['sub_msg'];}classAlipayService{protected$appId;受保护的$returnUrl;受保护的$notifyUrl;//私钥文件路径受保护$rsaPrivateKeyF文件路径;//私钥值受保护$rsaPrivateKey;公共函数__construct($appid,$returnUrl,$notifyUrl,$saPrivateKey){$this->appId=$appid;$this->returnUrl=$returnUrl;$this->notifyUrl=$notifyUrl;$this->charset='utf8';$this->rsaPrivateKey=$saPrivateKey;}/***发起订单*@paramfloat$totalFee收到的总费用的单位*@paramstring$outTradeNo唯一订单号*@paramstring$orderName订单名称*@paramstring$notifyUrl支付结果通知url无疑问marks*@paramstring$timestamp订单发起时间*@returnarray*/publicfunctiondoPay($totalFee,$outTradeNo,$orderName,$returnUrl,$notifyUrl){//请求参数$requestConfigs=array('out_trade_no'=>$outTradeNo,'total_amount'=>$totalFee,//单元元素'subject'=>$orderName,//订单标题);$commonConfigs=array(//公共参数'app_id'=>$this->appId,'method'=>'alipay.trade.precreate',//接口名称'format'=>'JSON','charset'=>$this->charset,'sign_type'=>'RSA2','timestamp'=>date('Y-m-dH:i:s'),'version'=>'1.0','notify_url'=>$notifyUrl,'biz_content'=>json_encode($requestConfigs),);$commonConfigs["sign"]=$this->generateSign($commonConfigs,$commonConfigs['sign_type']);$result=$this->curlPost('https://openapi.alipay.com/gateway.do',$commonConfigs);返回json_decode($result,true);}publicfunctiongenerateSign($params,$signType="RSA"){返回$this->sign($this->getSignContent($params),$signType);}受保护的函数符号($data,$signType="RSA"){$priKey=$this->rsaPrivateKey;$res="-----开始RSA私钥-----\n".wordwrap($priKey,64,"\n",true)。"\n-----CNDRSAPRIVATEKEY-----";($res)ordie('您使用的私钥格式错误,请检查RSA私钥配置');if("RSA2"==$signType){openssl_sign($data,$sign,$res,version_compare(PHP_VERSION,'5.4.0','<')?SHA256:OPENSSL_ALGO_SHA256);//OPENSSL_ALGO_SHA256仅php5.4.8以上版本支持}else{openssl_sign($data,$sign,$res);}$sign=base64_encode($sign);return$sign;}/***检查$value是否不为空*如果没有设置,返回true;*如果为null,返回true;**/protectedfunctioncheckEmpty($value){if(!isset($value))returntrue;if($value===null)returntrue;if(trim($value)==="")返回真;返回假;}publicfunctiongetSignContent($params){ksort($params);$stringToBeSigned="";$i=0;foreach($paramsas$k=>$v){if(false===$this->checkEmpty($v)&&"@"!=substr($v,0,1)){//转换为目标字符集$v=$this->characet($v,$this->charset);如果($i==0){$stringToBeSigned.="$k".“=”。“$v”;}else{$stringToBeSigned.="&"."$k"。“=”。“$v”;$i++;}}取消设置($k,$v);返回$stringToBeSigned;}/***转换字符集编码*@param$data*@param$targetCharset*@returnstring*/functioncharacet($data,$targetCharset){if(!empty($data)){$fileType=$this->字符集;如果(strcasecmp($fileType,$targetCharset)!=0){$data=mb_convert_encoding($data,$targetCharset,$fileType);//$data=iconv($fileType,$targetCharset.'//忽略',$data);}}返回$数据;}publicfunctioncurlPost($url='',$postData='',$options=array()){如果(is_array($postData)){$postData=http_build_query($postData);}$ch=curl_init();curl_setopt($ch,CURLOPT_URL,$url);curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);curl_setopt($ch,CURLOPT_POST,1);curl_setopt($ch,CURLOPT_POSTFIELDS,$postData);curl_setopt($ch,CURLOPT_TIMEOUT,30);//设置cURL允许执行的最大秒数if(!empty($options)){curl_setopt_array($ch,$options);}//https请求不验证证书和主机curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,false);curl_setopt($ch,CURLOPT_SSL_VERIFYHOST,false);$data=curl_exec($ch);curl_close($ch);返回$数据;}}