summaryrefslogtreecommitdiffstats
path: root/documentation/articles
diff options
context:
space:
mode:
Diffstat (limited to 'documentation/articles')
-rw-r--r--documentation/articles/CreatingAServlet3.0Application.asciidoc62
-rw-r--r--documentation/articles/contents.asciidoc1
2 files changed, 63 insertions, 0 deletions
diff --git a/documentation/articles/CreatingAServlet3.0Application.asciidoc b/documentation/articles/CreatingAServlet3.0Application.asciidoc
new file mode 100644
index 0000000000..18e6a1c8dd
--- /dev/null
+++ b/documentation/articles/CreatingAServlet3.0Application.asciidoc
@@ -0,0 +1,62 @@
+[[creating-a-servlet-3.0-application]]
+Creating a servlet 3.0 application
+----------------------------------
+
+Servlet 3.0 introduces a `@WebServlet` annotation which can be used to
+replace the traditional web.xml. The straightforward approach to create
+a Vaadin application using servlet 3.0 annotations is to simply move
+whatever is in web.xml to a custom servlet class (extends `VaadinServlet`)
+and annotate it using `@WebServlet` and add `@WebInitParams` as needed. You
+will end up with something like
+
+[source,java]
+....
+@WebServlet(value = "/*", asyncSupported = true, initParams = {
+ @WebInitParam(name = "ui", value = "com.example.MyUI"),
+ @WebInitParam(name = "productionMode", value = "false")
+})
+public class MyServlet extends VaadinServlet {
+}
+....
+
+The problem you will face sooner or later with both this approach as
+well as using web.xml is that you will misspell some parameter name or
+class name. Maybe you change the UI class name and the init parameter is
+not automatically updated - and the head scratching and debugging
+starts.
+
+Vaadin 7.1 introduces two features which makes this a lot easier,
+`@VaadinServletConfiguration` and automatic UI finding.
+
+`@VaadinServletConfiguration` is a type safe, Vaadin version of
+`@WebInitParam` which provides you with the option to select UI by
+referring the UI class directly, toggle `productionMode` using a boolean
+and more. The above example rewritten using `@VaadinServletConfiguration`
+looks like:
+
+[source,java]
+....
+@WebServlet(value = "/*", asyncSupported = true)
+@VaadinServletConfiguration(productionMode = false, ui = MYUI.class)
+public class MyServlet extends VaadinServlet {
+}
+....
+
+Automatic UI finding takes this even one step further and allows you to
+leave out `@VaadinServletConfiguration` completely if you define your
+servlet class as a static inner class to your UI class. The above
+example could therefore also be written as
+
+[source,java]
+....
+public class MYUI extends UI {
+ @WebServlet(value = "/*", asyncSupported = true)
+ public static class Servlet extends VaadinServlet {
+ }
+....
+
+For clarity the variant with `@VaadinServletConfiguration` is likely the
+better option. Please do note that `@VaadinServletConfiguration` comes
+with defaults for some parameters, most importantly
+`legacyPropertyToStringMode`, which might be important if you are
+migrating an older application.
diff --git a/documentation/articles/contents.asciidoc b/documentation/articles/contents.asciidoc
index 9ff9ef74f4..16d16286a7 100644
--- a/documentation/articles/contents.asciidoc
+++ b/documentation/articles/contents.asciidoc
@@ -74,5 +74,6 @@ are great, too.
- link:WidgetStylingUsingOnlyCSS.asciidoc[Widget styling using only CSS]
- link:VisuallyDistinguishPrimaryActions.asciidoc[Visually distinguish primary actions]
- link:LabelButtonsExpressively.asciidoc[Label buttons expressively]
+- link:CreatingAServlet3.0Application.asciidoc[Creating a servlet 3.0 application]
- link:CreatingAUIExtension.asciidoc[Creating a UI extension]
- link:CreatingAThemeUsingSass.asciidoc[Creating a theme using Sass]