[웹 보안] 보안이란 무엇인가? [웹 보안의 구성, 보안에 대한 기본적인 오해]

2024. 2. 24. 16:58·◈ Study/웹 보안(Web Security)🔐
728x90


- 보안이란 무엇인가?

1. 정보 보안의 3가지 요소

1) 무결성 : 권한을 가진 사람만 정해진 방법으로 정보를 변경할 수 있어야 한다.

나의 개인정보를 변경할 수 있는 사람은 일반적으로 나 자신뿐이다. 모르는 사람이 갑자기 나의 이름(id)과 비밀번호를 바꿀 경우 무결성이 침해된 것이다. 민감한 정보뿐만 아니라, 모두에게 공개되는 나의 닉네임을 누군가 함부로 바꾸는 경우 등에도 무결성이 침해된 것이다.

 

2) 기밀성 : 권한을 가진 사람만 정보에 접근할 수 있어야 한다.

나의 금고를 열 수 있는 건 나 자신뿐이다. 원하지 않는 사람이 내 금고 안에 있는 내용(개인정보, 비밀번호 등)을 보는 것은 기밀성이 침해된 것이다. 위에서 나온 경우처럼 모르는 사람이 나의 개인정보를 함부로 변경할 때, 개인정보를 보면서 변경하였다면 기밀성까지 같이 침해된 것으로 볼 수 있다.

 

3) 가용성 : 원할 때 정보에 대한 접근이 가능해야 한다. (권한이 있을 때)

필요한 상황에서 나의 금고는 나에 의해 언제나 열릴 수 있어야 한다. 내가 나의 금고를 열려고 하는데, 안 열리는 경우에는 가용성이 침해된 것이다. 일상생활에서 편의점처럼 24시간 언제든 접근 가능한 곳 등은 가용성이 매우 크다고 볼 수 있다. 편의점에 사람이 너무 많아 못 들어가는 경우에는 일상생활에서의 가용성이 침해된 것이다.

2. 웹 보안의 구성

1. 방화벽

이상한 네트워크 패킷을 원천적으로 차단해주는 역할을 한다. 일반적인 웹 서비스라면 tcp 80번, tcp 443번을 제외하면 공개해야할 포트가 많이 없다. 이러한 방화벽은 웹 서비스 자체에 대한 공격은 막지 못한다.

 

2. 시큐어 코딩

취약점이 될 수 있는 논리적 오류 등을 개발 단계에서 개발자가 신경쓰는 개발기법이다. 프로그래밍을 할 때 보안에 신경써서 제작하는 게 중요하다.

 

3. 데이터 보안

DB에 저장되어 있는 데이터에 대한 보안에도 신경써야 한다. 특히 DB 서버와 애플리케이션 서버가 분리되어 있는 경우에는 더 관심을 가지고 관리해야 한다.

 

4. 로그 관리

웹 서버의 로그가 잘 기록되도록 해야 한다. 로그를 분석하면서 공격이 이루어진 정황을 찾아낼 수 있다.

 

5. 접근 관리

웹 서버에 접근하는 것에 대한 관리도 필요하다. root나 administrator 계정이 유출되지 않도록 주의하며, 이를 위해서 안전한 운영체제를 사용하고, 악성코드 같은 것들을 주의해야 한다.

3. 보안에 대한 기본적인 오해

  • 규모(회사 규모나 개발 규모)가 작은 웹 서비스에도 공격이 행해진다. 하물며 바이러스 같은 건 일반 컴퓨터 사용자에게까지 크게 전파되며, 불특정 다수에게 공개되는 웹 서비스는 당연히 공격을 받는다.
  • FrontEnd에도 보안 공격이 일어난다. 개인적으로 FrontEnd, BackEnd 중 보안에 더 신경써야 하는 분야를 고르라고 하면 못 고를 것이다. 어느 개발 분야이든 보안은 다 중요하다.
  • 많은 사람이 사용한다는 게 안전하다는 보장은 아니다.
  • 웹 서비스에 공격을 하는 사람은 정말 상상도 못한 방법을 동원할 때도 있다. (운영자 납치 등)
  • 내부자에 의한 보안 사고가 꽤 발생한다. 고의적으로 사고를 일으켰던, 단지 개발과정에서 스파게티 코드로 인한 의도하지 않은 정보 유출 등. 특히 의도하지 않은 정보 유출은 당장은 눈에 보이는 피해가 없더라도 나중에 공격을 받았을 때 피해를 크게 증폭시키게 된다.
  • 프로그래밍을 못하는 해커도 존재한다. 자동화 툴이 많이 발달되어 있다.

- 참고자료

 

[지금 무료] 웹 개발자라면 꼭 알아야 할 보안 기초 강의 - 인프런

정보 보안은 어렵고, 너무 전문적인 내용이라고요? 아니요. 지금 당장 안전한 웹을 만들어 갈 수 있는 정보 보안 기초를 시작해 보세요!, 배워서 바로 써먹는정보 보안 기초 🖥️ 웹 개발자 필수

www.inflearn.com


