PHP에서 Google reCAPTCHA를 사용한 인증
현대 온라인 세계에서 웹사이트 보안과 사용자 개인정보 보호는 점점 더 중요한 주제가 되고 있습니다. 그 중 인간-기계 검증이라는 기술적 방법은 악의적인 공격을 방지하는 데 없어서는 안 될 방법 중 하나가 되었습니다. Google reCAPTCHA는 인간-기계 검증에 널리 사용되는 도구입니다. 그 개념은 사람들의 마음속에 깊이 뿌리박혀 있으며, 우리가 매일 사용하는 많은 웹사이트에서도 그 존재를 볼 수 있습니다. 이 기사에서는 PHP에서 확인을 위해 Google reCAPTCHA를 사용하는 방법을 살펴보겠습니다.
Google reCAPTCHA 작동 방식
Google reCAPTCHA는 원래 Carnegie Mellon University의 연구팀이 개발한 인간 안티 봇 컴퓨터 프로그램으로 나중에 Google에 인수되어 개선되었습니다.
텍스트, 이미지 또는 오디오가 포함된 복잡한 질문을 사용자에게 보여주고 사용자에게 대답을 요구함으로써 로봇이 아닌 인간이 웹사이트를 방문하고 있음을 식별하는 방식으로 작동합니다. 또한 Google reCAPTCHA는 사용자 행동 패턴, 브라우저 지문 등의 요소를 기반으로 방문자를 저위험, 중간 위험, 고위험의 세 가지 수준으로 분류하여 검증의 정확성을 높이고 악의적인 공격을 예방할 수도 있습니다.
PHP에서 확인을 위해 Google reCAPTCHA를 사용하세요
Google reCAPTCHA를 사용하여 확인하기 전에 reCAPTCHA 사이트 키와 비밀 키를 신청해야 합니다. 사이트 키는 사용자 측에서 확인 정보를 표시하는 데 사용되고, 비밀 키는 사용자가 제출한 정보를 백그라운드에서 확인하는 데 사용됩니다. 이 정보는 reCAPTCHA를 사용하기 위해 꼭 필요한 정보이며, 올바르게 보관해야 합니다.
다음으로 PHP에서 Google reCAPTCHA를 사용하여 인증하는 방법에 중점을 두겠습니다. 사용자가 등록하려면 사용자 이름, 비밀번호 및 확인 코드를 입력해야 하는 간단한 등록 양식을 예로 들어 보겠습니다. 구체적인 단계는 다음과 같습니다.
- Google reCAPTCHA의 JavaScript 코드를 HTML에 삽입
<head> <script src="https://www.google.com/recaptcha/api.js" async defer></script> </head> <body> <form> <!--其他表单元素--> <div class="g-recaptcha" data-sitekey="在这里填入你的Site Key"></div> <button type="submit" name="submit">注册</button> </form> </body>
위 코드는 Google reCAPTCHA의 JavaScript 파일을 소개하고 "g-recaptcha" 클래스 및 data-sitekey 속성을 추가합니다. 형식 값은 reCAPTCHA 공식 웹사이트에서 신청한 사이트 키의 div 요소입니다. 이 요소를 양식에 삽입하여 사용자가 "등록" 버튼을 클릭하면 Google reCAPTCHA의 확인 기능이 실행되어 사용자가 사람인지 여부를 판단합니다.
- 인증코드가 맞는지 확인
<?php if(isset($_POST['submit'])){//当用户按下注册按钮 $username = $_POST['username']; $password = $_POST['password']; $captcha = $_POST['g-recaptcha-response']; $url = "https://www.google.com/recaptcha/api/siteverify";//Google reCAPTCHA的工作URL $data = array( 'secret' => '在这里填入你的Secret Key', 'response' => $captcha ); $options = array( 'http' => array( 'header' => "Content-type: application/x-www-form-urlencoded ", 'method' => 'POST', 'content' => http_build_query($data) ) ); $context = stream_context_create($options); $result = file_get_contents($url, false, $context);//向Google服务器发送POST请求 $response = json_decode($result);//解码JSON响应 if($response->success){//如果验证码正确 //将用户信息插入数据库 } else{ echo "验证码出错,请检查输入"; } } ?>
위 코드에서 등록된 PHP 처리 스크립트에서 먼저 사용자가 입력한 사용자 이름, 비밀번호, reCAPTCHA 인증코드(예: $_POST)를 얻어옵니다. ['username']
, $_POST['password']
및 $_POST['g-recaptcha-response']
), 그런 다음 POST를 구성합니다. Google reCAPTCHA URL로 요청하면 요청 데이터에는 우리가 신청한 비밀 키와 사용자가 제출한 인증 코드가 포함됩니다. $_POST['username']
、$_POST['password']
和$_POST['g-recaptcha-response']
),然后构造POST请求到Google reCAPTCHA的URL中,其中请求数据中包含了我们申请到的Secret Key和用户提交的验证码。
接下来,我们使用file_get_contents()
file_get_contents()
함수를 사용하여 Google reCAPTCHA 서버에 POST 요청을 보내고 응답을 디코딩합니다. 응답의 반환 값은 JSON 형식 개체이며, 성공 필드는 사용자의 확인 코드가 올바른지 여부를 나타냅니다. 인증 코드가 정확하면 사용자 정보가 데이터베이스에 삽입되고, 그렇지 않으면 오류 메시지가 출력됩니다. 결론Google reCAPTCHA는 코드에 Google reCAPTCHA를 구현하는 경우 웹사이트에 강력한 확인 메커니즘을 추가하기 위해 몇 줄의 코드만 있으면 웹사이트에 대한 보안을 간단하고 빠르게 제공할 수 있습니다. 🎜위 내용은 PHP에서 Google reCAPTCHA를 사용한 인증의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











