Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Sign in / Register
Toggle navigation
S
spring-boot
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
DEMO
spring-boot
Commits
bbec7b0f
Commit
bbec7b0f
authored
Aug 29, 2019
by
Andy Wilkinson
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch '2.1.x'
Closes gh-17994
parents
b57db504
9961647c
Changes
6
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
49 additions
and
3 deletions
+49
-3
UndertowServletWebServerFactory.java
...eb/embedded/undertow/UndertowServletWebServerFactory.java
+7
-3
ApplicationBuilder.java
...ngframework/boot/context/embedded/ApplicationBuilder.java
+4
-0
EmbeddedServletContainerJarDevelopmentIntegrationTests.java
...beddedServletContainerJarDevelopmentIntegrationTests.java
+10
-0
EmbeddedServletContainerJarPackagingIntegrationTests.java
...EmbeddedServletContainerJarPackagingIntegrationTests.java
+9
-0
EmbeddedServletContainerWarDevelopmentIntegrationTests.java
...beddedServletContainerWarDevelopmentIntegrationTests.java
+10
-0
EmbeddedServletContainerWarPackagingIntegrationTests.java
...EmbeddedServletContainerWarPackagingIntegrationTests.java
+9
-0
No files found.
spring-boot-project/spring-boot/src/main/java/org/springframework/boot/web/embedded/undertow/UndertowServletWebServerFactory.java
View file @
bbec7b0f
...
...
@@ -18,8 +18,8 @@ package org.springframework.boot.web.embedded.undertow;
import
java.io.File
;
import
java.io.IOException
;
import
java.net.MalformedURLException
;
import
java.net.URL
;
import
java.net.URLEncoder
;
import
java.time.Duration
;
import
java.util.ArrayList
;
import
java.util.Arrays
;
...
...
@@ -33,6 +33,7 @@ import java.util.Locale;
import
java.util.Map
;
import
java.util.Set
;
import
java.util.concurrent.TimeUnit
;
import
java.util.regex.Pattern
;
import
javax.servlet.ServletContainerInitializer
;
import
javax.servlet.ServletContext
;
...
...
@@ -95,6 +96,8 @@ import org.springframework.util.Assert;
public
class
UndertowServletWebServerFactory
extends
AbstractServletWebServerFactory
implements
ConfigurableUndertowWebServerFactory
,
ResourceLoaderAware
{
private
static
final
Pattern
ENCODED_SLASH
=
Pattern
.
compile
(
"%2F"
,
Pattern
.
LITERAL
);
private
static
final
Set
<
Class
<?>>
NO_CLASSES
=
Collections
.
emptySet
();
private
Set
<
UndertowBuilderCustomizer
>
builderCustomizers
=
new
LinkedHashSet
<>();
...
...
@@ -583,14 +586,15 @@ public class UndertowServletWebServerFactory extends AbstractServletWebServerFac
private
URLResource
getMetaInfResource
(
URL
resourceJar
,
String
path
)
{
try
{
URL
resourceUrl
=
new
URL
(
resourceJar
+
"META-INF/resources"
+
path
);
String
urlPath
=
URLEncoder
.
encode
(
ENCODED_SLASH
.
matcher
(
path
).
replaceAll
(
"/"
),
"UTF-8"
);
URL
resourceUrl
=
new
URL
(
resourceJar
+
"META-INF/resources"
+
urlPath
);
URLResource
resource
=
new
URLResource
(
resourceUrl
,
path
);
if
(
resource
.
getContentLength
()
<
0
)
{
return
null
;
}
return
resource
;
}
catch
(
MalformedURL
Exception
ex
)
{
catch
(
Exception
ex
)
{
return
null
;
}
}
...
...
spring-boot-tests/spring-boot-integration-tests/spring-boot-server-tests/src/test/java/org/springframework/boot/context/embedded/ApplicationBuilder.java
View file @
bbec7b0f
...
...
@@ -98,6 +98,10 @@ class ApplicationBuilder {
resourcesJarStream
.
putNextEntry
(
new
ZipEntry
(
"META-INF/resources/nested-meta-inf-resource.txt"
));
resourcesJarStream
.
write
(
"nested"
.
getBytes
());
resourcesJarStream
.
closeEntry
();
resourcesJarStream
.
putNextEntry
(
new
ZipEntry
(
"META-INF/resources/nested-reserved-!#$%&()*+,:=?@[]-meta-inf-resource.txt"
));
resourcesJarStream
.
write
(
"encoded-name"
.
getBytes
());
resourcesJarStream
.
closeEntry
();
return
resourcesJar
;
}
}
...
...
spring-boot-tests/spring-boot-integration-tests/spring-boot-server-tests/src/test/java/org/springframework/boot/context/embedded/EmbeddedServletContainerJarDevelopmentIntegrationTests.java
View file @
bbec7b0f
...
...
@@ -40,6 +40,16 @@ public class EmbeddedServletContainerJarDevelopmentIntegrationTests {
assertThat
(
entity
.
getStatusCode
()).
isEqualTo
(
HttpStatus
.
OK
);
}
@TestTemplate
public
void
metaInfResourceFromDependencyWithNameThatContainsReservedCharactersIsAvailableViaHttp
(
RestTemplate
rest
)
{
ResponseEntity
<
String
>
entity
=
rest
.
getForEntity
(
"/nested-reserved-%21%23%24%25%26%28%29%2A%2B%2C%3A%3D%3F%40%5B%5D-meta-inf-resource.txt"
,
String
.
class
);
assertThat
(
entity
.
getStatusCode
()).
isEqualTo
(
HttpStatus
.
OK
);
assertThat
(
entity
.
getBody
()).
isEqualTo
(
"encoded-name"
);
}
@TestTemplate
public
void
metaInfResourceFromDependencyIsAvailableViaServletContext
(
RestTemplate
rest
)
{
ResponseEntity
<
String
>
entity
=
rest
.
getForEntity
(
"/servletContext?/nested-meta-inf-resource.txt"
,
...
...
spring-boot-tests/spring-boot-integration-tests/spring-boot-server-tests/src/test/java/org/springframework/boot/context/embedded/EmbeddedServletContainerJarPackagingIntegrationTests.java
View file @
bbec7b0f
...
...
@@ -40,6 +40,15 @@ public class EmbeddedServletContainerJarPackagingIntegrationTests {
assertThat
(
entity
.
getStatusCode
()).
isEqualTo
(
HttpStatus
.
OK
);
}
@TestTemplate
public
void
nestedMetaInfResourceWithNameThatContainsReservedCharactersIsAvailableViaHttp
(
RestTemplate
rest
)
{
ResponseEntity
<
String
>
entity
=
rest
.
getForEntity
(
"/nested-reserved-%21%23%24%25%26%28%29%2A%2B%2C%3A%3D%3F%40%5B%5D-meta-inf-resource.txt"
,
String
.
class
);
assertThat
(
entity
.
getStatusCode
()).
isEqualTo
(
HttpStatus
.
OK
);
assertThat
(
entity
.
getBody
()).
isEqualTo
(
"encoded-name"
);
}
@TestTemplate
public
void
nestedMetaInfResourceIsAvailableViaServletContext
(
RestTemplate
rest
)
{
ResponseEntity
<
String
>
entity
=
rest
.
getForEntity
(
"/servletContext?/nested-meta-inf-resource.txt"
,
...
...
spring-boot-tests/spring-boot-integration-tests/spring-boot-server-tests/src/test/java/org/springframework/boot/context/embedded/EmbeddedServletContainerWarDevelopmentIntegrationTests.java
View file @
bbec7b0f
...
...
@@ -47,6 +47,16 @@ public class EmbeddedServletContainerWarDevelopmentIntegrationTests {
assertThat
(
entity
.
getStatusCode
()).
isEqualTo
(
HttpStatus
.
OK
);
}
@TestTemplate
public
void
metaInfResourceFromDependencyWithNameThatContainsReservedCharactersIsAvailableViaHttp
(
RestTemplate
rest
)
{
ResponseEntity
<
String
>
entity
=
rest
.
getForEntity
(
"/nested-reserved-%21%23%24%25%26%28%29%2A%2B%2C%3A%3D%3F%40%5B%5D-meta-inf-resource.txt"
,
String
.
class
);
assertThat
(
entity
.
getStatusCode
()).
isEqualTo
(
HttpStatus
.
OK
);
assertThat
(
entity
.
getBody
()).
isEqualTo
(
"encoded-name"
);
}
@TestTemplate
public
void
metaInfResourceFromDependencyIsAvailableViaServletContext
(
RestTemplate
rest
)
{
ResponseEntity
<
String
>
entity
=
rest
.
getForEntity
(
"/servletContext?/nested-meta-inf-resource.txt"
,
...
...
spring-boot-tests/spring-boot-integration-tests/spring-boot-server-tests/src/test/java/org/springframework/boot/context/embedded/EmbeddedServletContainerWarPackagingIntegrationTests.java
View file @
bbec7b0f
...
...
@@ -47,6 +47,15 @@ public class EmbeddedServletContainerWarPackagingIntegrationTests {
assertThat
(
entity
.
getStatusCode
()).
isEqualTo
(
HttpStatus
.
OK
);
}
@TestTemplate
public
void
nestedMetaInfResourceWithNameThatContainsReservedCharactersIsAvailableViaHttp
(
RestTemplate
rest
)
{
ResponseEntity
<
String
>
entity
=
rest
.
getForEntity
(
"/nested-reserved-%21%23%24%25%26%28%29%2A%2B%2C%3A%3D%3F%40%5B%5D-meta-inf-resource.txt"
,
String
.
class
);
assertThat
(
entity
.
getStatusCode
()).
isEqualTo
(
HttpStatus
.
OK
);
assertThat
(
entity
.
getBody
()).
isEqualTo
(
"encoded-name"
);
}
@TestTemplate
public
void
nestedMetaInfResourceIsAvailableViaServletContext
(
RestTemplate
rest
)
{
ResponseEntity
<
String
>
entity
=
rest
.
getForEntity
(
"/servletContext?/nested-meta-inf-resource.txt"
,
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment