Skip to content

PlusMagi's Blog By Pitt Phunsanit

Plus emotional magic to the knowledge of logic.

  • About’s Pitt
Close Button

Java: spring-security-web (login )Java: spring-security-web (login )

2025-12-132025-12-13| phunsanitphunsanit| 0 Comment | 07:00

ในการพัฒนาแอปพลิเคชันด้วย Spring Boot และต้องการจัดการเรื่องความปลอดภัย เรามักจะเห็น Library หลัก 3 ตัวนี้ทำงานร่วมกันเสมอครับ แม้ว่าเราจะติดตั้งผ่าน spring-boot-starter-security เพียงตัวเดียว แต่เบื้องหลังมันประกอบด้วยส่วนประกอบที่ทำหน้าที่ต่างกันดังนี้ครับ


spring-security-core

นี่คือ “หัวใจ” ของระบบครับ มันประกอบด้วย API พื้นฐานและคลาสหลักที่ไม่ขึ้นตรงกับระบบ Web ทำให้สามารถนำไปใช้กับแอปพลิเคชันประเภท Desktop หรือ Method-level security ได้

  • หน้าที่หลัก:
    • Authentication: เก็บ Model ของผู้ใช้ เช่น UserDetails, GrantedAuthority
    • Access Control: จัดการการตรวจสอบสิทธิ์ผ่าน AccessDecisionManager
    • Security Context: คลาส SecurityContextHolder ที่ใช้เก็บข้อมูลผู้ใช้ที่ล็อกอินอยู่ในปัจจุบัน
  • เหมาะสำหรับ: การทำ Unit Test หรือเขียน Logic ความปลอดภัยในระดับ Service layer

spring-security-web

ตัวนี้คือส่วนที่ทำให้ Security ทำงานบน HTTP Protocol ได้ครับ หากไม่มีตัวนี้ Spring Security ก็จะไม่รู้ว่าต้องจัดการกับ Request ที่วิ่งเข้ามาทาง Browser อย่างไร

  • หน้าที่หลัก:
    • Filters: หัวใจของมันคือ “Security Filter Chain”
    • Infrastructure: จัดการเรื่องการทำ Redirect, การส่ง Error , และการจัดการ Session /Cookies
    • Firewall: คลาส HttpFirewall ที่ช่วยป้องกันการโจมตีพื้นฐานทาง URL
  • หัวใจสำคัญ: คลาส HttpSecurity ที่เราใช้กำหนดว่า URL ไหนต้องล็อกอิน หรือ URL ไหนให้ผ่านได้เลย จะทำงานอยู่ใน Module นี้ครับ

spring-security-config

ตัวนี้เปรียบเสมือน “กาว” หรือตัวเชื่อมครับ มันช่วยให้เราเขียน Code เพื่อตั้งค่า ได้ง่ายขึ้นผ่าน Syntax ที่อ่านง่าย

  • หน้าที่หลัก:
    • DSL : ช่วยให้เราเขียน http.authorizeHttpRequests (...) .formLogin (...) ได้แบบไหลลื่น
    • Annotation Support: รองรับการใช้ @EnableWebSecurity, @EnableMethodSecurity
    • XML & Java Config: เป็นส่วนที่ประมวลผลการตั้งค่าทั้งหมดเพื่อไปสร้าง Bean ต่าง ๆ ใน Core และ Web
  • ประโยชน์: ช่วยลดความซับซ้อนในการ Setup เพราะมันจะดึงเอาคลาสจาก Core และ Web มาประกอบร่างให้เราโดยอัตโนมัติ

สรุปความสัมพันธ์แบบเปรียบเทียบ

Moduleหน้าที่เปรียบเหมือน
coreนิยามว่า “ใคร” และ “ทำอะไรได้บ้าง”กฎหมายและบัตรประชาชน
webดักจับ HTTP Request และจัดการ Sessionประตูกั้นและรปภ. หน้าตึก
configวิธีการตั้งค่าระบบทั้งหมดเข้าด้วยกันคู่มือการติดตั้งและปุ่มควบคุม

คำแนะนำเพิ่มเติม: ในการใช้งานจริงกับ Spring Boot คุณเพียงแค่ระบุ Dependency spring-boot-starter-security ในไฟล์ pom.xml หรือ build.gradle เพียงที่เดียว มันจะดึงทั้ง 3 ตัวนี้มาให้พร้อมใช้งานทันทีครับ


อ่านเพิ่มเติม

  • Authentication, Authenticator, Authorization, Login
  • ระบบ Login ควรมีอะไรบ้าง
  • login แบบปลอดภัย
Read MoreRead More

Posts pagination

ก่อนหน้า 1 … 54 55 56 … 1,039 ถัดไป

Projects

  • Statement Columns Mapping Helper
  • PlusMagi Site Search
  • jQuery Plus Repeater

Recent Posts

  • Playwright: Environment
  • Vue.js: TabulatorPlus
  • AI MCP: Model Context Protocol
  • React: TabulatorPlus
  • SonarQube: ติดตั้ง

Archives

Categories

  • AI (18)
  • Businesses (6)
  • Design (43)
    • UX/UI (12)
  • DevOps (61)
    • CI/CD (4)
    • Docker (32)
    • GIT (25)
  • Histories (10)
  • Life (89)
    • Books (35)
    • Cartoon (3)
    • Sci-Fi (4)
    • Tips and Tricks (22)
    • พุทธ (5)
  • Network (119)
    • Apache HTTP Server (14)
    • IOT (1)
    • Nginx (28)
    • Stalwart (5)
  • Operating Systems (258)
    • Unix-like (186)
      • Android (15)
        • F-Droid (5)
      • iPhone (8)
      • Linux (112)
      • macOS (99)
        • Homebrew (15)
        • OrbStack (11)
      • Oh My ZSH (4)
      • Shell Script (34)
      • SSH (11)
    • Windows (116)
      • PowerShell (24)
      • WSL (24)
  • Programming (697)
    • .NET (18)
      • .NET Core EF (5)
      • C# (17)
    • API (26)
      • REST (5)
      • Swagger (6)
    • Database (179)
      • DBeaver (3)
      • MariaDB (28)
      • MySql (66)
      • Oracle Database (6)
        • 10g (3)
      • PostgreSQL (8)
      • RDBMS (2)
      • SQL Server (85)
        • SSMS (8)
        • T-SQL (26)
      • SQLite (1)
    • PowerBuilder (10)
    • Python (2)
    • Rust (1)
    • System Analyst (SA) (13)
    • Testing (17)
      • Automated Testing (9)
        • Playwright (6)
    • UML (7)
    • Web (371)
      • Backend (238)
        • Golang (1)
        • Java (45)
          • Spring Boot (14)
        • Node.js (1)
        • PHP (192)
          • Laravel (16)
          • Yii (5)
      • Frontend (127)
        • CSS (17)
          • Tailwind CSS (5)
        • JavaScript (115)
          • Angular (2)
          • jQuery (60)
          • Tabulator (14)
          • Vue.js (5)
      • WordPress (25)
  • Programs (84)
    • Excel (10)
  • Security (52)
  • Uncategorized (1)
  • กฎหมาย (6)

Sirat WordPress Theme By VWThemes

Scroll Up