>  기사  >  백엔드 개발  >  WeChat 애플릿 채우기 함정 PHP 개발 IIS7

WeChat 애플릿 채우기 함정 PHP 개발 IIS7

不言
不言원래의
2018-04-17 11:22:131520검색

이 글에서는 주로 PHP 개발 IIS7의 문제점을 보완하기 위한 WeChat 애플릿을 소개합니다. 관심 있는 친구들이 참고할 수 있습니다.

몰 애플릿을 만드는 데 7일이 걸렸습니다. 문서가 포괄적이지 않아서 모든 것을 직접 탐색해야 합니다

온라인에 접속한 후 동시에 버전이 1.2 이상이어야 합니다. Alibaba Cloud에 무료 CA 인증서가 있습니다. 2018.4.16 친애하는 신청할 수 있지만 인증서를 신청하려면 탐색에서 무작위로 클릭해야 하며 무료 CA 인증서를 클릭해야 합니다

Windows 2008 r2에서 Windows Power를 통해 버전을 1.2 이상으로 업그레이드하려면 인터넷에 많은 튜토리얼도 있습니다


다음은 주로 개발 함정에 대해 설명합니다

1: 먼저 피트에 로그인하세요

session_key 및 openid를 얻으려면

https://developers.weixin.qq.com/miniprogram/dev/api/api-login.html

프런트 엔드 code

wx.login({
  success: (loginRes) =>  
  { 
    loginRes.code
  }
})

server로 이동합니다. 왜 프론트엔드에서 완성하지 않고 서버로 가야 할까요?

공식 문서에 다음과 같은 구절이 있습니다.

세션 키 session_key는 사용자 데이터를 암호화하고 서명하는 키입니다. 애플리케이션 자체의 데이터 보안을 보장하기 위해 개발자 서버는 세션 키를 미니 프로그램에 전달하거나 이 키를 외부에 제공해서는 안 됩니다.

서버측 PHP는 https://api.weixin.qq.com/sns/jscode2session

을 통해 session_key와 openid를 얻습니다.

사용자의 아바타 닉네임 등은 프런트엔드를 통해 얻을 수 있습니다.

wx.getUserInfo 인터페이스

데이터가 Tampering되는 것을 방지하기 위해 WeChat은 공식적으로 encryptedData 반환 값을 제공합니다. 이 반환 값은 서버
에서 제공되는 다양한 언어를 통해

서버

의 알고리즘을 통해 잠금 해제될 수 있습니다. 다음 페이지

https://developers.weixin.qq.com/miniprogram/dev/ api/signature.html?t=20161122

1: 결제 피트

위챗 관계자를 칭찬하고 싶습니다. 문서가 정말 지저분합니다. 특히 마지막 단계에 페이지가 있습니다. 결제 확인에 실패했습니다.

확실히 대소문자 문제입니다. 예를 들어, 앱 ID입니다. appid는 어디에나 있지만 여기서는 대문자로 표기해야 합니다. 확실하지 않은 내용이 있으면 공식에서 온라인 확인을 제공합니다

https://pay.weixin.qq.com/wiki/ tools/signverify/

결제 단계


사용자가 프런트 엔드에서 결제 시작 ->서버와 통신 ->서버가 매개변수 제출 WeChat 결제 인터페이스(https://api.mch.weixin.qq)로 이동 .com/pay/unifiedorder) prepay_id를 얻습니다. 서버는 확인 매개변수를 생성하여 프런트엔드로 보냅니다. 프런트 엔드는 wx.requestPayment

를 실행하여 통합 주문을 합니다. 문서: https:/ /pay.weixin.qq.com/wiki/doc/api/wxa/wxa_api.php?chapter=9_1


wx.request지불 문서: https://developers.weixin.qq.com/miniprogram/dev/api/api -pay.html

통합 주문 인터페이스를 통과한 후 대문자 사용에 주의하세요

. appid와 nonce_Str의 두 가지 잘못된 작성 방법을 오랫동안 반복해서 확인했습니다. 예도 제공하겠습니다. Array 및 pseudo-Query 변환을 위한 몇 가지 편리한 변환 함수

$params=array(
        'appId'=>'',
        'package'=>'prepay_id='.'',
        'timeStamp'=>'',
        'signType'=>'MD5',
        'nonceStr'=>''
);

$params['paySign']=md5Sign($params);
unset($params['appId']);

그런 다음 $params를 프런트엔드에 전달하여 wx.requestPayment 인터페이스를 호출합니다


다음은 제가 계정을 차단할 때 자주 사용하는 PHP 측 개발 함수입니다.

/*
by 醉亦逝愁
md5Sign用于小程序服务端签名校验
*/
function md5Sign($params){ 		
    	ksort($params); 
	$stringA=arr2str($params);
	$stringSignTemp=$stringA.'&key='.'商户key(mch_key)';
	$sign=strtoupper(md5($stringSignTemp));
	return $sign;
} 
/*
by 醉亦逝愁
arr2str用于小程序服务端Array转伪Query
*/
function arr2str($array){
 
    $string = [];
 
    if($array && is_array($array)){
 
        foreach ($array as $key=> $value){
            $string[] = $key.'='.$value;
        }
    }
 
    return implode('&',$string);
}
/*
by 醉亦逝愁
arr2str用于小程序服务端Array转Xml
用途https://api.mch.weixin.qq.com/pay/unifiedorder
*/
function arr2xml($arr,$item='root'){        
    $dom = new DOMDocument("1.0"); 
    $item = $dom->createElement($item); 
    $dom->appendChild($item); 
    foreach ($arr as $key=>$val){ 
        $itemx = $dom->createElement(is_string($key)?$key:"item"); 
        $item->appendChild($itemx); 
        if (!is_array($val)){ 
            $text = $dom->createCDATASection($val); 
            $itemx->appendChild($text); 
        }else { 
            arrayToXml($val,$dom,$itemx); 
        } 
    } 
    return $dom->saveXML($item); 
}




https://api.mch.weixin.qq.com/pay/unifiedorder 인터페이스에서 반환된 xml은 다음 함수를 통해 배열이 됩니다

$xmlstring=simplexml_load_string($data, 'SimpleXMLElement', LIBXML_NOCDATA);
$data=get_object_vars($xmlstring);

기타는 다음과 같습니다. 나중에 추가되었습니다.

관련 추천:

php WeChat 공개 계정 개발 현금 빨간 봉투







,


🎜

위 내용은 WeChat 애플릿 채우기 함정 PHP 개발 IIS7의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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