Interview kitsBlog

Your dream job? Lets Git IT.
Interactive technical interview preparation platform designed for modern developers.

XGitHub

Platform

  • Categories

Resources

  • Blog
  • About the app
  • FAQ
  • Feedback

Legal

  • Privacy Policy
  • Terms of Service

© 2026 LetsGit.IT. All rights reserved.

LetsGit.IT/Categories/Spring
Springhard

Spring Security context — why can auth break in async code?

Tags
#spring-security#securitycontext#threadlocal#async
Back to categoryPractice quiz

Answer

SecurityContext is often stored in a ThreadLocal. When you switch threads (async/executor), the new thread may not have that context, so auth info is missing. You must propagate context explicitly or use supported async security integration.

Advanced answer

Deep dive

Expanding on the short answer — what usually matters in practice:

  • Context (tags): spring-security, securitycontext, threadlocal, async
  • Lifecycle: what happens at runtime (render/build, request/response, background jobs).
  • Caching: where cache lives, cache keys, how to invalidate without chaos.
  • Security: authn/authz, secrets, attack surface (SSRF/CSRF).
  • Explain the "why", not just the "what" (intuition + consequences).
  • Trade-offs: what you gain/lose (time, memory, complexity, risk).
  • Edge cases: empty inputs, large inputs, invalid inputs, concurrency.

Examples

A tiny example (an explanation template):

// Example: discuss trade-offs for "spring-security-context-—-why-can-auth-break-in-"
function explain() {
  // Start from the core idea:
  // SecurityContext is often stored in a ThreadLocal. When you switch threads (async/executor)
}

Common pitfalls

  • Too generic: no concrete trade-offs or examples.
  • Mixing average-case and worst-case (e.g., complexity).
  • Ignoring constraints: memory, concurrency, network/disk costs.

Interview follow-ups

  • When would you choose an alternative and why?
  • What production issues show up and how do you diagnose them?
  • How would you test edge cases?

Related questions

Spring
`@Async` methods: how do they work and what are common pitfalls?
#spring#async#executor
Spring
How does `@Async` work in Spring and what’s a common gotcha?
#async#executor#proxy
Spring
Spring Security — where do authentication/authorization happen?
#spring-security#filters
#auth
Testing
How do you test asynchronous or concurrent code?
#async#concurrency#determinism
JavaScript
What does Promise.all do and when would you use it?
#promises#async
JavaScript
How do Promises work and how do they differ from callbacks?
#promises#async