国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - PHP教程 - php微信支付之APP支付方法

php微信支付之APP支付方法

2020-09-07 10:15OSC首席鍵客 PHP教程

這篇文章主要介紹了php微信支付之APP支付方法,實例分析了php微信支付接口文件及使用技巧,需要的朋友可以參考下

本文實例講述了微信開放平臺移動應用集成微信支付功能。分享給大家供大家參考。具體分析如下:

WechatAppPay文件代碼如下:

復制代碼 代碼如下:

<?php
namespace common\services\WechatPay;
class WechatAppPay extends WechatPayBase
{
    //package參數
    public $package = [];
    //異步通知參數
    public $notify = [];
    //推送預支付訂單參數
    protected $config = [];
    //存儲access token和獲取時間的文件
    protected $file;
    //access token
    protected $accessToken;
    //取access token的url
    const ACCESS_TOKEN_URL = 'https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=%s&secret=%s';
    //生成預支付訂單提交地址
    const POST_ORDER_URL = 'https://api.weixin.qq.com/pay/genprepay?access_token=%s';
    public function __construct()
    {
        $this->file = __DIR__ . '/payAccessToken.txt';
    }
    /**
     * 創建APP支付最終返回參數
     * @throws \Exception
     * @return multitype:string NULL
     */
    public function createAppPayData()
    {
        $this->generateConfig();
        $prepayid = $this->getPrepayid();
        try{
            $array = [
                'appid' => $this->appid,
                'appkey' => $this->paySignkey,
                'noncestr' => $this->getRandomStr(),
                'package' => 'Sign=WXPay',
                'partnerid' => $this->partnerId,
                'prepayid' => $prepayid,
                'timestamp' => (string)time(),
            ];
            $array['sign'] = $this->sha1Sign($array);
            unset($array['appkey']);
        } catch(\Exception $e) {
            throw new \Exception($e->getMessage());
        }
        return $array;
    }
    /**
     * 驗證支付成功后的通知參數
     *
     * @throws \Exception
     * @return boolean
     */
    public function verifyNotify()
    {
        try{
            $staySignStr = $this->notify;
            unset($staySignStr['sign']);
            $sign = $this->signData($staySignStr);
            return $this->notify['sign'] === $sign;
        } catch(\Exception $e) {
            throw new \Exception($e->getMessage());
        }
    }
    /**
     * 魔術方法,給添加支付參數進來
     *
     * @param string $name  參數名
     * @param string $value  參數值
     */
    public function __set($name, $value)
    {
        $this->$name = $value;
    }
    /**
     * 設置access token
     * @param string $token
     * @throws \Exception
     * @return boolean
     */
    public function setAccessToken()
    {
        try{
            if(!file_exists($this->file) || !is_file($this->file)) {
                $f = fopen($this->file, 'a');
                fclose($f);
            }
            $content = file_get_contents($this->file);
            if(!empty($content)) {
                $info = json_decode($content, true);
                if( time() - $info['getTime'] < 7150 ) {
                    $this->accessToken = $info['accessToken'];
                    return true;
                }
            }
            //文件內容為空或access token已失效,重新獲取
            $this->outputAccessTokenToFile();
        } catch(\Exception $e) {
            throw new \Exception($e->getMessage());
        }
        return true;
    }
    /**
     * 寫入access token 到文件
     * @throws \Exception
     * @return boolean
     */
    protected function outputAccessTokenToFile()
    {
        try{
            $f = fopen($this->file, 'wb');
            $token = [
                'accessToken' => $this->getAccessToken(),
                'getTime' => time(),
            ];
            flock($f, LOCK_EX);
            fwrite($f, json_encode($token));
            flock($f, LOCK_UN);
            fclose($f);
            $this->accessToken = $token['accessToken'];
        } catch(\Exception $e) {
            throw new \Exception($e->getMessage());
        }
        return true;
    }
    /**
     * 取access token
     *
     * @throws \Exception
     * @return string
     */
    protected function getAccessToken()
    {
        $url = sprintf(self::ACCESS_TOKEN_URL, $this->appid, $this->appSecret);
        $result = json_decode( $this->getUrl($url), true );
        if(isset($result['errcode'])) {
            throw new \Exception("get access token failed:{$result['errmsg']}");
        }
        return $result['access_token'];
    }
    /**
     * 取預支付會話標識
     *
     * @throws \Exception
     * @return string
     */
    protected function getPrepayid()
    {
        $data = json_encode($this->config);
        $url = sprintf(self::POST_ORDER_URL, $this->accessToken);
        $result = json_decode( $this->postUrl($url, $data), true );
        if( isset($result['errcode']) && $result['errcode'] != 0 ) {
            throw new \Exception($result['errmsg']);
        }
        if( !isset($result['prepayid']) ) {
            throw new \Exception('get prepayid failed, url request error.');
        }
        return $result['prepayid'];
    }
    /**
     * 組裝預支付參數
     *
     * @throws \Exception
     */
    protected function generateConfig()
    {
        try{
            $this->config = [
                    'appid' => $this->appid,
                    'traceid' => $this->traceid,
                    'noncestr' => $this->getRandomStr(),
                    'timestamp' => time(),
                    'package' => $this->generatePackage(),
                    'sign_method' => $this->sign_method,
            ];
            $this->config['app_signature'] = $this->generateSign();
        } catch(\Exception $e) {
            throw new \Exception($e->getMessage());
        }
    }
    /**
     * 生成package字段
     *
     * 生成規則:
     * 1、生成sign的值signValue
     * 2、對package參數再次拼接成查詢字符串,值需要進行urlencode
     * 3、將sign=signValue拼接到2生成的字符串后面得到最終的package字符串
     *
     * 第2步urlencode空格需要編碼成%20而不是+
     *
     * RFC 1738會把 空格編碼成+
     * RFC 3986會把空格編碼成%20
     *
     * @return string
     */
    protected function generatePackage()
    {
        $this->package['sign'] = $this->signData($this->package);
        return http_build_query($this->package, '', '&', PHP_QUERY_RFC3986);
    }
    /**
     * 生成簽名
     *
     * @return string
     */
    protected function generateSign()
    {
        $signArray = [
            'appid' => $this->appid,
            'appkey' => $this->paySignkey,
            'noncestr' => $this->config['noncestr'],
            'package' => $this->config['package'],
            'timestamp' => $this->config['timestamp'],
            'traceid' => $this->traceid,
        ];
        return $this->sha1Sign($signArray);
    }
    /**
     * 簽名數據
     *
     * 生成規則:
     * 1、字典排序,拼接成查詢字符串格式,不需要urlencode
     * 2、上一步得到的字符串最后拼接上key=paternerKey
     * 3、MD5哈希字符串并轉換成大寫得到sign的值signValue
     *
     * @param array $data 待簽名數據
     * @return string 最終簽名結果
     */
    protected function signData($data)
    {
        ksort($data);
        $str = $this->arrayToString($data);
        $str .= "&key={$this->partnerKey}";
        return strtoupper( $this->signMd5($str) );
    }
    /**
     * sha1簽名
     * 簽名規則
     * 1、字典排序
     * 2、拼接查詢字符串
     * 3、sha1運算
     *
     * @param array $arr
     * @return string
     */
    protected function sha1Sign($arr)
    {
        ksort($arr);
        return sha1( $this->arrayToString($arr) );
    }
}

 

