资讯专栏INFORMATION COLUMN

一个PHP文件搞定微信支付系列之原生支付(扫码支付)

JerryC / 2553人阅读

摘要:直接运行该文件即可得到一个支付二维码的图片。需要注意的事项该文件需放到支付授权目录下,可以在微信支付商户平台产品中心开发配置中设置。

网上的很多PHP微信扫码支付接入教程都颇为复杂,且需要配置和引入较多的文件,本人通过整理后给出一个单文件版的,只有200行代码,希望可以给各位想接入微信扫码支付的带来些许帮助和借鉴意义。

直接运行该文件即可得到一个支付二维码的图片。

需要注意的事项:
1.该文件需放到支付授权目录下,可以在微信支付商户平台->产品中心->开发配置中设置。
2.如提示签名错误可以通过微信支付签名验证工具进行验证:https://pay.weixin.qq.com/wik...

代码如下:

createJsBizPackage($payAmount,$outTradeNo,$orderName,$notifyUrl,$payTime);
//生成二维码
$url = "http://qr.liantu.com/api.php?text=".$arr["code_url"];
echo "";

class WxpayService
{
    protected $mchid;
    protected $appid;
    protected $apiKey;

    public function __construct($mchid, $appid, $key)
    {
        $this->mchid = $mchid;
        $this->appid = $appid;
        $this->apiKey = $key;
    }

    /**
     * 发起订单
     * @param float $totalFee 收款总费用 单位元
     * @param string $outTradeNo 唯一的订单号
     * @param string $orderName 订单名称
     * @param string $notifyUrl 支付结果通知url 不要有问号
     * @param string $timestamp 订单发起时间
     * @return array
     */
    public function createJsBizPackage($totalFee, $outTradeNo, $orderName, $notifyUrl, $timestamp)
    {
        $config = array(
            "mch_id" => $this->mchid,
            "appid" => $this->appid,
            "key" => $this->apiKey,
        );
        $orderName = iconv("GBK","UTF-8",$orderName);
        $unified = array(
            "appid" => $config["appid"],
            "attach" => "pay",             //商家数据包,原样返回,如果填写中文,请注意转换为utf-8
            "body" => $orderName,
            "mch_id" => $config["mch_id"],
            "nonce_str" => self::createNonceStr(),
            "notify_url" => $notifyUrl,
            "out_trade_no" => $outTradeNo,
            "spbill_create_ip" => "127.0.0.1",
            "total_fee" => intval($totalFee * 100),       //单位 转为分
            "trade_type" => "NATIVE",
        );
        $unified["sign"] = self::getSign($unified, $config["key"]);
        $responseXml = self::curlPost("https://api.mch.weixin.qq.com/pay/unifiedorder", self::arrayToXml($unified));
        $unifiedOrder = simplexml_load_string($responseXml, "SimpleXMLElement", LIBXML_NOCDATA);
        if ($unifiedOrder === false) {
            die("parse xml error");
        }
        if ($unifiedOrder->return_code != "SUCCESS") {
            die($unifiedOrder->return_msg);
        }
        if ($unifiedOrder->result_code != "SUCCESS") {
            die($unifiedOrder->err_code);
        }
        $codeUrl = (array)($unifiedOrder->code_url);
        if(!$codeUrl[0]) exit("get code_url error");
        $arr = array(
            "appId" => $config["appid"],
            "timeStamp" => $timestamp,
            "nonceStr" => self::createNonceStr(),
            "package" => "prepay_id=" . $unifiedOrder->prepay_id,
            "signType" => "MD5",
            "code_url" => $codeUrl[0],
        );
        $arr["paySign"] = self::getSign($arr, $config["key"]);
        return $arr;
    }


    public function notify()
    {
        $config = array(
            "mch_id" => $this->mchid,
            "appid" => $this->appid,
            "key" => $this->apiKey,
        );
        $postStr = $GLOBALS["HTTP_RAW_POST_DATA"];

        $postObj = simplexml_load_string($postStr, "SimpleXMLElement", LIBXML_NOCDATA);
        if ($postObj === false) {
            die("parse xml error");
        }
        if ($postObj->return_code != "SUCCESS") {
            die($postObj->return_msg);
        }
        if ($postObj->result_code != "SUCCESS") {
            die($postObj->err_code);
        }
        $arr = (array)$postObj;
        unset($arr["sign"]);
        if (self::getSign($arr, $config["key"]) == $postObj->sign) {
            echo "";
            return $postObj;
        }
    }

