찾다
백엔드 개발PHP 튜토리얼PHP는 보안 프로그래밍을 구현합니다: CSRF 공격 및 방어

인터넷 애플리케이션에서 보안 문제는 항상 중요한 문제였습니다. 그 중 CSRF(Cross-Site Request Forgery) 공격은 일반적인 취약점으로 공격자가 쉽게 악용할 수 있습니다. 그렇다면 PHP 개발에서 보안 프로그래밍을 구현하는 방법은 무엇입니까? 이 기사에서는 CSRF 공격 및 방어 솔루션에 중점을 둘 것입니다.

1. CSRF 공격이란?

CSRF 공격, 크로스 사이트 요청 위조는 피해자의 로그인 상태를 이용하여 피해자가 모르는 사이에 대상 웹 사이트에 악성 요청을 보내는 공격 방법입니다. 공격자는 다양한 방법을 통해 피해자의 로그인 상태를 알아낸 뒤, 눈치채지 못한 채 대상 웹사이트에 위조된 요청을 보내 공격을 감행할 수 있다. 공격자는 이메일이나 채팅 소프트웨어에 포함된 링크를 통해 피해자에게 제3자 웹사이트 방문을 허용하거나, 소셜 네트워크에 링크를 게시하는 방식으로 피해자의 작업을 유도함으로써 공격을 촉발할 수 있다.

다음 예에서 공격자는 피해자가 악성 웹사이트를 방문하도록 하고 POST 요청을 생성한 후 이를 대상 웹사이트의 요청으로 위장하고 피해자가 로그인하면 허가를 얻습니다. a comment:

<form action="https://www.targetwebsite.com/comment" method="post">
<input type="hidden" name="comment" value="harmful comment" />
<input type="submit" value="Submit Comment" />
</form>
<script>
document.forms[0].submit();
</script>

이 공격 방법은 공격자가 대상 웹 사이트를 직접 공격하지 않고 대상 웹 사이트의 취약점을 이용하여 공격을 수행하기 때문에 매우 은밀합니다. 피해자가 인지하지 못하기 때문에 공격을 탐지하기가 어렵습니다. 대상 웹사이트가 CSRF 공격을 방어하지 못할 경우 데이터 유출, 악의적인 운영 등의 위험이 발생할 수 있습니다.

2. CSRF를 방어하는 방법은 무엇입니까?

CSRF 공격은 매우 위험하므로 어떻게 방어해야 할까요? 다음은 몇 가지 일반적인 방어 전략입니다.

1. 토큰 확인 추가

사용자가 로그인하면 백엔드 서버는 토큰을 생성하여 프런트 엔드에 다시 전달하고 이후 상호 작용에서 토큰을 서버에 저장합니다. 서버, 프런트 엔드는 요청과 함께 토큰을 서버로 가져와야 합니다. 서버는 토큰 확인을 통해 요청이 합법적인지 여부를 판단할 수 있습니다.

다음은 간단한 코드 예시입니다:

<!-- 后端代码 -->
<?php
session_start();
if(!isset($_SESSION['token'])){
$_SESSION['token'] = md5(uniqid(rand(), true));
}
$token = $_SESSION['token'];
?>

<!-- 前端代码 -->
<form method="post" action="/some/url">
<?php echo "<input type='hidden' name='token' value='".$token."' />"; ?>
<input type="text" name="username" />
<input type="text" name="password" />
<input type="submit" value="Submit" />
</form>

이 예시에서는 백그라운드에서 임의의 토큰을 생성하여 프런트엔드에 다시 전달합니다. 다음으로 토큰은 숨겨진 입력 태그에 추가됩니다. 프런트 엔드가 요청을 제출하면 토큰도 제출되며, 서버의 코드는 제출된 토큰을 기반으로 요청이 합법적인지 여부를 확인합니다.

2. 추천인 추가 확인