PHP 8.4는 상당한 양의 기능 중단 및 제거를 통해 몇 가지 새로운 기능, 보안 개선 및 성능 개선을 제공합니다. 이 가이드에서는 Ubuntu, Debian 또는 해당 파생 제품에서 PHP 8.4를 설치하거나 PHP 8.4로 업그레이드하는 방법을 설명합니다.

VS Code라고도 알려진 Visual Studio Code는 모든 주요 운영 체제에서 사용할 수 있는 무료 소스 코드 편집기 또는 통합 개발 환경(IDE)입니다. 다양한 프로그래밍 언어에 대한 대규모 확장 모음을 통해 VS Code는

숙련된 PHP 개발자라면 이미 그런 일을 해왔다는 느낌을 받을 것입니다. 귀하는 상당한 수의 애플리케이션을 개발하고, 수백만 줄의 코드를 디버깅하고, 여러 스크립트를 수정하여 작업을 수행했습니다.

이 튜토리얼은 PHP를 사용하여 XML 문서를 효율적으로 처리하는 방법을 보여줍니다. XML (Extensible Markup Language)은 인간의 가독성과 기계 구문 분석을 위해 설계된 다목적 텍스트 기반 마크 업 언어입니다. 일반적으로 데이터 저장 AN에 사용됩니다

JWT는 주로 신분증 인증 및 정보 교환을 위해 당사자간에 정보를 안전하게 전송하는 데 사용되는 JSON을 기반으로 한 개방형 표준입니다. 1. JWT는 헤더, 페이로드 및 서명의 세 부분으로 구성됩니다. 2. JWT의 작업 원칙에는 세 가지 단계가 포함됩니다. JWT 생성, JWT 확인 및 Parsing Payload. 3. PHP에서 인증에 JWT를 사용하면 JWT를 생성하고 확인할 수 있으며 사용자 역할 및 권한 정보가 고급 사용에 포함될 수 있습니다. 4. 일반적인 오류에는 서명 검증 실패, 토큰 만료 및 대형 페이로드가 포함됩니다. 디버깅 기술에는 디버깅 도구 및 로깅 사용이 포함됩니다. 5. 성능 최적화 및 모범 사례에는 적절한 시그니처 알고리즘 사용, 타당성 기간 설정 합리적,

문자열은 문자, 숫자 및 기호를 포함하여 일련의 문자입니다. 이 튜토리얼은 다른 방법을 사용하여 PHP의 주어진 문자열의 모음 수를 계산하는 방법을 배웁니다. 영어의 모음은 A, E, I, O, U이며 대문자 또는 소문자 일 수 있습니다. 모음이란 무엇입니까? 모음은 특정 발음을 나타내는 알파벳 문자입니다. 대문자와 소문자를 포함하여 영어에는 5 개의 모음이 있습니다. a, e, i, o, u 예 1 입력 : String = "Tutorialspoint" 출력 : 6 설명하다 문자열의 "Tutorialspoint"의 모음은 u, o, i, a, o, i입니다. 총 6 개의 위안이 있습니다

정적 바인딩 (정적 : :)는 PHP에서 늦은 정적 바인딩 (LSB)을 구현하여 클래스를 정의하는 대신 정적 컨텍스트에서 호출 클래스를 참조 할 수 있습니다. 1) 구문 분석 프로세스는 런타임에 수행됩니다. 2) 상속 관계에서 통화 클래스를 찾아보십시오. 3) 성능 오버 헤드를 가져올 수 있습니다.

PHP의 마법 방법은 무엇입니까? PHP의 마법 방법은 다음과 같습니다. 1. \ _ \ _ Construct, 객체를 초기화하는 데 사용됩니다. 2. \ _ \ _ 파괴, 자원을 정리하는 데 사용됩니다. 3. \ _ \ _ 호출, 존재하지 않는 메소드 호출을 처리하십시오. 4. \ _ \ _ get, 동적 속성 액세스를 구현하십시오. 5. \ _ \ _ Set, 동적 속성 설정을 구현하십시오. 이러한 방법은 특정 상황에서 자동으로 호출되어 코드 유연성과 효율성을 향상시킵니다.
