API Gateway is DataMate's unified entry point, built on Spring Cloud Gateway, responsible for route forwarding, JWT authentication, and rate limiting.
backend/api-gateway/
├── src/main/java/com/datamate/gateway/
│ ├── config/ # Gateway configuration
│ ├── filter/ # JWT authentication filter
│ └── route/ # Route definitions
└── src/main/resources/
└── application.yml # Gateway configuration
- Default: 8080
- Nacos Discovery Port: 30000
spring:
application:
name: datamate-gateway
cloud:
nacos:
discovery:
port: 30000
server-addr: ${NACOS_ADDR}
username: consul
password:
datamate:
jwt:
secret: ${JWT_SECRET}
expiration-seconds: 3600- Forward frontend requests to corresponding backend services
- Support for load balancing
- Path rewriting
- JWT Token-based authentication
- Token validation and expiration checking
- User context propagation
- Request rate limiting (if configured)
- Prevent API abuse
- JDK 21+
- Maven 3.8+
- Nacos service (if using service discovery)
cd backend/api-gateway
mvn clean installcd backend/api-gateway
mvn spring-boot:runConfigure route rules in application.yml or via Nacos:
spring:
cloud:
gateway:
routes:
- id: data-management
uri: lb://data-management-service
predicates:
- Path=/api/data-management/**
filters:
- StripPrefix=3Create a GlobalFilter or GatewayFilter:
@Component
public class AuthFilter implements GlobalFilter {
@Override
public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {
// Filter logic
return chain.filter(exchange);
}
}curl http://localhost:8080/api/data-management/datasetscurl -H "Authorization: Bearer <token>" http://localhost:8080/api/protected-endpoint- Spring Cloud Gateway Docs: https://docs.spring.io/spring-cloud-gateway/
- Nacos Discovery: https://nacos.io/