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 … 47 48 49 … 980 ถัดไป

Projects

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

Recent Posts

  • AI:thClaws
  • Laravel: php artisan tinker
  • Line: API มันทำอะไรได้บ้าง
  • Laravel: reset password
  • AWS S3 คืออะไร ? คู่มือครบจบสำหรับผู้เริ่มต้น

Archives

Categories

  • AI (10)
  • Businesses (4)
  • Design (37)
    • UX/UI (6)
  • DevOps (55)
    • CI/CD (2)
    • Docker (29)
    • GIT (25)
  • Histories (10)
  • Life (75)
    • Books (28)
    • Tips and Tricks (15)
    • พุทธ (5)
  • Network (115)
    • Apache HTTP Server (13)
    • IOT (1)
    • Nginx (27)
    • Stalwart (5)
  • Operating Systems (243)
    • Unix-like (172)
      • Android (13)
      • iPhone (5)
      • Linux (107)
      • macOS (85)
        • Homebrew (15)
        • OrbStack (10)
      • Oh My ZSH (4)
      • Shell Script (32)
      • SSH (11)
    • Windows (111)
      • PowerShell (23)
      • WSL (24)
  • Programming (652)
    • .NET (18)
      • .NET Core EF (5)
      • C# (17)
    • API (21)
      • REST (5)
      • Swagger (6)
    • Database (173)
      • DBeaver (3)
      • MariaDB (26)
      • MySql (64)
      • Oracle Database (5)
        • 10g (2)
      • PostgreSQL (6)
      • RDBMS (1)
      • SQL Server (84)
        • SSMS (8)
        • T-SQL (26)
      • SQLite (1)
    • PowerBuilder (10)
    • Python (1)
    • Rust (1)
    • System Analyst (SA) (3)
    • Testing (11)
      • Automated Testing (3)
        • Playwright (2)
    • UML (2)
    • Web (343)
      • Backend (218)
        • Golang (1)
        • Java (44)
          • Spring Boot (14)
        • Node.js (1)
        • PHP (173)
          • Laravel (16)
          • Yii (5)
      • Frontend (123)
        • CSS (17)
          • Tailwind CSS (5)
        • JavaScript (111)
          • Angular (2)
          • jQuery (60)
          • Tabulator (11)
          • Vue.js (3)
      • WordPress (25)
  • Programs (73)
    • Excel (10)
  • Security (47)
  • กฎหมาย (6)

Sirat WordPress Theme By VWThemes

Scroll Up