Referer는 사용자가 현재 페이지로 리디렉션한 페이지가 포함된 HTTP 헤더의 일부입니다. HTTP 헤더의 Referer를 확인함으로써 서버는 요청이 합법적인 페이지에서 오는지 여부를 확인할 수 있습니다. 리퍼러가 잘못된 것으로 감지되면 서버는 요청에 대한 응답을 거부합니다.

다음은 간단한 코드 예입니다.

<?php
$referer = $_SERVER['HTTP_REFERER'];
if(parse_url($referer, PHP_URL_HOST) != 'www.validwebsite.com') {
die("Invalid Referer");
}
// 处理正常的请求
?>

이 예에서는 HTTP 헤더에서 Referer를 가져오고 요청이 "www.validwebsite.com"이라는 웹사이트에서 오는지 확인합니다. 요청이 이 웹사이트에서 오지 않은 경우 서버는 응답을 거부하고 "잘못된 추천자" 메시지를 표시합니다.

3. 브라우저 쿠키 추가

쿠키 기반 CSRF 공격은 사용자의 로그인 상태를 이용하여 사용자의 쿠키를 공격자의 웹사이트로 보내는 공격 방법입니다. 민감한 페이지에 대해 단기 쿠키를 설정한 다음 해당 페이지와 관련된 작업을 수행할 때 쿠키의 존재를 확인함으로써 이를 수행할 수 있습니다.

다음은 간단한 코드 예입니다.

header('Set-Cookie: csrf_cookie=' . uniqid(rand(), true) . '; path=/; HttpOnly');

이 예에서는 임의의 csrf_cookie를 생성하고 이를 HttpOnly로 설정합니다. 이는 쿠키가 HTTP 프로토콜을 통해서만 전송될 수 있고 JavaScript를 통해서는 액세스할 수 없음을 의미합니다. 요청이 서버에 도달하면 해당 쿠키가 해당 페이지와 일치하는지 확인하여 가능한 공격을 식별할 수 있습니다.

요약

CSRF 공격은 매우 위험한 공격 방법입니다. CSRF 공격으로부터 방어하는 것은 데이터 보안을 보호하는 데 도움이 될 뿐만 아니라 보안 프로그래밍을 구현하기 위한 기본 요구 사항이기도 합니다. PHP 개발 환경에서는 토큰 확인 설정, 참조자 확인, 브라우저 쿠키 추가 등과 같은 CSRF 공격을 방지하기 위한 몇 가지 조치를 취할 수 있습니다. 이러한 조치를 통해 우리는 민감한 데이터가 포함된 사용자 로그인 상태 및 페이지를 공격으로부터 효과적으로 보호할 수 있습니다.

위 내용은 PHP는 보안 프로그래밍을 구현합니다: CSRF 공격 및 방어의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

PHP와 Python은 각각 고유 한 장점이 있으며 선택은 프로젝트 요구 사항을 기반으로해야합니다. 1.PHP는 간단한 구문과 높은 실행 효율로 웹 개발에 적합합니다. 2. Python은 간결한 구문 및 풍부한 라이브러리를 갖춘 데이터 과학 및 기계 학습에 적합합니다.

PHP : 죽어 가거나 단순히 적응하고 있습니까?PHP : 죽어 가거나 단순히 적응하고 있습니까?Apr 11, 2025 am 12:13 AM

PHP는 죽지 않고 끊임없이 적응하고 진화합니다. 1) PHP는 1994 년부터 새로운 기술 트렌드에 적응하기 위해 여러 버전 반복을 겪었습니다. 2) 현재 전자 상거래, 컨텐츠 관리 시스템 및 기타 분야에서 널리 사용됩니다. 3) PHP8은 성능과 현대화를 개선하기 위해 JIT 컴파일러 및 기타 기능을 소개합니다. 4) Opcache를 사용하고 PSR-12 표준을 따라 성능 및 코드 품질을 최적화하십시오.

PHP의 미래 : 적응 및 혁신PHP의 미래 : 적응 및 혁신Apr 11, 2025 am 12:01 AM

PHP의 미래는 새로운 기술 트렌드에 적응하고 혁신적인 기능을 도입함으로써 달성 될 것입니다. 1) 클라우드 컴퓨팅, 컨테이너화 및 마이크로 서비스 아키텍처에 적응, Docker 및 Kubernetes 지원; 2) 성능 및 데이터 처리 효율을 향상시키기 위해 JIT 컴파일러 및 열거 유형을 도입합니다. 3) 지속적으로 성능을 최적화하고 모범 사례를 홍보합니다.

PHP의 초록 클래스 또는 인터페이스에 대한 특성과 언제 특성을 사용 하시겠습니까?PHP의 초록 클래스 또는 인터페이스에 대한 특성과 언제 특성을 사용 하시겠습니까?Apr 10, 2025 am 09:39 AM

PHP에서, 특성은 방법 재사용이 필요하지만 상속에 적합하지 않은 상황에 적합합니다. 1) 특성은 클래스에서 다중 상속의 복잡성을 피할 수 있도록 수많은 방법을 허용합니다. 2) 특성을 사용할 때는 대안과 키워드를 통해 해결할 수있는 방법 충돌에주의를 기울여야합니다. 3) 성능을 최적화하고 코드 유지 보수성을 향상시키기 위해 특성을 과도하게 사용해야하며 단일 책임을 유지해야합니다.

DIC (Dependency Injection Container) 란 무엇이며 PHP에서 사용하는 이유는 무엇입니까?DIC (Dependency Injection Container) 란 무엇이며 PHP에서 사용하는 이유는 무엇입니까?Apr 10, 2025 am 09:38 AM

의존성 주입 컨테이너 (DIC)는 PHP 프로젝트에 사용하기위한 객체 종속성을 관리하고 제공하는 도구입니다. DIC의 주요 이점에는 다음이 포함됩니다. 1. 디커플링, 구성 요소 독립적 인 코드는 유지 관리 및 테스트가 쉽습니다. 2. 유연성, 의존성을 교체 또는 수정하기 쉽습니다. 3. 테스트 가능성, 단위 테스트를 위해 모의 객체를 주입하기에 편리합니다.

SPL SplfixedArray 및 일반 PHP 어레이에 비해 성능 특성을 설명하십시오.SPL SplfixedArray 및 일반 PHP 어레이에 비해 성능 특성을 설명하십시오.Apr 10, 2025 am 09:37 AM

SplfixedArray는 PHP의 고정 크기 배열로, 고성능 및 메모리 사용이 필요한 시나리오에 적합합니다. 1) 동적 조정으로 인한 오버 헤드를 피하기 위해 생성 할 때 크기를 지정해야합니다. 2) C 언어 배열을 기반으로 메모리 및 빠른 액세스 속도를 직접 작동합니다. 3) 대규모 데이터 처리 및 메모리에 민감한 환경에 적합하지만 크기가 고정되어 있으므로주의해서 사용해야합니다.

PHP는 파일 업로드를 어떻게 단단히 처리합니까?PHP는 파일 업로드를 어떻게 단단히 처리합니까?Apr 10, 2025 am 09:37 AM

PHP는 $ \ _ 파일 변수를 통해 파일 업로드를 처리합니다. 보안을 보장하는 방법에는 다음이 포함됩니다. 1. 오류 확인 확인, 2. 파일 유형 및 크기 확인, 3 파일 덮어 쓰기 방지, 4. 파일을 영구 저장소 위치로 이동하십시오.

Null Coalescing 연산자 (??) 및 Null Coalescing 할당 연산자 (?? =)은 무엇입니까?Null Coalescing 연산자 (??) 및 Null Coalescing 할당 연산자 (?? =)은 무엇입니까?Apr 10, 2025 am 09:33 AM

JavaScript에서는 NullCoalescingOperator (??) 및 NullCoalescingAssignmentOperator (?? =)를 사용할 수 있습니다. 1. 2. ??= 변수를 오른쪽 피연산자의 값에 할당하지만 변수가 무효 또는 정의되지 않은 경우에만. 이 연산자는 코드 로직을 단순화하고 가독성과 성능을 향상시킵니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

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

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.