    /**
     * curl get
     *
     * @param string $url
     * @param array $options
     * @return mixed
     */
    public static function curlGet($url = "", $options = array())
    {
        $ch = curl_init($url);
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
        curl_setopt($ch, CURLOPT_TIMEOUT, 30);
        if (!empty($options)) {
            curl_setopt_array($ch, $options);
        }
        //https请求 不验证证书和host
        curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
        curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);
        $data = curl_exec($ch);
        curl_close($ch);
        return $data;
    }

    public static function curlPost($url = "", $postData = "", $options = array())
    {
        if (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请求 不验证证书和host
        curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
        curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);
        $data = curl_exec($ch);
        curl_close($ch);
        return $data;
    }

    public static function createNonceStr($length = 16)
    {
        $chars = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";
        $str = "";
        for ($i = 0; $i < $length; $i++) {
            $str .= substr($chars, mt_rand(0, strlen($chars) - 1), 1);
        }
        return $str;
    }

    public static function arrayToXml($arr)
    {
        $xml = "";
        foreach ($arr as $key => $val) {
            if (is_numeric($val)) {
                $xml .= "<" . $key . ">" . $val . "";
            } else
                $xml .= "<" . $key . ">";
        }
        $xml .= "";
        return $xml;
    }
    /**
     * 获取签名
     */
    public static function getSign($params, $key)
    {
        ksort($params, SORT_STRING);
        $unSignParaString = self::formatQueryParaMap($params, false);
        $signStr = strtoupper(md5($unSignParaString . "&key=" . $key));
        return $signStr;
    }

    protected static function formatQueryParaMap($paraMap, $urlEncode = false)
    {
        $buff = "";
        ksort($paraMap);
        foreach ($paraMap as $k => $v) {
            if (null != $v && "null" != $v) {
                if ($urlEncode) {
                    $v = urlencode($v);
                }
                $buff .= $k . "=" . $v . "&";
            }
        }
        $reqPar = "";
        if (strlen($buff) > 0) {
            $reqPar = substr($buff, 0, strlen($buff) - 1);
        }
        return $reqPar;
    }
}

github下载地址:https://github.com/dedemao/we...

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/26108.html

相关文章

  • 一个PHP文件搞定微信支付系列退款

    摘要:网上的很多微信支付接入教程都颇为复杂,且需要配置和引入较多的文件,本人通过整理后给出一个单文件版的,希望可以给各位想接入微信支付的带来些许帮助和借鉴意义。直接运行该文件即可给指定的微信用户退款。 网上的很多PHP微信支付接入教程都颇为复杂,且需要配置和引入较多的文件,本人通过整理后给出一个单文件版的,希望可以给各位想接入微信支付的带来些许帮助和借鉴意义。 直接运行该文件即可给指定的微信...

    sanyang 评论0 收藏0
  • 一个PHP文件搞定支付系列手机网站支付(兼容微信浏览器)

    摘要:网上的很多支付宝支付接入教程都颇为复杂,且需要配置和引入较多的文件,本人通过整理后给出一个单文件版的,希望可以给各位想接入支付宝支付的带来些许帮助和借鉴意义。 网上的很多PHP支付宝支付接入教程都颇为复杂,且需要配置和引入较多的文件,本人通过整理后给出一个单文件版的,希望可以给各位想接入支付宝支付的带来些许帮助和借鉴意义。 一个PHP文件搞定支付宝系列:https://github.c...

    xinhaip 评论0 收藏0
  • 一个PHP文件搞定微信支付系列公众号支付

    摘要:效果如下需要注意的事项该文件需放到支付授权目录下,可以在微信支付商户平台产品中心开发配置中设置。 网上的很多PHP微信扫码支付接入教程都颇为复杂,且需要配置和引入较多的文件,本人通过整理后给出一个单文件版的,希望可以给各位想接入微信扫码支付的带来些许帮助和借鉴意义。 将该文件放到你的授权目录下,并在微信里访问这个文件,即可看到演示效果。效果如下:showImg(https://segm...

    Kaede 评论0 收藏0
  • 一个PHP文件搞定微信支付系列现金红包

    摘要:网上的很多微信支付接入教程都颇为复杂,且需要配置和引入较多的文件,本人通过整理后给出一个单文件版的,希望可以给各位想接入微信支付的带来些许帮助和借鉴意义。直接运行该文件即可给指定的微信用户发送现金红包。 网上的很多PHP微信支付接入教程都颇为复杂,且需要配置和引入较多的文件,本人通过整理后给出一个单文件版的,希望可以给各位想接入微信支付的带来些许帮助和借鉴意义。 直接运行该文件即可给指...

    pf_miles 评论0 收藏0
  • 一个PHP文件搞定微信支付系列企业付款

    摘要:网上的很多微信支付接入教程都颇为复杂,且需要配置和引入较多的文件,本人通过整理后给出一个单文件版的,希望可以给各位想接入微信支付的带来些许帮助和借鉴意义。直接运行该文件即可给指定的微信用户转账。 网上的很多PHP微信支付接入教程都颇为复杂,且需要配置和引入较多的文件,本人通过整理后给出一个单文件版的,希望可以给各位想接入微信支付的带来些许帮助和借鉴意义。 直接运行该文件即可给指定的微信...

    MoAir 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<