Categories: 정보처리기사

정보처리기사 기출문제 총정리 ㉖ 시큐어 코딩 – 입력 검증·암호화·보안 취약점 제거

시큐어 코딩이란?

시큐어 코딩(Secure Coding)은 소프트웨어 개발 단계에서 보안 취약점이 발생하지 않도록 보안 원칙을 적용하는 코딩 방법론입니다. 취약점을 나중에 패치하는 것보다 처음부터 안전하게 개발하는 것이 훨씬 비용 효율적입니다.

입력 데이터 검증 원칙

화이트리스트 vs 블랙리스트

  • 화이트리스트(Allowlist): 허용된 값만 통과. 더 안전하고 권장되는 방법
  • 블랙리스트(Denylist): 알려진 악성 값 차단. 우회 가능성 있음

입력 검증 위치

  • 서버 측(Server-side) 검증: 반드시 수행. 클라이언트 검증은 우회 가능
  • 클라이언트 측(Client-side) 검증: UX 향상용 보조 수단

주요 취약점과 방어 코딩

인젝션 방어

  • 준비된 구문(Prepared Statement)/파라미터화 쿼리 사용
  • 저장 프로시저(Stored Procedure) 활용
  • ORM(Object-Relational Mapping) 사용
  • 입력값 특수문자 이스케이프

XSS 방어

  • 출력 시 HTML 인코딩 적용 (< → &lt;)
  • Content-Security-Policy(CSP) 헤더 설정
  • HttpOnly, Secure 쿠키 플래그 설정

인증·세션 관리

  • 세션 ID: 암호학적으로 안전한 난수 생성
  • 로그인 성공 후 세션 ID 재생성 (Session Fixation 방어)
  • 타임아웃: 일정 시간 비활성 시 세션 만료
  • HTTPS에서만 세션 쿠키 전송 (Secure 플래그)

민감 정보 처리

  • 패스워드: 단방향 해시(bcrypt, Argon2) 저장 (단순 MD5/SHA-1 사용 금지)
  • 소금(Salt) 추가: 레인보우 테이블 공격 방어
  • 신용카드 번호: PCI-DSS에 따라 암호화 저장 또는 토큰화
  • 민감 정보 로그 기록 금지 (패스워드, 카드번호, 개인정보)

오류 처리 보안

  • 상세 오류 메시지를 사용자에게 노출하지 않음 (내부 경로, 스택 트레이스 숨김)
  • 오류는 로그에만 기록 (서버 측)
  • 기본 오류 페이지(404, 500) 커스터마이징

국내 시큐어 코딩 기준

  • 행안부 시큐어 코딩 가이드: 공공기관 소프트웨어 개발 시 의무 적용
  • 7대 보안 약점: 입력 데이터 검증·표현, 보안 기능, 시간 및 상태, 에러 처리, 코드 오류, 캡슐화, API 오용

시험 핵심 포인트

  • Prepared Statement: 인젝션 방어의 핵심 기법
  • 화이트리스트: 블랙리스트보다 안전한 입력 검증
  • 서버 측 검증: 반드시 수행 (클라이언트 검증만으로는 불충분)
  • 패스워드 저장: bcrypt/Argon2 + Salt (단방향 해시)
  • HttpOnly 쿠키: JavaScript 접근 차단 (XSS로 쿠키 탈취 방지)

마무리

시큐어 코딩은 보안의 시작점입니다. 인젝션 방어(Prepared Statement), XSS 방어(출력 인코딩), 패스워드 안전 저장은 가장 중요한 세 가지 원칙입니다.

zerg96

Recent Posts

네트워크관리사 기출 핵심 [55] 클라우드 네트워크 보안과 VPC 설계 완전 정복

클라우드 VPC 보안이란? Virtual Private Cloud(VPC)는 퍼블릭 클라우드 내 격리된 가상 네트워크 환경입니다. 네트워크관리사 시험에서는…

15시간 ago

네트워크관리사 기출 핵심 [54] 네트워크 성능 측정과 벤치마킹 완전 정복

네트워크 성능 측정이란? 네트워크 성능 측정은 SLA 준수 확인, 병목 구간 발견, 용량 계획의 기반입니다.…

15시간 ago

네트워크관리사 기출 핵심 [53] 네트워크 가상화 심화와 오버레이 네트워크 완전 정복

네트워크 가상화와 오버레이 네트워크란? 오버레이 네트워크는 물리 네트워크 위에 논리적 네트워크를 구성해 가상 머신·컨테이너 간…

15시간 ago

네트워크관리사 기출 핵심 [52] 인터넷 교환 지점과 CDN 아키텍처 완전 정복

인터넷 교환 지점(IXP)이란? 인터넷 교환 지점(IXP)은 서로 다른 네트워크(AS)가 트래픽을 교환하는 물리적 인프라입니다. 네트워크관리사 시험에서는…

15시간 ago

네트워크관리사 기출 핵심 [51] 네트워크 슬라이싱과 5G 코어 아키텍처 완전 정복

5G 코어와 네트워크 슬라이싱이란? 5G 코어 네트워크는 클라우드 네이티브 아키텍처로 완전히 재설계되었습니다. 네트워크관리사 시험에서는 5G…

15시간 ago

정보처리기사 기출 핵심 [55] 플랫폼 엔지니어링과 IDP 구축 완전 정복

플랫폼 엔지니어링이란? 플랫폼 엔지니어링은 개발팀에게 셀프 서비스 인프라와 도구를 제공하는 규율입니다. 내부 개발자 플랫폼(IDP)을 통해…

15시간 ago