Our Users
REST API security(2)
User ID |
Password |
Roles |
john |
test123 |
EMPLOYEE |
mary |
test123 |
EMPLOYEE, MANAGER |
susan |
test123 |
EMPLOYEE, MANAGER, ADMIN |
Development Process
- Create Spring Security Configuration(@Configuration)
- Add users, passwords and roles
Step 1: Create Spring Security Configuration
File:DemoSecurityConfig.java
import org.springframework.context.annotation.Configuration;
@Configuration
public class DemoSecurityConfig {
// add our security configurations here ...
}
Spring Security Password Storage
- In Spring, passwords are stored using a specific format
{id}encodedPassword
ID |
Description |
noop |
Plain text passwords |
bcrypt |
BCrypt password hashing |
… |
… |
Password Example
data:image/s3,"s3://crabby-images/a3123/a312342595e9c35793d980989f2bbd573c092f30" alt=""
Step 2: Add users, passwords and roles
- File: DemoSecurityConfig.java
data:image/s3,"s3://crabby-images/fd227/fd22734419d42496c5d233c0a8a5ff5bd04403d6" alt=""
- Since we defined our users here…
- Spring Boot will NOT use the user/pass from the application.properties file
data:image/s3,"s3://crabby-images/1572c/1572c5dceaeabd600bedebc4340d93a99540bc62" alt=""
Restric Access Based on Roles
Example
HTTP Method |
Endpoint |
CRUD Action |
Role |
GET |
/api/employees |
Read all |
EMPLOYEE |
GET |
/api/employees/{employeeId} |
Read single |
EMPLOYEE |
POST |
/api/employees |
Create |
MANAGER |
PUT |
/api/employees |
Update |
MANAGER |
DELETE |
/api/employees/{employeeId} |
Delete employee |
ADMIN |
Restricting Access to Roles
data:image/s3,"s3://crabby-images/4ef8f/4ef8ff86b096f62bc1c2dc81580071ef716aec9f" alt=""
data:image/s3,"s3://crabby-images/27c85/27c8568e66a16a8ce0399a6be28570d2e239c57d" alt=""
data:image/s3,"s3://crabby-images/e6496/e6496060ed2558a91833daab585af4c1731d7e95" alt=""
Authorize Requests for EMPLOYEE role
data:image/s3,"s3://crabby-images/26868/268687b89f83ac986aebba4b7f64a860f168ddd4" alt=""
Authorize Requests for MANAGER role
data:image/s3,"s3://crabby-images/0f74a/0f74a7057e831827d45a00109ee70f47f40b52eb" alt=""
Authorize Requests for ADMIN role
data:image/s3,"s3://crabby-images/b1b99/b1b99c6b36a66c3b111a185d8d3d8245e41bffa0" alt=""
Pull it Together
data:image/s3,"s3://crabby-images/54c35/54c359e11abc5843547e04dab805e4475a042e5a" alt=""
Cross-Site Request Forgery(CSRF)
- Spring Security can protect against CSRF attacks
- Embed additional authentication data/token into all HTML forms
- On subsequent requests, web app will verify token bofore processing
- Primary use case is traditional web applications (HTML forms etc..)
When to use CSRF Protection?
- The Spring Security team recommends
- Use CSRF protection for any normal browser web requests
- Traditional web apps with HTML forms to add/modify data
- If you are building a REST API for non-browser clients
- you may want to disable CSRF protection
- In general, not required for stateless REST APIs
- That use POST,PUT,DELETE and/or PATCH
Pull it Together
data:image/s3,"s3://crabby-images/32960/32960b9250017e64b1cc888eb40b262b0ba67afd" alt=""
data:image/s3,"s3://crabby-images/494ae/494ae1788c61c78bca3eddf714e055f45f87abaf" alt=""
- Role : ADMIN
- Test user : susan / test123
- pass: Get all employees
- pass: Get single employee
- pass: Add employee
- pass: Update employee
- pass: Delete employee
댓글남기기