Add 'Migrating to Spring Framework 3.2' appendix
This commit is contained in:
parent
a4f882fbf0
commit
3458d4d945
|
@ -471,6 +471,9 @@
|
|||
<xi:include href="classic-aop-spring.xml"
|
||||
xmlns:xi="http://www.w3.org/2001/XInclude" />
|
||||
|
||||
<xi:include href="migration-3.2.xml"
|
||||
xmlns:xi="http://www.w3.org/2001/XInclude" />
|
||||
|
||||
<xi:include href="xsd-configuration.xml"
|
||||
xmlns:xi="http://www.w3.org/2001/XInclude" />
|
||||
|
||||
|
|
|
@ -0,0 +1,328 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<appendix xml:id="migration-3.2"
|
||||
xmlns="http://docbook.org/ns/docbook" version="5.0"
|
||||
xmlns:xl="http://www.w3.org/1999/xlink"
|
||||
xmlns:xi="http://www.w3.org/2001/XInclude"
|
||||
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||
xsi:schemaLocation="
|
||||
http://docbook.org/ns/docbook http://www.docbook.org/xml/5.0/xsd/docbook.xsd
|
||||
http://www.w3.org/1999/xlink http://www.docbook.org/xml/5.0/xsd/xlink.xsd">
|
||||
<title>Migrating to Spring Framework 3.2</title>
|
||||
|
||||
<para>In this appendix we discuss discuss what users will want to know when upgrading to
|
||||
Spring Framework 3.2. For a general overview of features, please see
|
||||
<xref linkend="new-in-3.2"/></para>
|
||||
|
||||
<section xml:id="migration-3.2-new-optional-deps">
|
||||
<title>Newly optional dependencies</title>
|
||||
<para>Certain inter-module dependencies are now <literal>optional</literal> at the
|
||||
Maven POM level where they were once required. For example, <literal>spring-tx</literal>
|
||||
and its dependence on <literal>spring-context</literal>. This may result in <literal>
|
||||
ClassNotFoundErrors</literal> or other similar problems for users that have been relying
|
||||
on transitive dependency management to pull in affected downstream <literal>spring-*
|
||||
</literal>. To resolve this problem, simply add the appropriate missing jars to your
|
||||
build configuration.</para>
|
||||
</section>
|
||||
|
||||
<section xml:id="migration-3.2-inline-asm">
|
||||
<title>Inlining of spring-asm jar</title>
|
||||
<para>In versions 3.0 and 3.1, we published a discrete <literal>spring-asm</literal>
|
||||
containing repackaged <literal>org.objectweb.asm</literal> 3.x sources. As of Spring
|
||||
Framework 3.2, we have upgraded to <literal>org.objectweb.asm</literal> 4.0 and done
|
||||
away with the separate module jar, favoring inlining these classes directly within
|
||||
<literal>spring-core</literal>. This should cause no migration issue for most users;
|
||||
but on the off chance that you have <literal>spring-asm</literal> declared directly
|
||||
within your project's build script, you'll want to remove it when upgrading to
|
||||
Spring Framework 3.2.</para>
|
||||
</section>
|
||||
|
||||
<section xml:id="migration-3.2-inline-cglib">
|
||||
<title>Explicit CGLIB dependency no longer required</title>
|
||||
<para>In prior versions, users of Spring's subclass-based AOP proxies (e.g. via
|
||||
<literal>proxy-target-class="true"</literal>) and <literal>@Configuration</literal>
|
||||
class support were required to declare an explicit dependency on CGLIB 2.2. As of
|
||||
Spring Framework 3.2, we now repackage and inline the newly-released CGLIB 3.0.</para>
|
||||
<para>This means greater convenience for users, as well as correct functionality for
|
||||
Java 7 users who are creating subclass proxies of types that contain <literal>
|
||||
invokedynamic</literal> bytecode instructions. Repackaging CGLIB internally ensures
|
||||
no classpath conflicts with other third party frameworks that may depend on other
|
||||
versions of CGLIB.</para>
|
||||
</section>
|
||||
|
||||
<section xml:id="migration-3.2-osgi-users">
|
||||
<title>For OSGi users</title>
|
||||
<para>OSGi metadata is no longer published within individual Spring Framework
|
||||
jar MANIFEST.MF files. Please see this
|
||||
<link xl:href="http://www.springsource.org/springframework-ebr">announcement</link>
|
||||
for more information about how users can get OSGi-ready versions of Spring
|
||||
Framework 3.2 jars.</para>
|
||||
</section>
|
||||
|
||||
<section xml:id="migration-3.2-compatibility-mvc-config">
|
||||
<title>MVC Java Config and MVC Namespace</title>
|
||||
|
||||
<para>As explained in <xref linkend="mvc-config-content-negotiation"/>, both
|
||||
the MVC Java config and the MVC namespace register extensions such as
|
||||
<filename>.json</filename> and <filename>.xml</filename> if the
|
||||
corresponding classpath dependencies are present. That means controller
|
||||
methods may now return JSON or XML formatted content if those
|
||||
extensions are present in the request URI,
|
||||
even if the 'Accept' header doesn't request those media types.</para>
|
||||
|
||||
<para>The newly added support for matrix variables is explained in
|
||||
<xref linkend="mvc-ann-matrix-variables"/>. To preserve backward
|
||||
compatibility, by default, semicolon content is removed from incoming
|
||||
request URIs and therefore <interfacename>@MatrixVariable</interfacename>
|
||||
cannot be used without additional configuration. However, when using
|
||||
the MVC Java config and the MVC namespace, semicolon content is left
|
||||
in the URI so that matrix variables are automatically supported.
|
||||
The removal of semicolon content is controlled through the
|
||||
<classname>UrlPathHelper</classname> property of
|
||||
<classname>RequestMappingHandlerMapping</classname>.</para>
|
||||
</section>
|
||||
|
||||
<section xml:id="migration-3.2-compatibility-uri-variable-values">
|
||||
<title>Decoding of URI Variable Values</title>
|
||||
<para>URI variable values now get decoded when
|
||||
<code>UrlPathHelper.setUrlDecode</code> is set to <code>false</code>.
|
||||
See <link xl:href="https://jira.springsource.org/browse/SPR-9098">SPR-9098</link>.</para>
|
||||
</section>
|
||||
|
||||
<section xml:id="migration-3.2-compatibility-http-patch">
|
||||
<title>HTTP PATCH method</title>
|
||||
<para>The <classname>DispatcherServlet</classname> now allows the
|
||||
HTTP PATCH method where previously it didn't.</para>
|
||||
</section>
|
||||
|
||||
<section xml:id="migration-3.2-compatibility-tiles3">
|
||||
<title>Tiles 3</title>
|
||||
|
||||
<para>Besides the version number change, the set of Tiles
|
||||
dependencies has also changed. You will need to have a subset or all of
|
||||
<filename>tiles-request-api</filename>, <filename>tiles-api</filename>,
|
||||
<filename>tiles-core</filename>, <filename>tiles-servlet</filename>,
|
||||
<filename>tiles-jsp</filename>, <filename>tiles-el</filename>.
|
||||
</para>
|
||||
</section>
|
||||
|
||||
<section xml:id="migration-3.2-compatibility-spring-mvc-test">
|
||||
<title>Spring MVC Test standalone project</title>
|
||||
|
||||
<para>If migrating from the
|
||||
<link xl:href="https://github.com/SpringSource/spring-test-mvc">spring-test-mvc</link>
|
||||
standalone project to the <filename>spring-test</filename> module in
|
||||
Spring Framework 3.2, you will need to adjust the root package
|
||||
to be <classname>org.springframework.test.web.servlet</classname>.</para>
|
||||
|
||||
<para>You will no longer be able to use the
|
||||
<classname>MockMvcBuilders</classname> <code>annotationConfigSetup</code>
|
||||
and <code>xmlConfigSetup</code> options. Instead you'll need to switch
|
||||
to using the <interfacename>@WebApplicationContext</interfacename> support
|
||||
of <filename>spring-test</filename> for loading Spring configuration,
|
||||
then inject a <interfacename>WebApplicationContext</interfacename> into
|
||||
the test and use it to create a <classname>MockMvc</classname>.
|
||||
<xref linkend="spring-mvc-test-framework" /> for details.</para>
|
||||
</section>
|
||||
|
||||
<section xml:id="migration-3.2-changes">
|
||||
<title>Public API changes</title>
|
||||
|
||||
<section xml:id="migration-3.2-api-changes">
|
||||
<title>JDiff reports</title>
|
||||
Select JDiff reports are now being published to provide users with a convenient
|
||||
means of understanding what's changed between versions. Going forward these will be
|
||||
published between each minor version, e.g. from 3.1.3.RELEASE to 3.1.4.RELEASE; from
|
||||
the latest maintenance version to the latest GA release, e.g.
|
||||
<link xl:href="http://static.springsource.org/spring-framework/docs/3.1.3.RELEASE_to_3.2.0.RELEASE">
|
||||
3.1.3.RELEASE to 3.2.0.RELEASE</link>; and in between each milestone
|
||||
and/or RC for users who are tracking next-generation development, e.g.
|
||||
<link xl:href="http://static.springsource.org/spring-framework/docs/3.2.0.RC2_to_3.2.0.RELEASE">
|
||||
3.2.0.RC2 to 3.2.0.RELEASE</link>.
|
||||
</section>
|
||||
|
||||
<section xml:id="migration-3.2-removals-and-deprecations">
|
||||
<title>Deprecations</title>
|
||||
<para>The following packages and types have been wholly or partially deprecated
|
||||
in Spring Framework 3.2 and may be removed in a future version. Click through
|
||||
to the linked Javadoc for each item for exact details. See also the
|
||||
<link xl:href="http://static.springsource.org/spring-framework/docs/3.2.0.RELEASE/javadoc-api/deprecated-list.html">
|
||||
complete list of deprecations</link> in the framework.</para>
|
||||
<itemizedlist>
|
||||
<listitem>
|
||||
<para>
|
||||
<link xl:href="http://static.springsource.org/spring-framework/docs/3.2.0.RELEASE/javadoc-api/org/springframework/orm/ibatis/package-summary.html">
|
||||
org.springframework.orm.ibatis</link>
|
||||
</para>
|
||||
</listitem>
|
||||
<listitem>
|
||||
<para>
|
||||
<link xl:href="http://static.springsource.org/spring-framework/docs/3.2.0.RELEASE/javadoc-api/org/springframework/scheduling/backportconcurrent/package-summary.html">
|
||||
org.springframework.scheduling.backportconcurrent</link>
|
||||
</para>
|
||||
</listitem>
|
||||
<listitem>
|
||||
<para>
|
||||
<link xl:href="http://static.springsource.org/spring-framework/docs/3.2.0.RELEASE/javadoc-api/org/springframework/ejb/support/package-summary.html">
|
||||
org.springframework.ejb.support</link>
|
||||
</para>
|
||||
</listitem>
|
||||
<listitem>
|
||||
<para>
|
||||
<link xl:href="http://static.springsource.org/spring-framework/docs/3.2.0.RELEASE/javadoc-api/org/springframework/http/converter/xml/XmlAwareFormHttpMessageConverter.html">
|
||||
org.springframework.http.converter.xml.XmlAwareFormHttpMessageConverter</link>
|
||||
</para>
|
||||
</listitem>
|
||||
<listitem>
|
||||
<para>
|
||||
<link xl:href="http://static.springsource.org/spring-framework/docs/3.2.0.RELEASE/javadoc-api/org/springframework/web/jsf/DelegatingVariableResolver.html">
|
||||
org.springframework.web.jsf.DelegatingVariableResolver</link>
|
||||
</para>
|
||||
</listitem>
|
||||
<listitem>
|
||||
<para>
|
||||
<link xl:href="http://static.springsource.org/spring-framework/docs/3.2.0.RELEASE/javadoc-api/org/springframework/web/jsf/SpringBeanVariableResolver.html">
|
||||
org.springframework.web.jsf.SpringBeanVariableResolver</link>
|
||||
</para>
|
||||
</listitem>
|
||||
<listitem>
|
||||
<para>
|
||||
<link xl:href="http://static.springsource.org/spring-framework/docs/3.2.0.RELEASE/javadoc-api/org/springframework/ui/velocity/CommonsLoggingLogSystem.html">
|
||||
org.springframework.ui.velocity.CommonsLoggingLogSystem</link>
|
||||
</para>
|
||||
</listitem>
|
||||
<listitem>
|
||||
<para>
|
||||
<link xl:href="http://static.springsource.org/spring-framework/docs/3.2.0.RELEASE/javadoc-api/org/springframework/ui/velocity/VelocityEngineUtils.html">
|
||||
org.springframework.ui.velocity.VelocityEngineUtils</link>
|
||||
</para>
|
||||
</listitem>
|
||||
<listitem>
|
||||
<para>
|
||||
<link xl:href="http://static.springsource.org/spring-framework/docs/3.2.0.RELEASE/javadoc-api/org/springframework/beans/factory/config/BeanReferenceFactoryBean.html">
|
||||
org.springframework.beans.factory.config.BeanReferenceFactoryBean</link>
|
||||
</para>
|
||||
</listitem>
|
||||
<listitem>
|
||||
<para>
|
||||
<link xl:href="http://static.springsource.org/spring-framework/docs/3.2.0.RELEASE/javadoc-api/org/springframework/beans/factory/config/CommonsLogFactoryBean.html">
|
||||
org.springframework.beans.factory.config.CommonsLogFactoryBean</link>
|
||||
</para>
|
||||
</listitem>
|
||||
<listitem>
|
||||
<para>
|
||||
<link xl:href="http://static.springsource.org/spring-framework/docs/3.2.0.RELEASE/javadoc-api/org/springframework/instrument/classloading/oc4j/OC4JLoadTimeWeaver.html">
|
||||
org.springframework.beans.instrument.classloading.oc4j.OC4JLoadTimeWeaver</link>
|
||||
</para>
|
||||
</listitem>
|
||||
<listitem>
|
||||
<para>
|
||||
<link xl:href="http://static.springsource.org/spring-framework/docs/3.2.0.RELEASE/javadoc-api/org/springframework/transaction/jta/OC4JJtaTransactionManager.html">
|
||||
org.springframework.transaction.jta.OC4JJtaTransactionManager</link>
|
||||
</para>
|
||||
</listitem>
|
||||
<listitem>
|
||||
<para>
|
||||
<link xl:href="http://static.springsource.org/spring-framework/docs/3.2.0.RELEASE/javadoc-api/org/springframework/web/util/ExpressionEvaluationUtils.html">
|
||||
org.springframework.web.util.ExpressionEvaluationUtils</link>
|
||||
</para>
|
||||
</listitem>
|
||||
<listitem>
|
||||
<para>
|
||||
<link xl:href="http://static.springsource.org/spring-framework/docs/3.2.0.RELEASE/javadoc-api/org/springframework/web/servlet/mvc/annotation/AnnotationMethodHandlerAdapter.html">
|
||||
org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter</link>
|
||||
</para>
|
||||
</listitem>
|
||||
<listitem>
|
||||
<para>
|
||||
<link xl:href="http://static.springsource.org/spring-framework/docs/3.2.0.RELEASE/javadoc-api/org/springframework/web/servlet/mvc/annotation/AnnotationMethodHandlerExceptionResolver.html">
|
||||
org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerExceptionResolver</link>
|
||||
</para>
|
||||
</listitem>
|
||||
<listitem>
|
||||
<para>
|
||||
<link xl:href="http://static.springsource.org/spring-framework/docs/3.2.0.RELEASE/javadoc-api/org/springframework/web/servlet/mvc/annotation/DefaultAnnotationHandlerMapping.html">
|
||||
org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping</link>
|
||||
</para>
|
||||
</listitem>
|
||||
<listitem>
|
||||
<para>
|
||||
<link xl:href="http://static.springsource.org/spring-framework/docs/3.2.0.RELEASE/javadoc-api/org/springframework/web/servlet/mvc/annotation/ServletAnnotationMappingUtils.html">
|
||||
org.springframework.web.servlet.mvc.annotation.ServletAnnotationMappingUtils</link>
|
||||
</para>
|
||||
</listitem>
|
||||
<listitem>
|
||||
<para>
|
||||
<link xl:href="http://static.springsource.org/spring-framework/docs/3.2.0.RELEASE/javadoc-api/org/springframework/jmx/support/MBeanRegistrationSupport.html">
|
||||
org.springframework.jmx.support.MBeanRegistrationSupport</link>
|
||||
</para>
|
||||
</listitem>
|
||||
<listitem>
|
||||
<para>
|
||||
<link xl:href="http://static.springsource.org/spring-framework/docs/3.2.0.RELEASE/javadoc-api/org/springframework/test/context/ContextConfigurationAttributes.html">
|
||||
org.springframework.test.context.ContextConfigurationAttributes</link>
|
||||
</para>
|
||||
</listitem>
|
||||
<listitem>
|
||||
<para>
|
||||
<link xl:href="http://static.springsource.org/spring-framework/docs/3.2.0.RELEASE/javadoc-api/org/springframework/test/context/junit4/AbstractTransactionalJUnit4SpringContextTests.html">
|
||||
org.springframework.test.context.junit4.AbstractTransactionalJUnit4SpringContextTests</link>
|
||||
</para>
|
||||
</listitem>
|
||||
<listitem>
|
||||
<para>
|
||||
<link xl:href="http://static.springsource.org/spring-framework/docs/3.2.0.RELEASE/javadoc-api/org/springframework/test/context/testng/AbstractTransactionalTestNGSpringContextTests.html">
|
||||
org.springframework.test.context.testng.AbstractTransactionalTestNGSpringContextTests</link>
|
||||
</para>
|
||||
</listitem>
|
||||
<listitem>
|
||||
<para>
|
||||
<link xl:href="http://static.springsource.org/spring-framework/docs/3.2.0.RELEASE/javadoc-api/org/springframework/test/jdbc/SimpleJdbcTestUtils.html">
|
||||
org.springframework.test.jdbc.SimpleJdbcTestUtils</link>
|
||||
</para>
|
||||
</listitem>
|
||||
<listitem>
|
||||
<para>
|
||||
<link xl:href="http://static.springsource.org/spring-framework/docs/3.2.0.RELEASE/javadoc-api/org/springframework/web/servlet/view/ContentNegotiatingViewResolver.html">
|
||||
org.springframework.web.servlet.view.ContentNegotiatingViewResolver</link>
|
||||
</para>
|
||||
</listitem>
|
||||
<listitem>
|
||||
<para>
|
||||
<link xl:href="http://static.springsource.org/spring-framework/docs/3.2.0.RELEASE/javadoc-api/org/springframework/transaction/interceptor/TransactionAspectUtils.html">
|
||||
org.springframework.transaction.interceptor.TransactionAspectUtils</link>
|
||||
</para>
|
||||
</listitem>
|
||||
<listitem>
|
||||
<para>
|
||||
<link xl:href="http://static.springsource.org/spring-framework/docs/3.2.0.RELEASE/javadoc-api/org/springframework/http/HttpStatus.html">
|
||||
org.springframework.http.HttpStatus</link>
|
||||
</para>
|
||||
</listitem>
|
||||
<listitem>
|
||||
<para>
|
||||
<link xl:href="http://static.springsource.org/spring-framework/docs/3.2.0.RELEASE/javadoc-api/org/springframework/web/util/UriUtils.html">
|
||||
org.springframework.web.util.UriUtils</link>
|
||||
</para>
|
||||
</listitem>
|
||||
<listitem>
|
||||
<para>
|
||||
<link xl:href="http://static.springsource.org/spring-framework/docs/3.2.0.RELEASE/javadoc-api/org/springframework/orm/jpa/vendor/TopLinkJpaDialect.html">
|
||||
org.springframework.orm.jpa.vendor.TopLinkJpaDialect</link>
|
||||
</para>
|
||||
</listitem>
|
||||
<listitem>
|
||||
<para>
|
||||
<link xl:href="http://static.springsource.org/spring-framework/docs/3.2.0.RELEASE/javadoc-api/org/springframework/orm/jpa/vendor/TopLinkJpaVendorAdapter.html">
|
||||
org.springframework.orm.jpa.vendor.TopLinkJpaVendorAdapter</link>
|
||||
</para>
|
||||
</listitem>
|
||||
<listitem>
|
||||
<para>
|
||||
<link xl:href="http://static.springsource.org/spring-framework/docs/3.2.0.RELEASE/javadoc-api/org/springframework/util/CachingMapDecorator.html">
|
||||
org.springframework.orm.util.CachingMapDecorator</link>
|
||||
</para>
|
||||
</listitem>
|
||||
</itemizedlist>
|
||||
</section>
|
||||
</section>
|
||||
</appendix>
|
|
@ -9,6 +9,9 @@
|
|||
xmlns:ns="http://docbook.org/ns/docbook">
|
||||
<title>New Features and Enhancements in Spring Framework 3.2</title>
|
||||
|
||||
<para>This section covers what's new in Spring Framework 3.2. See also
|
||||
<xref linkend="migration-3.2"/></para>
|
||||
|
||||
<section xml:id="new-in-3.2-webmvc-async">
|
||||
<title>Support for Servlet 3 based asynchronous request processing</title>
|
||||
|
||||
|
@ -165,6 +168,24 @@
|
|||
configuration.</para>
|
||||
</section>
|
||||
|
||||
<section xml:id="new-in-3.2-webmvc-tiles3">
|
||||
<title>Tiles 3</title>
|
||||
|
||||
<para>Tiles 3 is now supported in addition to Tiles 2.x. Configuring
|
||||
it should be very similar to the Tiles 2 configuration, i.e. the
|
||||
combination of <classname>TilesConfigurer</classname>,
|
||||
<classname>TilesViewResolver</classname> and <classname>TilesView</classname>
|
||||
except using the <code>tiles3</code> instead of the <code>tiles2</code>
|
||||
package.</para>
|
||||
|
||||
<para>Also note that besides the version number change, the tiles
|
||||
dependencies have also changed. You will need to have a subset or all of
|
||||
<filename>tiles-request-api</filename>, <filename>tiles-api</filename>,
|
||||
<filename>tiles-core</filename>, <filename>tiles-servlet</filename>,
|
||||
<filename>tiles-jsp</filename>, <filename>tiles-el</filename>.
|
||||
</para>
|
||||
</section>
|
||||
|
||||
<section xml:id="new-in-3.2-webmvc-request-body-arg-with-binding-result">
|
||||
<title><interfacename>@RequestBody</interfacename> improvements</title>
|
||||
|
||||
|
|
Loading…
Reference in New Issue