찾다
백엔드 개발PHP 튜토리얼php 위챗 결제 APP 결제방법_php 스킬

이 기사에서는 WeChat 결제 기능을 통합한 WeChat 오픈 플랫폼 모바일 애플리케이션의 예를 설명합니다. 참고할 수 있도록 모든 사람과 공유하세요. 구체적인 분석은 다음과 같습니다.

WechatAppPay 파일 코드는 다음과 같습니다.

코드 복사 코드는 다음과 같습니다.

네임스페이스 commonservicesWechatPay;
WechatAppPay 클래스는 WechatPayBase를 확장합니다
{
//패키지 매개변수
공개 $패키지 = [];
//비동기 알림 매개변수
공개 $notify = [];
//선불 주문 매개변수 푸시
보호된 $config = [];
//액세스 토큰과 획득 시간을 저장하는 파일
보호된 $file;
//액세스 토큰
보호된 $accessToken;
//액세스 토큰 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';
공개 함수 __construct()
{
           $this->file = __DIR__ '/payAccessToken.txt';
}
/**
* *APP 결제 최종 반환 매개변수 생성
* @예외 발생
* @return 다중 유형:문자열 NULL
​​*/
공개 함수 createAppPayData()
{
          $this->generateConfig();
$prepayid = $this->getPrepayid();
         시도해 보세요{
$배열 = [
                  'appid' => $this->appid,
                 'appkey' => $this->paySignkey,
                 'noncestr' =>$this->getRandomStr(),
               '패키지' => '서명=WXPay',
                  'partnerid' =>$this->partnerId,
                 '선불' => $선불,
                  '타임스탬프' => (문자열)시간(),
];
$array['sign'] = $this->sha1Sign($array);
              unset($array['appkey']);
           } catch(예외 $e) {
                 새로운 예외 발생($e->getMessage());
}
          $배열 반환;
}
/**
* * 결제 성공 확인 후 알림 매개변수
* *
* @예외 발생
* @return 부울
​​*/
공개 함수 verifyNotify()
{
         시도해 보세요{
$staySignStr = $this->알림;
              unset($staySignStr['sign']);
$sign = $this->signData($staySignStr);
                return $this->notify['sign'] === $sign;
           } catch(예외 $e) {
                 새로운 예외 발생($e->getMessage());
}
}
/**
* 마법의 방법, 결제 매개변수 추가
* *
* @param string $name 매개변수 이름
* @param string $value 매개변수 값
​​*/
공개 함수 __set($name, $value)
{
        $this->$name = $value;
    }
    /**
     * 设置액세스 토큰
     * @param 문자열 $token
     * @예외 발생
     * @return 부울
    */
    공개 함수 setAccessToken()
    {
        시도해 보세요{
            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']                     $this->accessToken = $info['accessToken'];
                    true를 반환합니다.
                }
            }
            //文件内容为空或액세스 토큰已失效,중신설
            $this->outputAccessTokenToFile();
        } catch(예외 $e) {
            새로운 예외 발생($e->getMessage());
        }
        true를 반환합니다.
    }
    /**
* 파일에 액세스 토큰 쓰기
* @예외 발생
* @return 부울
​​*/
    보호된 함수 outputAccessTokenToFile()
    {
        시도해 보세요{
            $f = fopen($this->file, 'wb');
            $토큰 = [
                '액세스 토큰' => $this->getAccessToken(),
                'getTime' => 시간(),
            ];
            무리($f, LOCK_EX);
            fwrite($f, json_encode($token));
            무리($f, LOCK_UN);
            fclose($f);
            $this->accessToken = $token['accessToken'];
        } catch(예외 $e) {
            새로운 예외 발생($e->getMessage());
        }
        true를 반환합니다.
    }
    /**
     * 取액세스 토큰
     *
     * @예외 발생
     * @return 문자열
    */
    보호된 함수 getAccessToken()
    {
        $url = sprintf(self::ACCESS_TOKEN_URL, $this->appid, $this->appSecret);
        $result = json_decode( $this->getUrl($url), true );
        if(isset($result['errcode'])) {
            새로운 예외 발생("액세스 토큰 가져오기 실패:{$result['errmsg']}");
        }
        $result['access_token'];
반환     }
    /**
* 선불 세션 ID 받기
* *
* @예외 발생
* @return 문자열
​​*/
    보호된 함수 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 ) {
            새로운 예외 발생($result['errmsg']);
        }
        if( !isset($result['prepayid']) ) {
            새로운 예외 발생('선불 ID 가져오기 실패, URL 요청 오류.');
        }
        $result['prepayid'];