728x90
'◈ Study/웹 보안(Web Security)🔐' 카테고리의 다른 글
  • [웹 보안] 세션 만료 시간 설정하기 [로그인 만료 기준(30분) 시간 초과]
  • [웹 보안] 분산 서비스 거부 공격 DDoS(Distributed Denial of Service) [DDoS 정의, 공격 방법, 방어 방법]
  • [웹 보안] 서비스 거부 공격 DoS(Denial-of-Service) [SYN Flooding, Ping of Death, 스머프 공격]
  • [웹 보안] 포트는 왜 중요할까? [포트와 보안의 상관 관계]
예르미(yermi)
예르미(yermi)
끊임없이 제 자신을 계발하는 개발자입니다👨🏻‍💻
  • 예르미(yermi)
    예르미의 코딩노트
    예르미(yermi)
  • 전체
    오늘
    어제
    • 분류 전체보기 (937)
      • ◎ Java (133)
        • Java☕ (93)
        • JSP📋 (26)
        • Applet🧳 (6)
        • Interview👨🏻‍🏫 (8)
      • ◎ JavaScript (48)
        • JavaScript🦎 (25)
        • jQuery🌊 (8)
        • React🌐 (2)
        • Vue.js🔰 (6)
        • Node.js🫒 (3)
        • Google App Script🐑 (4)
      • ◎ HTML5+CSS3 (17)
        • HTML5📝 (8)
        • CSS3🎨 (9)
      • ──────────── (0)
      • ▣ Framework (67)
        • Spring🍃 (36)
        • Spring Boot🍀 (12)
        • Bootstrap💜 (3)
        • Selenium🌕 (6)
        • MyBatis🐣 (10)
      • ▣ Tools (47)
        • API🎯 (18)
        • Library🎲 (15)
        • JitPack🚀 (3)
        • Jenkins👨🏻 (7)
        • Thymeleaf🌿 (4)
      • ▣ Server (32)
        • Apache Tomcat🐱 (14)
        • Apache HTTP Server🛡️ (1)
        • Nginx🧶 (7)
        • OracleXE💿 (4)
        • VisualSVN📡 (4)
      • ▣ OS : 운영체제 (18)
        • cmd : 명령프롬프트💻 (10)
        • Linux🐧 (8)
      • ▣ SQL : Database (56)
        • Oracle SQL🏮 (26)
        • PL SQL💾 (9)
        • MySQL🐬 (6)
        • MariaDB🦦 (6)
        • H2 Database🔠 (3)
        • SQL 실전문제🐌 (6)
      • ────────── (0)
      • ◈ Human Project (86)
        • Mini : Library Service📚 (15)
        • 화면 설계 [HTML]🐯 (10)
        • 서버 프로그램 구현🦁 (15)
        • Team : 여수어때🛫 (19)
        • Custom : Student🏫 (9)
        • Custom : Board📖 (18)
      • ◈ Yermi Project (40)
        • 조사모아(Josa-moa)📬 (5)
        • Riddle-Game🧩 (6)
        • 맛있을 지도🍚 (2)
        • 어디 가! 박대리!🙋🏻‍♂️ (5)
        • 조크베어🐻‍❄️ (4)
        • Looks Like Thirty🦉 (2)
        • Toy Project💎 (12)
        • 오픈소스 파헤치기🪐 (4)
      • ◈ Refactoring (15)
        • Mini : Library Service📚 (8)
        • 서버 프로그램 구현🦁 (1)
        • Team : 여수어때🛫 (0)
        • 쿼리 튜닝일지🔧 (6)
      • ◈ Coding Test (89)
        • 백준(BOJ)👨🏻‍💻 (70)
        • 프로그래머스😎 (2)
        • 코드트리🌳 (7)
        • 알고리즘(Algorithm)🎡 (10)
      • ◈ Study (102)
        • 기초튼튼 개발지식🥔 (25)
        • HTTP 웹 지식💡 (4)
        • 클린코드(Clean Code)🩺 (1)
        • 디자인패턴(GoF)🥞 (12)
        • 다이어그램(Diagram)📈 (4)
        • 파이썬(Python)🐍 (16)
        • 에러노트(Error Note)🧱 (34)
        • 웹 보안(Web Security)🔐 (6)
      • ◈ 공부모임 (39)
        • 혼공학습단⏰ (18)
        • 코드트리 챌린지👊🏻 (2)
        • 개발도서 100독👟 (8)
        • 나는 리뷰어다🌾 (11)
      • ◈ 자격증 공부 (37)
        • 정보처리기사🔱 (16)
        • 정보처리산업기사🔅 (9)
        • 컴퓨터활용능력 1급📼 (12)
      • ─────────── (0)
      • ◐ 기타 (113)
        • 알아두면 좋은 팁(tip)✨ (46)
        • 개발자의 일상🎈 (44)
        • 개발도서 서평🔍 (10)
        • 개발관련 세미나🎤 (2)
        • 블로그 꾸미기🎀 (9)
        • 사도신경 프로젝트🎚️ (2)
  • 인기 글

  • 최근 댓글

  • 태그

    Project
    Oracle
    자바스크립트
    javascript
    꿀팁
    jsp
    코딩
    html
    Database
    CSS
    코딩 테스트
    Error Note
    프로그래밍
    BOJ
    백준
    Java
    백준 티어
    SQL
    일상
    spring
  • 250x250
  • hELLO· Designed By정상우.v4.10.3
예르미(yermi)
[웹 보안] 보안이란 무엇인가? [웹 보안의 구성, 보안에 대한 기본적인 오해]
상단으로

티스토리툴바