希望本文所述對大家的php程序設計有所幫助。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 龙珠z普通话国语版在线观看 | 日韩簧片 | 伦理午夜电影免费观看 | 精品91久久 | 人人人射| 成人1区 | 欧美视频一区二区 | 色婷婷一区二区三区 | 中文字幕一区二区三区四区五区 | 欧美日韩精品 | 岛国av免费| 在线观看国产一区 | 少妇精品久久久久久久久久 | 欧美1页| 午夜精品网站 | 国产毛片一区二区 | 女同另类 | 日韩av一区二区在线观看 | 黄色毛片三级 | 狠狠躁夜夜躁人人爽天天高潮 | 可以看av的网站 | 一区二区三区视频在线观看 | 99视频在线 | 中文字幕av一区二区三区 | 国产精品爱久久久久久久 | 噜噜噜噜狠狠狠7777视频 | 久久国产精品免费一区二区三区 | 高清视频一区二区三区 | 特级黄一级播放 | 精品国产不卡一区二区三区 | 色爱综合网| 国产一级一级毛片女人精品 | 国产精品色一区二区三区 | 天天澡天天狠天天天做 | 色猫猫国产区一区二在线视频 | 色片视频免费 | 日韩高清电影 | 狠狠久 | 欧美日韩视频第一页 | 欧美综合在线观看 | 黄色片网站在线免费观看 |