Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/spring-mvc/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Spring mvc 文件上传与功能Webflux_Spring Mvc_Spring Boot_Spring Web_Spring Webflux - Fatal编程技术网

Spring mvc 文件上传与功能Webflux

Spring mvc 文件上传与功能Webflux,spring-mvc,spring-boot,spring-web,spring-webflux,Spring Mvc,Spring Boot,Spring Web,Spring Webflux,我正在使用路由器Kotlin DSL制作迁移到SpringWebFlux和SpringBoot功能变体的原型。现在我需要一些关于使用MIME类型multipart/form数据上传文件的提示,而不是使用application/json上传一些数据 当我定义一个简单的路由器函数和一个这样的处理程序时,我得到下面的stacktrace: fun routes(handler: MultimediaHandler) = router { (accept(MediaType.MULTIPART_

我正在使用路由器Kotlin DSL制作迁移到SpringWebFlux和SpringBoot功能变体的原型。现在我需要一些关于使用MIME类型multipart/form数据上传文件的提示,而不是使用application/json上传一些数据

当我定义一个简单的路由器函数和一个这样的处理程序时,我得到下面的stacktrace:

fun routes(handler: MultimediaHandler) = router {
    (accept(MediaType.MULTIPART_FORM_DATA) and "/multimedia").nest {
        PUT("/{id}", handler::upload)
    }
}
class MultimediaHandler {
    fun upload(request: ServerRequest): Mono<ServerResponse> {
        val id = request.pathVariable("id")
        return noContent().build()
    }
}
堆栈跟踪:

13:43:29.713 ERROR [i.u.request] [XNIO-1 I/O-3] UT005071: Undertow request failed HttpServerExchange{ PUT /multimedia/00000000-0000-0000-0000-000000000
001 request {Connection=[Keep-Alive], Accept-Encoding=[gzip,deflate], Content-Length=[1672], Content-Type=[multipart/form-data; boundary=-mJAzUqZoGk2nc
N1Rch4O4-KGbTExkAmQ7A], User-Agent=[Apache-HttpClient/4.5.2 (Java/1.8.0_144)], Host=[localhost:8444]} response {}}
java.lang.IllegalStateException: No multipart HttpMessageReader.
        at org.springframework.web.server.adapter.DefaultServerWebExchange.lambda$initMultipartData$3(DefaultServerWebExchange.java:144) ~[spring-web-5.0.0.RC3.jar:5.0.0.RC3]
        at java.util.Optional.orElseThrow(Optional.java:290) ~[?:1.8.0_144]
        at org.springframework.web.server.adapter.DefaultServerWebExchange.initMultipartData(DefaultServerWebExchange.java:144) ~[spring-web-5.0.0.RC3.jar:5.0.0.RC3]
        at org.springframework.web.server.adapter.DefaultServerWebExchange.<init>(DefaultServerWebExchange.java:109) ~[spring-web-5.0.0.RC3.jar:5.0.0.RC3]
        at org.springframework.web.server.adapter.HttpWebHandlerAdapter.createExchange(HttpWebHandlerAdapter.java:167) ~[spring-web-5.0.0.RC3.jar:5.0.0.RC3]
        at org.springframework.web.server.adapter.HttpWebHandlerAdapter.handle(HttpWebHandlerAdapter.java:156) ~[spring-web-5.0.0.RC3.jar:5.0.0.RC3]
        at org.springframework.http.server.reactive.UndertowHttpHandlerAdapter.handleRequest(UndertowHttpHandlerAdapter.java:71) ~[spring-web-5.0.0.RC3.jar:5.0.0.RC3]
        at io.undertow.server.Connectors.executeRootHandler(Connectors.java:332) [undertow-core-1.4.19.Final.jar:1.4.19.Final]
        at io.undertow.server.protocol.http.HttpReadListener.handleEventWithNoRunningRequest(HttpReadListener.java:254) [undertow-core-1.4.19.Final.jar:1.4.19.Final]
        at io.undertow.server.protocol.http.HttpReadListener.handleEvent(HttpReadListener.java:136) [undertow-core-1.4.19.Final.jar:1.4.19.Final]
        at io.undertow.server.protocol.http.HttpOpenListener.handleEvent(HttpOpenListener.java:148) [undertow-core-1.4.19.Final.jar:1.4.19.Final]
        at io.undertow.server.protocol.http.AlpnOpenListener$AlpnConnectionListener.handleEvent(AlpnOpenListener.java:357) [undertow-core-1.4.19.Final.jar:1.4.19.Final]
        at io.undertow.server.protocol.http.AlpnOpenListener$AlpnConnectionListener.handleEvent(AlpnOpenListener.java:308) [undertow-core-1.4.19.Final.jar:1.4.19.Final]
        at org.xnio.ChannelListeners.invokeChannelListener(ChannelListeners.java:92) [xnio-api-3.5.1.Final.jar:3.5.1.Final]
        at org.xnio.conduits.ReadReadyHandler$ChannelListenerHandler.readReady(ReadReadyHandler.java:66) [xnio-api-3.5.1.Final.jar:3.5.1.Final]
        at io.undertow.protocols.ssl.SslConduit$SslReadReadyHandler.readReady(SslConduit.java:1140) [undertow-core-1.4.19.Final.jar:1.4.19.Final]
        at org.xnio.nio.NioSocketConduit.handleReady(NioSocketConduit.java:89) [xnio-nio-3.5.1.Final.jar:3.5.1.Final]
        at org.xnio.nio.WorkerThread.run(WorkerThread.java:571) [xnio-nio-3.5.1.Final.jar:3.5.1.Final]

您的类路径是否具有以下依赖关系? Spring框架需要这种方法来解析多部分请求

<dependency>
  <groupId>org.synchronoss.cloud</groupId>
  <artifactId>nio-multipart-parser</artifactId>
  <version>...</version>
</dependency>

您的类路径是否具有以下依赖关系? Spring框架需要这种方法来解析多部分请求

<dependency>
  <groupId>org.synchronoss.cloud</groupId>
  <artifactId>nio-multipart-parser</artifactId>
  <version>...</version>
</dependency>

谢谢,现在错误消失了。仅供参考,只要我在SpringMVC中使用SpringCloud和SpringBoot,就不需要这种依赖关系。我刚刚将MultipartFile与@RequestParam一起使用,这是因为它使用标准的servlet多部分支持。这里没有这样的东西。谢谢你,现在错误消失了。仅供参考,只要我在SpringMVC中使用SpringCloud和SpringBoot,就不需要这种依赖关系。我刚刚将MultipartFile与@RequestParam一起使用,这是因为它使用标准的servlet多部分支持。这里没有这样的事。