>위챗 애플릿 >위챗 개발 >WeChat 공개 플랫폼, WeChat 결제 개발

WeChat 공개 플랫폼, WeChat 결제 개발

高洛峰
高洛峰원래의
2017-03-01 09:59:091838검색

1. JS-SDK

공식 계정의 WeChat 결제는 JS를 통해 구현되어야 합니다. WeChat JS-SDK는 웹 개발자를 위해 WeChat 공개 플랫폼에서 제공하는 WeChat 기반의 웹 개발 툴킷입니다.

1) JS 스크립트 파일 가져오기

<script src="http://res.wx.qq.com/open/js/jweixin-1.0.0.js"></script>

2) 구성 인터페이스를 통해 권한 확인 구성 삽입

<script>
    wx.config({
    debug: false, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
    appId: &#39;&#39;, // 必填,公众号的唯一标识
    timestamp: , // 必填,生成签名的时间戳
    nonceStr: &#39;&#39;, // 必填,生成签名的随机串
    signature: &#39;&#39;,// 必填,签名
});
</script>

appId는 애플리케이션 ID, wx로 시작하는 문자열, timestampphp에서는 time()을 사용하여 구하는데 nonceStr은 uniqid()를 사용하여 구하고 시그니처는 특정 알고리즘에 따라 구합니다.

protected function getJsapiConfig()
    {
        $weixin = new Weixin();
        $ticketMongo = new WeixinJsapiTicket();
        $data = [
            &#39;appId&#39; => $weixin->getAppId(),
            &#39;noncestr&#39; => uniqid(),
            &#39;jsapi_ticket&#39; => $ticketMongo->getJsapiTicket(),
            &#39;timestamp&#39; => time()
        ];
        //拼装原始待签名串
        $src = [
            &#39;noncestr=&#39; . $data[&#39;noncestr&#39;],
            &#39;jsapi_ticket=&#39; . $data[&#39;jsapi_ticket&#39;],
            &#39;timestamp=&#39; . $data[&#39;timestamp&#39;]
        ];
        sort($src);
        $data[&#39;signature&#39;] = sha1(implode(&#39;&&#39;, $src));
        return $data;
    }

다음은 "jsapi_ticket"에 대한 설명입니다. jsapi_ticket은 공용 계정에서 WeChat JS 인터페이스를 호출하는 데 사용되는 임시 티켓입니다. 일반적인 상황에서 access_token을 통해 얻은 jsapi_ticket의 유효기간은 7200초입니다. 시간 제한이 있고 jsapi_ticket을 얻기 위한 API 호출 횟수가 매우 제한되어 있으므로 얻은 jsapi_ticket을 MongoDB에 저장하겠습니다.

/**
     * 通过access_token获取jsapi_ticket
     * @param $access_token
     * @return string | null
     */
    public function getJsapiTicket($access_token)
    {
        $url = &#39;https://api.weixin.qq.com/cgi-bin/ticket/getticket&#39;;
        $param = [
        &#39;access_token&#39; => $access_token,
        &#39;type&#39; => &#39;jsapi&#39;
                ];
        $res = $this->request($url, $param);
        $result = json_decode($res, true);
        if (isset($result[&#39;errcode&#39;]) && $result[&#39;errcode&#39;] == 0 && isset($result[&#39;ticket&#39;])) {
            return $result;
        }
        return null;
    }

3) 준비된 인터페이스를 통해 성공적인 인증 처리

1) prepay_id 기반 on 로컬에서 생성된 주문 번호를 얻습니다. 주문 번호는 요청할 때마다 다릅니다. 그렇지 않으면 오류가 보고됩니다.

2) md5(uniqid('baiaimama'))를 사용하세요. nonceStr을 얻으려면

3) signType은 MD5를 사용합니다

4) paySign은 코드의 매개변수에 따라 정렬하고 연결하여 얻습니다.

wx.chooseWXPay({
    timestamp: 0, // 支付签名时间戳,注意微信jssdk中的所有使用timestamp字段均为小写。但最新版的支付后台生成签名使用的timeStamp字段名需大写其中的S字符
    nonceStr: '', // 支付签名随机串,不长于 32 位
    package: '', // 统一支付接口返回的prepay_id参数值,提交格式如:prepay_id=***)
    signType: '', // 签名方式,默认为'SHA1',使用新版支付需传入'MD5'
    paySign: '', // 支付签名
    success: function (res) {
        // 支付成功后的回调函数
    }
});

/**
     * 生成jsapi需要调用的参数
     */
    public function getJsapiParam(){
        $param = [
        'appId' => $this->APPID,
        'timeStamp' => time(),
        'nonceStr' => md5(uniqid('baiaimama')),
        'package' => 'prepay_id='.$this->param['prepay_id'],
        'signType' => 'MD5'
                ];
    
        $str = [];
        foreach($param as $k=>$v){
            if(!empty($v)){
                $str[] = "{$k}={$v}";
            }
        }
        sort($str);
        $unsignKey = join('&', $str).'&key='.$this->KEY;
        $sign = strtoupper(md5($unsignKey));
        $param['paySign'] = $sign;
        return $param;
    }

비동기 콜백

비동기 콜백에서는 주문 상태 수정, 문자 메시지 보내기, 메시지 푸시 등의 작업을 수행합니다.

아아앙

데모 다운로드:

github 주소: https://github.com/pwstrick/weixin_demo

CSDN 주소: http://download.csdn.net/detail/loneleaf1 /9045731

더 많은 WeChat 공개 플랫폼 개발 및 WeChat 결제 관련 기사를 보려면 PHP 중국어 웹사이트를 주목하세요!



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