BAEL-7470 (#16035)
* BAEL-7470 initial commit * BAEL-7470 changed file name * BAEL-7470 new module * BAEL-7470 new module * BAEL-7470 remove spring-core 4
This commit is contained in:
parent
d5f76028a3
commit
d932403049
spring-boot-modules/spring-boot-basic-customization-3
README.mdpom.xml
src
main
java/com/baeldung
filter
AppConfig.javaLoggingFilterAutowiringSupport.javaLoggingFilterDelegatingFilterProxy.javaLoggingFilterRegistrationBean.javaLoggingFilterWebApplicationContext.javaLoggingService.javaSpringBootFilterStartApp.javaUser.javaUserController.java
springStart
resources
test/java/com/baeldung/filter
@ -0,0 +1,5 @@
|
||||
## Spring Boot Basic Customization 3
|
||||
|
||||
This module contains articles about Spring Boot customization 3
|
||||
|
||||
### Relevant Articles:
|
@ -0,0 +1,53 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project xmlns="http://maven.apache.org/POM/4.0.0"
|
||||
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||
<modelVersion>4.0.0</modelVersion>
|
||||
<artifactId>spring-boot-basic-customization-3</artifactId>
|
||||
<name>spring-boot-basic-customization-3</name>
|
||||
<packaging>jar</packaging>
|
||||
<description>Module For Spring Boot Basic Customization 3</description>
|
||||
|
||||
<parent>
|
||||
<groupId>com.baeldung</groupId>
|
||||
<artifactId>parent-boot-3</artifactId>
|
||||
<version>0.0.1-SNAPSHOT</version>
|
||||
<relativePath>../../parent-boot-3</relativePath>
|
||||
</parent>
|
||||
|
||||
<dependencies>
|
||||
<dependency>
|
||||
<groupId>org.springframework.boot</groupId>
|
||||
<artifactId>spring-boot-starter-web</artifactId>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.springframework.boot</groupId>
|
||||
<artifactId>spring-boot-starter-actuator</artifactId>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.springframework.boot</groupId>
|
||||
<artifactId>spring-boot-starter-test</artifactId>
|
||||
</dependency>
|
||||
</dependencies>
|
||||
|
||||
<build>
|
||||
<plugins>
|
||||
<plugin>
|
||||
<groupId>org.springframework.boot</groupId>
|
||||
<artifactId>spring-boot-maven-plugin</artifactId>
|
||||
<configuration>
|
||||
<finalName>springStartupApp</finalName>
|
||||
<mainClass>com.baeldung.springStart.SpringStartApplication</mainClass>
|
||||
</configuration>
|
||||
<executions>
|
||||
<execution>
|
||||
<goals>
|
||||
<goal>repackage</goal>
|
||||
</goals>
|
||||
</execution>
|
||||
</executions>
|
||||
</plugin>
|
||||
</plugins>
|
||||
</build>
|
||||
|
||||
</project>
|
30
spring-boot-modules/spring-boot-basic-customization-3/src/main/java/com/baeldung/filter/AppConfig.java
Normal file
30
spring-boot-modules/spring-boot-basic-customization-3/src/main/java/com/baeldung/filter/AppConfig.java
Normal file
@ -0,0 +1,30 @@
|
||||
package com.baeldung.filter;
|
||||
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.boot.web.servlet.FilterRegistrationBean;
|
||||
import org.springframework.context.annotation.Bean;
|
||||
import org.springframework.context.annotation.Configuration;
|
||||
import org.springframework.web.filter.DelegatingFilterProxy;
|
||||
|
||||
@Configuration
|
||||
public class AppConfig {
|
||||
|
||||
@Bean
|
||||
public FilterRegistrationBean<DelegatingFilterProxy> loggingFilterDelegatingProxy() {
|
||||
FilterRegistrationBean<DelegatingFilterProxy> registrationBean = new FilterRegistrationBean<>();
|
||||
registrationBean.setFilter(new DelegatingFilterProxy("loggingFilterDelegateProxy"));
|
||||
registrationBean.addUrlPatterns("/*");
|
||||
return registrationBean;
|
||||
}
|
||||
|
||||
@Bean
|
||||
@Autowired
|
||||
public FilterRegistrationBean<LoggingFilterRegistrationBean> loggingFilterRegistration(LoggingService loggingService) {
|
||||
FilterRegistrationBean<LoggingFilterRegistrationBean> registrationBean = new FilterRegistrationBean<>();
|
||||
registrationBean.setFilter(new LoggingFilterRegistrationBean(loggingService));
|
||||
registrationBean.addUrlPatterns("/*");
|
||||
return registrationBean;
|
||||
}
|
||||
|
||||
|
||||
}
|
35
spring-boot-modules/spring-boot-basic-customization-3/src/main/java/com/baeldung/filter/LoggingFilterAutowiringSupport.java
Normal file
35
spring-boot-modules/spring-boot-basic-customization-3/src/main/java/com/baeldung/filter/LoggingFilterAutowiringSupport.java
Normal file
@ -0,0 +1,35 @@
|
||||
package com.baeldung.filter;
|
||||
|
||||
import java.io.IOException;
|
||||
|
||||
import jakarta.servlet.FilterChain;
|
||||
import jakarta.servlet.Filter;
|
||||
import jakarta.servlet.FilterConfig;
|
||||
import jakarta.servlet.ServletException;
|
||||
import jakarta.servlet.ServletRequest;
|
||||
import jakarta.servlet.ServletResponse;
|
||||
import jakarta.servlet.http.HttpServletRequest;
|
||||
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.stereotype.Component;
|
||||
import org.springframework.web.context.support.SpringBeanAutowiringSupport;
|
||||
|
||||
@Component
|
||||
public class LoggingFilterAutowiringSupport implements Filter {
|
||||
|
||||
@Autowired
|
||||
LoggingService loggingService;
|
||||
|
||||
@Override
|
||||
public void init(FilterConfig filterConfig) {
|
||||
SpringBeanAutowiringSupport.processInjectionBasedOnServletContext(this,
|
||||
filterConfig.getServletContext());
|
||||
}
|
||||
|
||||
@Override
|
||||
public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
|
||||
HttpServletRequest httpServletRequest = (HttpServletRequest) servletRequest;
|
||||
loggingService.log(httpServletRequest.getMethod(), httpServletRequest.getRequestURI());
|
||||
filterChain.doFilter(servletRequest, servletResponse);
|
||||
}
|
||||
}
|
27
spring-boot-modules/spring-boot-basic-customization-3/src/main/java/com/baeldung/filter/LoggingFilterDelegatingFilterProxy.java
Normal file
27
spring-boot-modules/spring-boot-basic-customization-3/src/main/java/com/baeldung/filter/LoggingFilterDelegatingFilterProxy.java
Normal file
@ -0,0 +1,27 @@
|
||||
package com.baeldung.filter;
|
||||
|
||||
import java.io.IOException;
|
||||
|
||||
import jakarta.servlet.FilterChain;
|
||||
import jakarta.servlet.Filter;
|
||||
import jakarta.servlet.ServletException;
|
||||
import jakarta.servlet.ServletRequest;
|
||||
import jakarta.servlet.ServletResponse;
|
||||
import jakarta.servlet.http.HttpServletRequest;
|
||||
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.stereotype.Component;
|
||||
|
||||
@Component("loggingFilterDelegateProxy")
|
||||
public class LoggingFilterDelegatingFilterProxy implements Filter {
|
||||
|
||||
@Autowired
|
||||
LoggingService loggingService;
|
||||
|
||||
@Override
|
||||
public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
|
||||
HttpServletRequest httpServletRequest = (HttpServletRequest) servletRequest;
|
||||
loggingService.log(httpServletRequest.getMethod(), httpServletRequest.getRequestURI());
|
||||
filterChain.doFilter(servletRequest, servletResponse);
|
||||
}
|
||||
}
|
32
spring-boot-modules/spring-boot-basic-customization-3/src/main/java/com/baeldung/filter/LoggingFilterRegistrationBean.java
Normal file
32
spring-boot-modules/spring-boot-basic-customization-3/src/main/java/com/baeldung/filter/LoggingFilterRegistrationBean.java
Normal file
@ -0,0 +1,32 @@
|
||||
package com.baeldung.filter;
|
||||
|
||||
import java.io.IOException;
|
||||
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.stereotype.Component;
|
||||
import org.springframework.web.context.support.SpringBeanAutowiringSupport;
|
||||
|
||||
import jakarta.servlet.Filter;
|
||||
import jakarta.servlet.FilterChain;
|
||||
import jakarta.servlet.FilterConfig;
|
||||
import jakarta.servlet.ServletException;
|
||||
import jakarta.servlet.ServletRequest;
|
||||
import jakarta.servlet.ServletResponse;
|
||||
import jakarta.servlet.http.HttpServletRequest;
|
||||
|
||||
@Component
|
||||
public class LoggingFilterRegistrationBean implements Filter {
|
||||
|
||||
private LoggingService loggingService;
|
||||
|
||||
public LoggingFilterRegistrationBean(LoggingService loggingService) {
|
||||
this.loggingService = loggingService;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
|
||||
HttpServletRequest httpServletRequest = (HttpServletRequest) servletRequest;
|
||||
loggingService.log(httpServletRequest.getMethod(), httpServletRequest.getRequestURI());
|
||||
filterChain.doFilter(servletRequest, servletResponse);
|
||||
}
|
||||
}
|
34
spring-boot-modules/spring-boot-basic-customization-3/src/main/java/com/baeldung/filter/LoggingFilterWebApplicationContext.java
Normal file
34
spring-boot-modules/spring-boot-basic-customization-3/src/main/java/com/baeldung/filter/LoggingFilterWebApplicationContext.java
Normal file
@ -0,0 +1,34 @@
|
||||
package com.baeldung.filter;
|
||||
|
||||
import java.io.IOException;
|
||||
|
||||
import jakarta.servlet.FilterChain;
|
||||
import jakarta.servlet.Filter;
|
||||
import jakarta.servlet.FilterConfig;
|
||||
import jakarta.servlet.ServletException;
|
||||
import jakarta.servlet.ServletRequest;
|
||||
import jakarta.servlet.ServletResponse;
|
||||
import jakarta.servlet.http.HttpServletRequest;
|
||||
|
||||
import org.springframework.stereotype.Component;
|
||||
import org.springframework.web.context.support.WebApplicationContextUtils;
|
||||
|
||||
@Component
|
||||
public class LoggingFilterWebApplicationContext implements Filter {
|
||||
|
||||
private LoggingService loggingService;
|
||||
|
||||
@Override
|
||||
public void init(FilterConfig filterConfig) {
|
||||
loggingService = WebApplicationContextUtils
|
||||
.getRequiredWebApplicationContext(filterConfig.getServletContext())
|
||||
.getBean(LoggingService.class);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
|
||||
HttpServletRequest httpServletRequest = (HttpServletRequest) servletRequest;
|
||||
loggingService.log(httpServletRequest.getMethod(), httpServletRequest.getRequestURI());
|
||||
filterChain.doFilter(servletRequest, servletResponse);
|
||||
}
|
||||
}
|
14
spring-boot-modules/spring-boot-basic-customization-3/src/main/java/com/baeldung/filter/LoggingService.java
Normal file
14
spring-boot-modules/spring-boot-basic-customization-3/src/main/java/com/baeldung/filter/LoggingService.java
Normal file
@ -0,0 +1,14 @@
|
||||
package com.baeldung.filter;
|
||||
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
import org.springframework.stereotype.Service;
|
||||
|
||||
@Service
|
||||
public class LoggingService {
|
||||
|
||||
private final Logger logger = LoggerFactory.getLogger(this.getClass());
|
||||
public void log(String message,String url){
|
||||
logger.info("Logging Request {} for URI : {}",message,url);
|
||||
}
|
||||
}
|
12
spring-boot-modules/spring-boot-basic-customization-3/src/main/java/com/baeldung/filter/SpringBootFilterStartApp.java
Normal file
12
spring-boot-modules/spring-boot-basic-customization-3/src/main/java/com/baeldung/filter/SpringBootFilterStartApp.java
Normal file
@ -0,0 +1,12 @@
|
||||
package com.baeldung.filter;
|
||||
|
||||
import org.springframework.boot.SpringApplication;
|
||||
import org.springframework.boot.autoconfigure.SpringBootApplication;
|
||||
|
||||
@SpringBootApplication
|
||||
public class SpringBootFilterStartApp {
|
||||
|
||||
public static void main(String[] args) {
|
||||
SpringApplication.run(SpringBootFilterStartApp.class, args);
|
||||
}
|
||||
}
|
39
spring-boot-modules/spring-boot-basic-customization-3/src/main/java/com/baeldung/filter/User.java
Normal file
39
spring-boot-modules/spring-boot-basic-customization-3/src/main/java/com/baeldung/filter/User.java
Normal file
@ -0,0 +1,39 @@
|
||||
package com.baeldung.filter;
|
||||
|
||||
public class User {
|
||||
|
||||
private String id;
|
||||
private String name;
|
||||
private String email;
|
||||
|
||||
public User(String id, String name, String email) {
|
||||
this.id = id;
|
||||
this.name = name;
|
||||
this.email = email;
|
||||
}
|
||||
|
||||
public String getId() {
|
||||
return id;
|
||||
}
|
||||
|
||||
public void setId(String id) {
|
||||
this.id = id;
|
||||
}
|
||||
|
||||
public String getName() {
|
||||
return name;
|
||||
}
|
||||
|
||||
public void setName(String name) {
|
||||
this.name = name;
|
||||
}
|
||||
|
||||
public String getEmail() {
|
||||
return email;
|
||||
}
|
||||
|
||||
public void setEmail(String email) {
|
||||
this.email = email;
|
||||
}
|
||||
|
||||
}
|
17
spring-boot-modules/spring-boot-basic-customization-3/src/main/java/com/baeldung/filter/UserController.java
Normal file
17
spring-boot-modules/spring-boot-basic-customization-3/src/main/java/com/baeldung/filter/UserController.java
Normal file
@ -0,0 +1,17 @@
|
||||
package com.baeldung.filter;
|
||||
|
||||
import java.util.Arrays;
|
||||
import java.util.List;
|
||||
|
||||
import org.springframework.web.bind.annotation.GetMapping;
|
||||
import org.springframework.web.bind.annotation.RestController;
|
||||
|
||||
@RestController
|
||||
public class UserController {
|
||||
|
||||
@GetMapping("/users")
|
||||
public List<User> getUsers(){
|
||||
return Arrays.asList(new User("1","John","john@email.com"),
|
||||
new User("2","Smith","smith@email.com"));
|
||||
}
|
||||
}
|
12
spring-boot-modules/spring-boot-basic-customization-3/src/main/java/com/baeldung/springStart/SpringStartApplication.java
Normal file
12
spring-boot-modules/spring-boot-basic-customization-3/src/main/java/com/baeldung/springStart/SpringStartApplication.java
Normal file
@ -0,0 +1,12 @@
|
||||
package com.baeldung.springStart;
|
||||
|
||||
import org.springframework.boot.SpringApplication;
|
||||
import org.springframework.boot.autoconfigure.SpringBootApplication;
|
||||
|
||||
@SpringBootApplication
|
||||
public class SpringStartApplication {
|
||||
|
||||
public static void main(String[] args) {
|
||||
SpringApplication.run(SpringStartApplication.class, args);
|
||||
}
|
||||
}
|
0
spring-boot-modules/spring-boot-basic-customization-3/src/main/resources/application.properties
Normal file
0
spring-boot-modules/spring-boot-basic-customization-3/src/main/resources/application.properties
Normal file
30
spring-boot-modules/spring-boot-basic-customization-3/src/test/java/com/baeldung/filter/LoggingFilterAutowiringSupportUnitTest.java
Normal file
30
spring-boot-modules/spring-boot-basic-customization-3/src/test/java/com/baeldung/filter/LoggingFilterAutowiringSupportUnitTest.java
Normal file
@ -0,0 +1,30 @@
|
||||
package com.baeldung.filter;
|
||||
|
||||
import java.lang.reflect.Field;
|
||||
|
||||
import org.junit.Assert;
|
||||
import org.junit.Test;
|
||||
import org.junit.runner.RunWith;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.boot.test.context.SpringBootTest;
|
||||
import org.springframework.test.context.junit4.SpringRunner;
|
||||
|
||||
@RunWith(SpringRunner.class)
|
||||
@SpringBootTest
|
||||
public class LoggingFilterAutowiringSupportUnitTest {
|
||||
|
||||
@Autowired
|
||||
private LoggingFilterAutowiringSupport loggingFilter;
|
||||
|
||||
@Test
|
||||
public void givenFilter_whenAutowired_thenDependencyInjected() throws Exception {
|
||||
Assert.assertNotNull(loggingFilter);
|
||||
Assert.assertNotNull(getField(loggingFilter,"loggingService"));
|
||||
}
|
||||
|
||||
private Object getField(Object target, String fieldName) throws NoSuchFieldException, IllegalAccessException {
|
||||
Field field = target.getClass().getDeclaredField(fieldName);
|
||||
field.setAccessible(true);
|
||||
return field.get(target);
|
||||
}
|
||||
}
|
30
spring-boot-modules/spring-boot-basic-customization-3/src/test/java/com/baeldung/filter/LoggingFilterDelegatingFilterProxyUnitTest.java
Normal file
30
spring-boot-modules/spring-boot-basic-customization-3/src/test/java/com/baeldung/filter/LoggingFilterDelegatingFilterProxyUnitTest.java
Normal file
@ -0,0 +1,30 @@
|
||||
package com.baeldung.filter;
|
||||
|
||||
import java.lang.reflect.Field;
|
||||
|
||||
import org.junit.Assert;
|
||||
import org.junit.Test;
|
||||
import org.junit.runner.RunWith;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.boot.test.context.SpringBootTest;
|
||||
import org.springframework.test.context.junit4.SpringRunner;
|
||||
|
||||
@RunWith(SpringRunner.class)
|
||||
@SpringBootTest
|
||||
public class LoggingFilterDelegatingFilterProxyUnitTest {
|
||||
|
||||
@Autowired
|
||||
private LoggingFilterDelegatingFilterProxy loggingFilter;
|
||||
|
||||
@Test
|
||||
public void testLoggingFilter() throws Exception {
|
||||
Assert.assertNotNull(loggingFilter);
|
||||
Assert.assertNotNull(getField(loggingFilter,"loggingService"));
|
||||
}
|
||||
|
||||
private Object getField(Object target, String fieldName) throws NoSuchFieldException, IllegalAccessException {
|
||||
Field field = target.getClass().getDeclaredField(fieldName);
|
||||
field.setAccessible(true);
|
||||
return field.get(target);
|
||||
}
|
||||
}
|
30
spring-boot-modules/spring-boot-basic-customization-3/src/test/java/com/baeldung/filter/LoggingFilterRegistrationBeanUnitTest.java
Normal file
30
spring-boot-modules/spring-boot-basic-customization-3/src/test/java/com/baeldung/filter/LoggingFilterRegistrationBeanUnitTest.java
Normal file
@ -0,0 +1,30 @@
|
||||
package com.baeldung.filter;
|
||||
|
||||
import java.lang.reflect.Field;
|
||||
|
||||
import org.junit.Assert;
|
||||
import org.junit.Test;
|
||||
import org.junit.runner.RunWith;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.boot.test.context.SpringBootTest;
|
||||
import org.springframework.test.context.junit4.SpringRunner;
|
||||
|
||||
@RunWith(SpringRunner.class)
|
||||
@SpringBootTest
|
||||
public class LoggingFilterRegistrationBeanUnitTest {
|
||||
|
||||
@Autowired
|
||||
private LoggingFilterRegistrationBean loggingFilter;
|
||||
|
||||
@Test
|
||||
public void testLoggingFilter() throws Exception {
|
||||
Assert.assertNotNull(loggingFilter);
|
||||
Assert.assertNotNull(getField(loggingFilter,"loggingService"));
|
||||
}
|
||||
|
||||
private Object getField(Object target, String fieldName) throws NoSuchFieldException, IllegalAccessException {
|
||||
Field field = target.getClass().getDeclaredField(fieldName);
|
||||
field.setAccessible(true);
|
||||
return field.get(target);
|
||||
}
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user