찾다
백엔드 개발PHP 튜토리얼PHP의 코드이그나이터 보안 예방 조치에 대한 자세한 그래픽 설명

이 글은 주로 PHP 코드이그나이터의 보안 주의 사항을 소개합니다. 관심 있는 친구들이 참고하시면 도움이 될 것입니다.

1. httponly

session은 httponly여야 합니다. 그렇지 않으면 js를 사용하여 쿠키의 session_id를 얻을 수 있습니다.

프레임워크의 ci_session, 더 긴 비트 수, httponly를 사용해야 하며 모두 기본적으로 구성되어 있습니다.

기본 phpsession을 사용하지 말고 ci_session을 사용하세요. ci_session 숫자가 더 깁니다.

네이티브 세션을 사용하려면 다음과 같이 설정해야 합니다(php.ini):

session.sid_length //Sid 길이를 여기서 늘려야 합니다. 기본값은 너무 짧습니다

session.cookie_httponly = 1 기본 세션은 httponly가 됩니다.

2.phpinfo

반드시 phpinfo 페이지를 닫아주세요. 덤프 요청 정보가 공격자에게 사용될 수 있습니다. 쿠키 정보 등.

3. cdn을 통해 전체 사이트를 강제로 https

점프하게 하고, 로컬 개발 환경도 https를 갖추고 있어야 합니다. 메시지 푸시 등 일부 측면에서 https를 사용할 수 없는 경우 새 사이트를 만들 수 있습니다.

4.엄격 모드

session.use_strict_mode = 1

사용자 클라이언트에서 생성된 세션 ID가 아닌 서버 자체에서 생성된 세션 ID만 사용하세요.

5. CSRF 크로스 사이트 요청 위조

A의 쿠키에는 example.com 사이트의 세션 ID가 포함되어 있으며 B는 A가 이 사진을 클릭하도록 유인하기 위해 포럼에 사진을 게시합니다. 이 그림 A의 요청이 시작됩니다. A의 브라우저는 이를 사실로 믿고 B의 코드에 의해 B에게 전송됩니다. B는 이를 사용합니다. 쿠키는 example.com에서 A의 계정에 로그인합니다.

CI에는 CSRF 방지 메커니즘이 있습니다. 즉, 숨겨진 CSRF 필드를 양식에 자동으로 삽입합니다. 다음 설정을 지정해야 합니다.

application/config/config.php:

$config['csrf_protection'] = TRUE;


이 기능을 켜면 아웃바운드 사이트에 대한 모든 요청이 차단됩니다. 당사 웹사이트가 API 호출과 같이 다른 웹사이트에서 데이터를 얻는 동작을 하는 경우 이 스위치를 활성화할 수 없습니다.

6.

7. 재생

사용자 이름과 비밀번호를 암호화하여 로그인 확인을 위해 서버로 보냅니다. 공격자는 사용자 이름과 비밀번호를 해독할 필요가 없으며 가로채는 데이터 패킷만 다시 암호화하면 됩니다. . 한 번의 작업 후에 로그인이 가능합니다. 이것이 재생입니다.

방어 조치 5 및 6: 각 양식에는 한 번만 사용할 수 있는 숨겨진 무작위 코드 토큰이 포함되어 있습니다.

일회성 토큰 구현만 사용: redis는 만료 및 무효화 후 바로 삭제됩니다.

8. 요약: 사용자 안전한 로그인 프로세스

기본 세션 전략: (1) 세션은 세션 세션으로만 사용되며 브라우저를 닫으면 무효화됩니다.

(2) 세션의 유효 기간이 짧을수록 60초와 같이 더 안전합니다. (3) 세션의 새로 고침 시간은 30초와 같이 적절하게 수정되어야 합니다. (4) 세션을 저장하도록 redis를 설정합니다.

구성은 다음과 같습니다.

php.ini에서:

$this->input->post('a',true);

기본값은 1440초로 24분입니다. 예를 들어 60초로 설정합니다. 60초 후에 클라이언트의 SID가 서버의 SID와 일치하면 유효하지 않습니다. SID를 업데이트하려면 60초 전에 페이지를 새로 고쳐야 합니다. 업데이트 방법은 application/config/에 설명되어 있습니다. config.php:

session.gc_maxlifetime = 60

세션 ID 새로 고침 및 세션 만료 시간 구분:


참고:

이 설정은 보안과 밀접한 관련이 있으므로 구별하여 사용해야 합니다.

위의

session.gc_maxlifetime

은 무엇을 의미하나요? 즉, 세션이 생성된 시점부터 만료되어 사용할 수 없는 시점까지의 시간입니다. 실제로 redis를 사용하면 이 값은 sid를 저장하기 위해 redis를 사용할 때 설정되는 기간이므로 매우 명확합니다. 도달하면 이 키-값이 삭제됩니다.

그래서 이번 sess_time_to_update는 이름에서 알 수 있듯이 새로 고침 시간입니다. 이 시간이 지나면 새로 고쳐진다는 의미입니다. 자동으로 새로고침되는 것이 아니라, 세션 접속 시 새로고침됩니다! 세션을 사용할 때 마지막 세션과 이번 시간 사이의 간격이 결정됩니다. 간격이 이 값보다 크면 sid가 새로 고쳐집니다. 이 사용법의 일반적인 성능은 페이지를 새로 고칠 때 인증을 위해 세션을 읽어야 한다는 것입니다. 그런 다음 페이지를 새로 고칠 때 두 번 사이의 간격이 이 시간을 초과합니다. 즉, sid를 새로 고치는 것입니다. 위에서는 새로 고침이 완료되었음을 의미하며 이후 세션이 갱신되고 타이머가 다시 시작되면서 새 세션이 작성됩니다.

즉, 페이지를 수시로 새로 고치면 필요할 때 새로 고침 메커니즘이 실행되고 정기적으로 발생하면 세션이 만료되지 않습니다. 두 번의 새로 고침 사이의 시간 간격이 maxlifetime을 초과하면 로그인 시간 초과가 표시되고 세션이 종료됩니다. 왜냐하면 만료 후에 업데이트를 시도하면 분명히 작동하지 않고 업데이트가 실패하기 때문입니다.

요약하자면 이 maxlifetime은 두 번의 새로 고침 사이에서 초과할 수 없는 기간을 결정한다는 것입니다. 그렇지 않으면 로그인 시간이 초과되고 업데이트는 maxlifetime보다 작아야 합니다. 왜냐하면 이보다 크면 유효하지 않기 때문입니다. 새로 고침이 만료되었습니다. 그리고 가급적이면 이번 업데이트는 maxlifetime의 절반 미만이어야 한다고 생각합니다. maxlifetime이 매우 긴 경우(사용자 경험을 개선하기 위해 사용자가 항상 로그인하고 시간 초과하는 것은 항상 좋지 않음) 업데이트가 더 짧게 설정되어 있는지 여부는 중요하지 않습니다. 세션이 도난당했다고 가정하면 더 짧아질 위험이 커집니다. 도둑이 세션을 사용할 때 만료되었을 가능성이 있으므로 보안이 더 높아질 것입니다.

one-times-tokens:

One-time tokens

위 내용은 이 글의 전체 내용입니다. 모두의 학습에 도움이 되기를 바랍니다.


관련 권장 사항:

PHP우회 비활성화 기능을 통해 시스템 명령을 실행하는 방법

PHP에서 "{}" 중괄호 사용 요약

PHP

위 내용은 PHP의 코드이그나이터 보안 예방 조치에 대한 자세한 그래픽 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
PHP 세션에 어떤 데이터를 저장할 수 있습니까?PHP 세션에 어떤 데이터를 저장할 수 있습니까?May 02, 2025 am 12:17 AM

phpsessionscanstorestrings, 숫자, 배열 및 객체 1.Strings : TextDatalikeUsernames.2.numbers : integorfloatsforcounters.3.arrays : listslikeshoppingcarts.4.objects : complexStructuresThatareserialized.

PHP 세션을 어떻게 시작합니까?PHP 세션을 어떻게 시작합니까?May 02, 2025 am 12:16 AM

tostartAphPessession, us

세션 재생이란 무엇이며 보안을 어떻게 개선합니까?세션 재생이란 무엇이며 보안을 어떻게 개선합니까?May 02, 2025 am 12:15 AM

세션 재생은 세션 고정 공격의 경우 사용자가 민감한 작업을 수행 할 때 새 세션 ID를 생성하고 이전 ID를 무효화하는 것을 말합니다. 구현 단계에는 다음이 포함됩니다. 1. 민감한 작업 감지, 2. 새 세션 ID 생성, 3. 오래된 세션 ID 파괴, 4. 사용자 측 세션 정보 업데이트.

PHP 세션을 사용할 때 몇 가지 성능 고려 사항은 무엇입니까?PHP 세션을 사용할 때 몇 가지 성능 고려 사항은 무엇입니까?May 02, 2025 am 12:11 AM

PHP 세션은 응용 프로그램 성능에 큰 영향을 미칩니다. 최적화 방법은 다음과 같습니다. 1. 데이터베이스를 사용하여 세션 데이터를 저장하여 응답 속도를 향상시킵니다. 2. 세션 데이터 사용을 줄이고 필요한 정보 만 저장하십시오. 3. 비 차단 세션 프로세서를 사용하여 동시성 기능을 향상시킵니다. 4. 사용자 경험과 서버 부담의 균형을 맞추기 위해 세션 만료 시간을 조정하십시오. 5. 영구 세션을 사용하여 데이터 읽기 및 쓰기 시간의 수를 줄입니다.

PHP 세션은 쿠키와 어떻게 다릅니 까?PHP 세션은 쿠키와 어떻게 다릅니 까?May 02, 2025 am 12:03 AM

phpsessionsareser-side, whilecookiesareclient-side.1) sessions stessoredataontheserver, andhandlargerdata.2) cookiesstoredataonthecure, andlimitedinsize.usesessionsforsensitivestataondcookiesfornon-sensistive, client-sensation.

PHP는 사용자 세션을 어떻게 식별합니까?PHP는 사용자 세션을 어떻게 식별합니까?May 01, 2025 am 12:23 AM

phpidifiesauser의 sssessionusessessioncookiesandssessionids.1) whensession_start () iscalled, phpgeneratesauniquessessionStoredInacookienamedPhpsSessIdonSeuser 'sbrowser.2) thisidallowsphptoretrievessessionDataTromServer.

PHP 세션을 확보하기위한 모범 사례는 무엇입니까?PHP 세션을 확보하기위한 모범 사례는 무엇입니까?May 01, 2025 am 12:22 AM

PHP 세션의 보안은 다음 측정을 통해 달성 할 수 있습니다. 1. Session_REGENEREAT_ID ()를 사용하여 사용자가 로그인하거나 중요한 작업 일 때 세션 ID를 재생합니다. 2. HTTPS 프로토콜을 통해 전송 세션 ID를 암호화합니다. 3. 세션 _save_path ()를 사용하여 세션 데이터를 저장하고 권한을 올바르게 설정할 보안 디렉토리를 지정하십시오.

PHP 세션 파일은 기본적으로 어디에 저장됩니까?PHP 세션 파일은 기본적으로 어디에 저장됩니까?May 01, 2025 am 12:15 AM

phpsessionfilesarestoredInTheRectorySpecifiedBysession.save_path, 일반적으로/tmponunix-likesystemsorc : \ windows \ temponwindows.tocustomizethis : 1) austession_save_path () toSetacustomDirectory, verlyTeCustory-swritation;

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 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.