이 기사에서는 PHP를 사용하여 SMS 인증 코드를 보내는 작업을 공개합니다. 예전에 모바일 앱에 계정을 등록할 때 인증 코드 전송을 클릭하면 " "삑삑" 소리가 나면 몇 초 안에 인증번호가 휴대폰으로 전송됩니다. 정말 놀랍죠?
1. 비즈니스에서 로그인 및 등록을 위한 API 인터페이스를 작성해야 하므로 휴대폰 번호 등록의 프런트엔드 및 백엔드 상호 작용 프로세스에 대해 배웠습니다.
(1) 사용자가 운영하는 작업입니다. 클라이언트가 클릭하여 인증 코드를 보냅니다. (그런 다음 고객은 마지막에 ajax를 통해 요청을 보내고 버튼은 60초 무음 시간입니다.)
(2) 백엔드 로직 레이어는 전달된 휴대폰 번호를 수락하고, 형식이 합법적인지 확인하고 일치 항목이 있는지 확인하기 위해 데이터베이스에 들어갑니다
(3) 인증 코드를 생성하고 세션이 존재하며 컬이 타사 SMS 인터페이스 링크로 전송됩니다
(4) 세 번째 구성 -지정된 휴대폰 번호를 사용하는 사용자에게 인증 코드 정보를 보내는 파티 SMS 플랫폼
오늘은 주로 타사 플랫폼의 구성과 백그라운드 처리 논리를 설명합니다.타사 플랫폼은 다음과 같습니다. (다른 플랫폼을 선택할 수도 있으며 원칙은 거의 유사합니다.) (1) Saidi Cloud Communication ( https://www.mysubmail .com )
(2) 등록, 실명 인증 , 제품 및 서비스를 입력하고 새 템플릿을 생성하면 해당 템플릿 구문은 지원 문서에서 볼 수 있습니다
(3) "AppIdD 생성/관리" 열로 이동하여 프로젝트를 생성 및 활성화한 다음 생성합니다. 기본 "APPID" 및 "APPKEY"
(4) 홈페이지로 이동하여 "API 개발 문서 보기" 링크를 클릭하고 POST 요청에 대한 링크를 가져옵니다.
4.
백엔드 로직 개발:
핵심: 인증 코드 생성 -> POST 요청 기능 캡슐화 -> 인증 코드를 제3자 플랫폼으로 전송 -> 그런 다음 제3자가 사용자의 휴대폰으로 전달
마크다운을 지원하지 않습니다. 핵심 코드와 큰 함정이 발생한 장소만 게시합니다.
(1) 타사 플랫폼에 인증 코드 보내기: (함정 없음, 논리가 기록되어 있음) 매우 원활하게 )
private function sendMessage() { $appId = "xxxxx"; $appKey = "36426a9xxxxxxxxxxxx7bed8583a3c"; $code = $this->makeCode(6); $data = [ "appid" => $appId, "to" => $this->phone, "project" => "FoJ494", "vars" => '{"code":' . $code . ',"time":"60"}', "signature" => $appKey, ]; $res = $this->httpRequest($data); var_dump($res); }
(2) 인증 코드 데이터를 타사 플랫폼으로 보내는 링크를 요청합니다. (여기에는 큰 함정이 있습니다 )
-- 좋아요, 정상적으로 적어 두겠습니다.
private function httpRequest($data) { $curl = curl_init(); curl_setopt($curl, CURLOPT_URL, $this->RequestUrl); curl_setopt($curl, CURLOPT_HEADER, 0); curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1); if (isset($data)) { curl_setopt($curl, CURLOPT_POST, 1); curl_setopt($curl, CURLOPT_POSTFIELDS, $data); } $res = curl_exec($curl); var_dump(curl_error($curl)); //打印请求错误 curl_close($curl); return $res; }
그런 다음 신고하세요. 오류: 'SSL 인증서 문제: 로컬 발급자 인증서를 얻을 수 없습니다' 그렇다면 걱정하지 마세요. 공식 채널에 따라 작업을 계속하세요:
--- https://curl.haxx.se/로 이동하세요. cacert.pem
을 다운로드하려면 docs/caextract.html
--- 그런 다음 cacert.pem을 php 디렉토리에 붙여넣은 다음 php.ini로 이동하여 ";curl.cainfo"를 찾아 수정합니다. to:
컬.cainfo = "C:/wamp/bin/php/php7.0.10/ cacert.pem", 알았어, 쓸모 없어 , 계속해서 오류를 보고해!
--- 그런 다음 계속해서 해결책을 찾으세요. , 그리고 온라인 정보에 따라 그 아래의 ";openssl.cafile"을 다음과 같이 변경합니다: openssl.cafile= "C:/wamp/bin/php/php7.0.10/cacert.pem" , 알겠습니다, =_=! 계속해서 오류를 신고하니 벌써 마음이 황폐해졌습니다!
--- 그러다가 큰따옴표 지우고, 작은따옴표 추가하고, 큰따옴표 지우고 하다가 심장이 얼어붙기 시작했어요! 여전히 SSL 인증서 오류입니다! !
--- 내 뒤에는 물이 고인 느낌으로 Google 서핑을 계속했지만 계속해서 해변으로 씻겨 나가고 멍들고 멍들고 배고프고 목마릅니다!
--- 드디어, 드디어, 드디어, 젠장! ! ! 해보았습니다~~
(3) 해결방법 :
컬_exec() 앞에 추가 : (cacert.pem 파일을 현재 디렉토리에 복사, 다른 경로도 가능)
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, true); curl_setopt($curl, CURLOPT_CAINFO, dirname(__FILE__) . '/cacert.pem'); curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, 2);
5 최종 효과. :
관련 권장 사항:
SMS 보물을 사용하여 문자 메시지를 보내는 PHP 방법
jQuery를 사용하여 문자 메시지 보내기에 대한 카운트다운 기능 구현
php는 등록 기능을 완료하기 위해 SMS 인증 코드를 보냅니다
위 내용은 PHP는 문자 메시지 보내기를 구현합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!