번개 보호! 기업 계정을 통합하는 thinkphp의 함정

藏色散人
풀어 주다: 2020-07-28 14:03:25
앞으로
1869명이 탐색했습니다.

다음 튜토리얼 칼럼인 thinkphp 프레임워크에서는 thinkphp 통합 기업 계정의 문제점을 공유할 것입니다. 이것이 필요한 친구들에게 도움이 되기를 바랍니다!

번개 보호! 기업 계정을 통합하는 thinkphp의 함정

WeChat 기업 계정 콜백 사용 시 ThinkPHP의 함정

최근에 기업 계정 콜백을 위한 인터페이스 작업을 하고 있는데 이전에 Thinkphp에 연결할 때마다 다양한 오류가 보고되었습니다. 나는 밟아야 할 덫과 밟아서는 안 될 덫을 모두 밟아버렸다.

이번에 함정에 빠져 포기할 뻔 했습니다. 기업 계정 콜백이 암호화된 알고리즘을 거치게 된다는 것은 개발자가 콜백을 활성화하기 위해 복호화해야 한다는 사실을 알고 계실 겁니다. , WeChat 오류 메시지 매우 위압적입니다. 귀하의 잘못이 무엇이든 "echostr 확인에 실패했습니다. 올바르게 해독되었는지 확인하고 일반 텍스트 echostr을 출력하십시오"라고 말하면 됩니다. 최소한 개발자는 WeChat에서 수신한 응답의 길이를 알려야 하며, 내용은 물론이고 길이가 일치하지 않는 경우 자체 출력으로 확인할 수도 있습니다.

나처럼 TP 프레임워크를 사용한다면 이 기사에서는 Thinkphp3.2.3 php 버전 5.3을 예로 들어 설명하겠습니다.

Pit 1

  • 공식 처리 인터페이스 예제를 다운로드하여 Thinkphp>Library>에 넣으세요. ;

  • Wechat(자체 구축) 디렉터리에서 WXBizMsgCrypt.php를 WXBizMsgCrypt.class.php로 수정합니다.

  • WXBizMsgCrypt에서 Wechat 네임스페이스를 선언합니다.

  • Wechat을 사용하는 클래스를 소개합니다. 필요한 컨트롤러에 WXBizM이 포함되어 있습니다. sgCrypt ;

그런 다음 공식 샘플 사본을 사용하여 프로젝트에 들어가서 간단한 수정만 하면 통합이 완료됩니다. PHP5.3 이전의 생성자 작성 방법은 PHP5.3 이후와 달라졌습니다. 생성자는 더 이상 클래스 이름을 함수 이름으로 지정할 수 없습니다. 생성자를 선언하려면 __construct를 사용해야 합니다. 즉, 공식 예제를 사용하여 통합해야 합니다. 물론 PHP5.3 이후 버전을 사용하는 경우 오류가 보고됩니다.

그래서 여전히

  • WXBizMsgCrypt 파일에서 WXBizMsgCrypt 함수 이름을 수정하고 __construct

  • pkcs7Encoder 파일에서 pkcs7Encoder 함수 이름을 수정하고 __construct

  • 로 변경해야 합니다.

너는 done Thinkphp 이하 php5.3 버전에서는 적용되지 않을 수 있습니다. 다른 버전은 테스트해보지 않았습니다.

Pit 2

기업 계정 콜백 정보를 입력하고 저장을 클릭했는데 실패할 경우 몇 번 더 클릭하면 정말 놀라운 일이 됩니다. !
농담이 아닙니다~~ 기업 계정에서 개발자에게 보내는 무작위 서명에는 + 기호가 포함될 가능성이 높기 때문에 URL을 받으면 PHP는 자동으로 + 기호를 공백으로 필터링하여 전송된 서명과 실제 서명을 생성합니다. 주소가 일치하지 않으면 서명 확인이 통과되지 않고 40001: 서명 확인 오류가 보고됩니다.
물론, 전송된 서명 주소와 일치하도록 공백을 + 기호로 변경할 수도 있습니다. (위챗 콜백의 작은 버그인 것 같습니다. 서명에 그런 특별한 의미를 갖는 기호가 포함되어서는 안 됩니다.)

Pit 3

모두 검증을 통과했으며, 위챗에서 요청한 일반 텍스트가 여전히 반환되지 않았습니다. 무엇? 로컬로 인쇄해서 확인해 보세요. 바이두 전체를 검색해서 파일의 BOM 헤더를 제거하고 헤더를 변경하기 위해 모든 노력을 다 했고, 해독된 결과를 WeChat으로 돌려보냈습니다. 아직도 작동하지 않아요, WTF. .

일반 텍스트가 정말 반환되었나요? 로컬로 인쇄하는 것이 맞다고 생각하시나요? 잘못된. 버퍼라는 것이 있습니다. 버퍼에 있는 내용은 로컬로 인쇄되지 않습니다. WeChat이 웹 사이트에 액세스할 때 가장 먼저 얻는 것은 사용자가 출력하는 일반 텍스트가 아닌 버퍼의 내용입니다. 따라서 echo 이전에 ob_clean()을 사용하여 버퍼를 먼저 지워야 합니다. 다른 프레임워크도 동일할 것으로 추정됩니다.

이 세 가지는 상대적으로 큰 함정이며 인터넷에는 정보가 거의 없습니다. 모두에게 도움이 되기를 바랍니다.

위 내용은 번개 보호! 기업 계정을 통합하는 thinkphp의 함정의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:segmentfault.com
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