BAEL-636: add standalone deployment (#1521)
This commit is contained in:
parent
85969c69d2
commit
a18d779294
@ -40,13 +40,6 @@
|
|||||||
<artifactId>spring-boot-starter-webflux</artifactId>
|
<artifactId>spring-boot-starter-webflux</artifactId>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<!-- a fix for spring-boot dependency on Reactor -->
|
|
||||||
<dependency>
|
|
||||||
<groupId>io.projectreactor</groupId>
|
|
||||||
<artifactId>reactor-core</artifactId>
|
|
||||||
<version>3.0.6.BUILD-SNAPSHOT</version>
|
|
||||||
</dependency>
|
|
||||||
|
|
||||||
<!-- utils -->
|
<!-- utils -->
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.apache.commons</groupId>
|
<groupId>org.apache.commons</groupId>
|
||||||
|
@ -0,0 +1,87 @@
|
|||||||
|
package com.baeldung.functional;
|
||||||
|
|
||||||
|
import org.springframework.core.io.ClassPathResource;
|
||||||
|
import org.springframework.http.server.reactive.HttpHandler;
|
||||||
|
import org.springframework.http.server.reactive.ServletHttpHandlerAdapter;
|
||||||
|
import org.springframework.util.MultiValueMap;
|
||||||
|
import org.springframework.web.reactive.function.server.RouterFunction;
|
||||||
|
import org.springframework.web.reactive.function.server.RouterFunctions;
|
||||||
|
import org.springframework.web.reactive.function.server.ServerResponse;
|
||||||
|
import org.springframework.web.server.adapter.WebHttpHandlerBuilder;
|
||||||
|
import reactor.core.publisher.Flux;
|
||||||
|
import reactor.core.publisher.Mono;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.concurrent.CopyOnWriteArrayList;
|
||||||
|
import java.util.concurrent.atomic.AtomicLong;
|
||||||
|
|
||||||
|
import static org.springframework.web.reactive.function.BodyExtractors.toDataBuffers;
|
||||||
|
import static org.springframework.web.reactive.function.BodyExtractors.toFormData;
|
||||||
|
import static org.springframework.web.reactive.function.BodyInserters.fromObject;
|
||||||
|
import static org.springframework.web.reactive.function.server.RequestPredicates.*;
|
||||||
|
import static org.springframework.web.reactive.function.server.RouterFunctions.route;
|
||||||
|
import static org.springframework.web.reactive.function.server.RouterFunctions.toHttpHandler;
|
||||||
|
import static org.springframework.web.reactive.function.server.ServerResponse.ok;
|
||||||
|
|
||||||
|
public class RootServlet extends ServletHttpHandlerAdapter {
|
||||||
|
|
||||||
|
public RootServlet() {
|
||||||
|
this(WebHttpHandlerBuilder
|
||||||
|
.webHandler(toHttpHandler(routingFunction()))
|
||||||
|
.prependFilter(new IndexRewriteFilter())
|
||||||
|
.build());
|
||||||
|
}
|
||||||
|
|
||||||
|
private RootServlet(HttpHandler httpHandler) {
|
||||||
|
super(httpHandler);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Actor BRAD_PITT = new Actor("Brad", "Pitt");
|
||||||
|
private static final Actor TOM_HANKS = new Actor("Tom", "Hanks");
|
||||||
|
private static final List<Actor> actors = new CopyOnWriteArrayList<>(Arrays.asList(BRAD_PITT, TOM_HANKS));
|
||||||
|
|
||||||
|
private static RouterFunction<?> routingFunction() {
|
||||||
|
|
||||||
|
return route(GET("/test"), serverRequest -> ok().body(fromObject("helloworld")))
|
||||||
|
.andRoute(POST("/login"), serverRequest -> serverRequest
|
||||||
|
.body(toFormData())
|
||||||
|
.map(MultiValueMap::toSingleValueMap)
|
||||||
|
.map(formData -> {
|
||||||
|
System.out.println("form data: " + formData.toString());
|
||||||
|
if ("baeldung".equals(formData.get("user")) && "you_know_what_to_do".equals(formData.get("token"))) {
|
||||||
|
return ok()
|
||||||
|
.body(Mono.just("welcome back!"), String.class)
|
||||||
|
.block();
|
||||||
|
}
|
||||||
|
return ServerResponse
|
||||||
|
.badRequest()
|
||||||
|
.build()
|
||||||
|
.block();
|
||||||
|
}))
|
||||||
|
.andRoute(POST("/upload"), serverRequest -> serverRequest
|
||||||
|
.body(toDataBuffers())
|
||||||
|
.collectList()
|
||||||
|
.map(dataBuffers -> {
|
||||||
|
AtomicLong atomicLong = new AtomicLong(0);
|
||||||
|
dataBuffers.forEach(d -> atomicLong.addAndGet(d
|
||||||
|
.asByteBuffer()
|
||||||
|
.array().length));
|
||||||
|
System.out.println("data length:" + atomicLong.get());
|
||||||
|
return ok()
|
||||||
|
.body(fromObject(atomicLong.toString()))
|
||||||
|
.block();
|
||||||
|
}))
|
||||||
|
.and(RouterFunctions.resources("/files/**", new ClassPathResource("files/")))
|
||||||
|
.andNest(path("/actor"), route(GET("/"), serverRequest -> ok().body(Flux.fromIterable(actors), Actor.class)).andRoute(POST("/"), serverRequest -> serverRequest
|
||||||
|
.bodyToMono(Actor.class)
|
||||||
|
.doOnNext(actors::add)
|
||||||
|
.then(ok().build())))
|
||||||
|
.filter((request, next) -> {
|
||||||
|
System.out.println("Before handler invocation: " + request.path());
|
||||||
|
return next.handle(request);
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -1,6 +1,7 @@
|
|||||||
package com.baeldung.web;
|
package com.baeldung.web;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Optional;
|
||||||
|
|
||||||
import javax.validation.constraints.Max;
|
import javax.validation.constraints.Max;
|
||||||
import javax.validation.constraints.Min;
|
import javax.validation.constraints.Min;
|
||||||
@ -33,7 +34,7 @@ public class FooController {
|
|||||||
@ResponseBody
|
@ResponseBody
|
||||||
@Validated
|
@Validated
|
||||||
public Foo findById(@PathVariable @Min(0) final long id) {
|
public Foo findById(@PathVariable @Min(0) final long id) {
|
||||||
return repo.findOne(id);
|
return repo.findOne(id).orElse(null);
|
||||||
}
|
}
|
||||||
|
|
||||||
@RequestMapping(method = RequestMethod.GET)
|
@RequestMapping(method = RequestMethod.GET)
|
||||||
|
21
spring-5/src/main/webapp/WEB-INF/web.xml
Normal file
21
spring-5/src/main/webapp/WEB-INF/web.xml
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
|
||||||
|
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||||
|
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
|
||||||
|
version="3.1">
|
||||||
|
|
||||||
|
<display-name>Spring Functional Application</display-name>
|
||||||
|
|
||||||
|
<servlet>
|
||||||
|
<servlet-name>functional</servlet-name>
|
||||||
|
<servlet-class>com.baeldung.functional.RootServlet</servlet-class>
|
||||||
|
<load-on-startup>1</load-on-startup>
|
||||||
|
<async-supported>true</async-supported>
|
||||||
|
</servlet>
|
||||||
|
<servlet-mapping>
|
||||||
|
<servlet-name>functional</servlet-name>
|
||||||
|
<url-pattern>/</url-pattern>
|
||||||
|
</servlet-mapping>
|
||||||
|
|
||||||
|
|
||||||
|
</web-app>
|
Loading…
x
Reference in New Issue
Block a user