Site icon PlusMagi's Blog By Pitt Phunsanit

Java: spring-security-web ( login )

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


spring-security-core

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


spring-security-web

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


spring-security-config

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


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

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

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


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

Exit mobile version