반환     }
    /**
* 선불 매개변수 조합
* *
* @예외 발생
​​*/
    보호된 함수 generateConfig()
    {
        시도해 보세요{
            $this->config = [
                    '앱' => $this->appid,
                    '추적' => $this->traceid
                    'noncestr' => $this->getRandomStr(),
                    '타임스탬프' => 시간(),
                    '패키지' => $this->generatePackage(),
                    'sign_method' => $this->sign_method,
            ];
            $this->config['app_signature'] = $this->generateSign();
        } catch(예외 $e) {
            새로운 예외 발생($e->getMessage());
        }
    }
    /**
* 패키지 필드 생성
* *
* 규칙 생성:
* 1. 부호 signValue
의 값을 생성합니다. * 2. 패키지 매개변수를 쿼리 문자열에 다시 연결하고 값은 urlencode여야 합니다
* 3. 2에서 생성된 문자열에 sign=signValue를 붙여 최종 패키지 문자열
을 얻습니다. * *
* * 2단계에서 urlencode 공백은
대신에 인코딩되어야 합니다. * *
* RFC 1738은 공백을
으로 인코딩합니다. * RFC 3986은 공백을
으로 인코딩합니다. * *
* @return 문자열
​​*/
    보호된 함수 generatePackage()
    {
        $this->package['sign'] = $this->signData($this->패키지);
        return http_build_query($this->package, '', '&', PHP_QUERY_RFC3986);
    }
    /**
* 서명 생성
* *
* @return 문자열
​​*/
    보호된 함수 generateSign()
    {
        $signArray = [
            '앱' => $this->appid,
            '앱키' => $this->paySignkey,
            'noncestr' => $this->config['noncestr'],
            '패키지' => $this->config['패키지'],
            '타임스탬프' => $this->config['timestamp'],
            '추적' => $this->traceid
        ];
        return $this->sha1Sign($signArray);
    }
    /**
*시그니처 데이터
* *
* 규칙 생성:
* 1. 사전 정렬, 쿼리 문자열 형식으로 연결, urlencode 필요 없음
* 2. 이전 단계에서 얻은 문자열은 최종적으로 key=paternerKey
로 이어집니다. * 3. MD5는 문자열을 해시하고 대문자로 변환하여 부호 signValue
의 값을 얻습니다. * *
* @param array $data 서명할 데이터
* @return 문자열 최종 서명 결과
​​*/
    보호된 함수 signData($data)
    {
        ksort($data);
        $str = $this->arrayToString($data);
        $str .= "&key={$this->partnerKey}";
        return strtoupper( $this->signMd5($str) );
    }
    /**
* sha1 서명
*서명규칙
* 1. 사전정렬
* 2. 쿼리 문자열 연결
* 3. sha1 작업
* *
* @param 배열 $arr
* @return 문자열
​​*/
    보호된 함수 sha1Sign($arr)
    {
        ksort($arr);
        return sha1( $this->arrayToString($arr) );
    }
}

希望本文所述对大家程序设计有所帮助。

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

php把负数转为正整数的方法:1、使用abs()函数将负数转为正数,使用intval()函数对正数取整,转为正整数,语法“intval(abs($number))”;2、利用“~”位运算符将负数取反加一,语法“~$number + 1”。

php怎么实现几秒后执行一个函数php怎么实现几秒后执行一个函数Apr 24, 2022 pm 01:12 PM

实现方法:1、使用“sleep(延迟秒数)”语句,可延迟执行函数若干秒;2、使用“time_nanosleep(延迟秒数,延迟纳秒数)”语句,可延迟执行函数若干秒和纳秒;3、使用“time_sleep_until(time()+7)”语句。

php怎么除以100保留两位小数php怎么除以100保留两位小数Apr 22, 2022 pm 06:23 PM

php除以100保留两位小数的方法:1、利用“/”运算符进行除法运算,语法“数值 / 100”;2、使用“number_format(除法结果, 2)”或“sprintf("%.2f",除法结果)”语句进行四舍五入的处理值,并保留两位小数。

php怎么根据年月日判断是一年的第几天php怎么根据年月日判断是一年的第几天Apr 22, 2022 pm 05:02 PM

判断方法:1、使用“strtotime("年-月-日")”语句将给定的年月日转换为时间戳格式;2、用“date("z",时间戳)+1”语句计算指定时间戳是一年的第几天。date()返回的天数是从0开始计算的,因此真实天数需要在此基础上加1。

php字符串有没有下标php字符串有没有下标Apr 24, 2022 am 11:49 AM

php字符串有下标。在PHP中,下标不仅可以应用于数组和对象,还可应用于字符串,利用字符串的下标和中括号“[]”可以访问指定索引位置的字符,并对该字符进行读写,语法“字符串名[下标值]”;字符串的下标值(索引值)只能是整数类型,起始值为0。

php怎么替换nbsp空格符php怎么替换nbsp空格符Apr 24, 2022 pm 02:55 PM

方法:1、用“str_replace(" ","其他字符",$str)”语句,可将nbsp符替换为其他字符;2、用“preg_replace("/(\s|\&nbsp\;||\xc2\xa0)/","其他字符",$str)”语句。

php怎么判断有没有小数点php怎么判断有没有小数点Apr 20, 2022 pm 08:12 PM

php判断有没有小数点的方法:1、使用“strpos(数字字符串,'.')”语法,如果返回小数点在字符串中第一次出现的位置,则有小数点;2、使用“strrpos(数字字符串,'.')”语句,如果返回小数点在字符串中最后一次出现的位置,则有。

php怎么读取字符串后几个字符php怎么读取字符串后几个字符Apr 22, 2022 pm 08:31 PM

在php中,可以使用substr()函数来读取字符串后几个字符,只需要将该函数的第二个参数设置为负值,第三个参数省略即可;语法为“substr(字符串,-n)”,表示读取从字符串结尾处向前数第n个字符开始,直到字符串结尾的全部字符。

See all articles

핫 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 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기

Dreamweaver Mac版

Dreamweaver Mac版

시각적 웹 개발 도구

SublimeText3 영어 버전

SublimeText3 영어 버전

권장 사항: Win 버전, 코드 프롬프트 지원!

메모장++7.3.1

메모장++7.3.1

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