Spring считает, что все, что находится за последней точкой, является расширением файла, например .json
или .xml
, и усекает его для получения вашего параметра.
Так что если у вас есть /{blahName}
:
/param
, /param.json
, /param.xml
или /param.anything
приведет к параметру со значением param
/param.value.json
, /param.value.xml
или /param.value.anything
приведет кпараметр со значением param.value
Если вы измените отображение на /{blahName:.+}
, как предложено, любая точка, включая последнюю, будет считаться частью вашего параметра:
/param
приведет к параметру со значением param
/param.json
приведет к параметру со значением param.json
/param.xml
приведет к параметрусо значением param.xml
/param.anything
приведет к параметру со значением param.anything
/param.value.json
приведет к параметру со значением param.value.json
- ...
Если вам не нужно распознавание расширений, вы можете отключить его, переопределив mvc:annotation-driven
automagic:
<bean id="handlerMapping"
class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping">
<property name="contentNegotiationManager" ref="contentNegotiationManager"/>
<property name="useSuffixPatternMatch" value="false"/>
</bean>
Итак, еще раз, если у вас есть /{blahName}
:
/param
, /param.json
, /param.xml
или /param.anything
приведет к параметру со значением param
/param.value.json
, /param.value.xml
или /param.value.anything
приведет к параметрусо значением param.value
Примечание: отличие от конфигурации по умолчанию видно только в том случае, если у вас есть сопоставление типа /something.{blahName}
.См. Проблема проекта Resthub .
Если вы хотите сохранить управление расширениями, начиная с Spring 3.2, вы также можете установить свойство useRegisteredSuffixPatternMatch компонента RequestMappingHandlerMapping, чтобы сохранить активацию распознавания суффикса Паттерн, но ограниченную зарегистрированным расширением..
Здесь вы определяете только расширения json и xml:
<bean id="handlerMapping"
class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping">
<property name="contentNegotiationManager" ref="contentNegotiationManager"/>
<property name="useRegisteredSuffixPatternMatch" value="true"/>
</bean>
<bean id="contentNegotiationManager" class="org.springframework.web.accept.ContentNegotiationManagerFactoryBean">
<property name="favorPathExtension" value="false"/>
<property name="favorParameter" value="true"/>
<property name="mediaTypes">
<value>
json=application/json
xml=application/xml
</value>
</property>
</bean>
Обратите внимание, что mvc: annotation-driven теперь принимает опцию contentNegotiation для предоставления пользовательского компонента, но свойство RequestMappingHandlerMapping должно бытьизменено на true (по умолчанию false) (ср. https://jira.springsource.org/browse/SPR-7632).
По этой причине вам все равно придется переопределить всю конфигурацию, управляемую аннотациями mvc :. Я открыл билет в Spring, чтобы запросить пользовательский RequestMappingHandlerMapping:https://jira.springsource.org/browse/SPR-11253. Пожалуйста, проголосуйте, если вы заинтересованы.
При переопределении, будьте осторожны, чтобы учесть также переопределение пользовательского управления выполнением. В противном случае все ваши пользовательские сопоставления исключений потерпят неудачу. Вам придется повторно использовать messageCoverters со списком bean:
<bean id="validator" class="org.springframework.validation.beanvalidation.LocalValidatorFactoryBean" />
<bean id="conversionService" class="org.springframework.format.support.FormattingConversionServiceFactoryBean" />
<util:list id="messageConverters">
<bean class="your.custom.message.converter.IfAny"></bean>
<bean class="org.springframework.http.converter.ByteArrayHttpMessageConverter"></bean>
<bean class="org.springframework.http.converter.StringHttpMessageConverter"></bean>
<bean class="org.springframework.http.converter.ResourceHttpMessageConverter"></bean>
<bean class="org.springframework.http.converter.xml.SourceHttpMessageConverter"></bean>
<bean class="org.springframework.http.converter.xml.XmlAwareFormHttpMessageConverter"></bean>
<bean class="org.springframework.http.converter.xml.Jaxb2RootElementHttpMessageConverter"></bean>
<bean class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter"></bean>
</util:list>
<bean name="exceptionHandlerExceptionResolver"
class="org.springframework.web.servlet.mvc.method.annotation.ExceptionHandlerExceptionResolver">
<property name="order" value="0"/>
<property name="messageConverters" ref="messageConverters"/>
</bean>
<bean name="handlerAdapter"
class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter">
<property name="webBindingInitializer">
<bean class="org.springframework.web.bind.support.ConfigurableWebBindingInitializer">
<property name="conversionService" ref="conversionService" />
<property name="validator" ref="validator" />
</bean>
</property>
<property name="messageConverters" ref="messageConverters"/>
</bean>
<bean id="handlerMapping"
class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping">
</bean>
Я реализовал в проекте с открытым исходным кодом Resthub , частью которого я являюсь, набор тестов по этим предметам: см. https://github.com/resthub/resthub-spring-stack/pull/219/files и https://github.com/resthub/resthub-spring-stack/issues/217