All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.directwebremoting.servlet.DwrServlet Maven / Gradle / Ivy

Go to download

DWR is easy Ajax for Java. It makes it simple to call Java code directly from Javascript. It gets rid of almost all the boiler plate code between the web browser and your Java code.

There is a newer version: 3.0.2-RELEASE
Show newest version
/*
 * Copyright 2005 Joe Walker
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package org.directwebremoting.servlet;

import java.io.IOException;

import javax.servlet.ServletConfig;
import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.directwebremoting.Container;
import org.directwebremoting.WebContextFactory.WebContextBuilder;
import org.directwebremoting.extend.ServerLoadMonitor;
import org.directwebremoting.impl.ContainerUtil;
import org.directwebremoting.impl.DefaultContainer;
import org.directwebremoting.impl.StartupUtil;
import org.directwebremoting.util.Logger;
import org.directwebremoting.util.ServletLoggingOutput;

/**
 * This is the main servlet that handles all the requests to DWR.
 * 

It is on the large side because it can't use technologies like JSPs etc * since it all needs to be deployed in a single jar file, and while it might be * possible to integrate Velocity or similar I think simplicity is more * important, and there are only 2 real pages both script heavy in this servlet * anyway.

*

There are 5 things to do, in the order that you come across them:

*
    *
  • The index test page that points at the classes
  • *
  • The class test page that lets you execute methods
  • *
  • The interface javascript that uses the engine to send requests
  • *
  • The engine javascript to form the iframe request and process replies
  • *
  • The exec 'page' that executes the method and returns data to the iframe
  • *
* @author Joe Walker [joe at getahead dot ltd dot uk] * @noinspection RefusedBequest */ public class DwrServlet extends HttpServlet { /* (non-Javadoc) * @see javax.servlet.GenericServlet#init(javax.servlet.ServletConfig) */ public void init(ServletConfig servletConfig) throws ServletException { super.init(servletConfig); ServletContext servletContext = servletConfig.getServletContext(); try { // setupLogging() only needed for servlet logging if commons-logging is unavailable // logStartup() just outputs some version numbers StartupUtil.setupLogging(servletConfig, this); StartupUtil.logStartup(servletConfig); // create and setup a DefaultContainer container = ContainerUtil.createDefaultContainer(servletConfig); ContainerUtil.setupDefaultContainer(container, servletConfig); webContextBuilder = StartupUtil.initWebContext(servletConfig, servletContext, container); StartupUtil.initServerContext(servletConfig, servletContext, container); ContainerUtil.prepareForWebContextFilter(servletContext, servletConfig, container, webContextBuilder, this); ContainerUtil.configureContainerFully(container, servletConfig); ContainerUtil.publishContainer(container, servletConfig); } catch (ExceptionInInitializerError ex) { log.fatal("ExceptionInInitializerError. Nested exception:", ex.getException()); throw new ServletException(ex); } catch (Exception ex) { log.fatal("DwrServlet.init() failed", ex); throw new ServletException(ex); } finally { if (webContextBuilder != null) { webContextBuilder.unset(); } ServletLoggingOutput.unsetExecutionContext(); } } /* (non-Javadoc) * @see javax.servlet.GenericServlet#destroy() */ public void destroy() { shutdown(); super.destroy(); } /** * Kill all comet polls. *

Technically a servlet engine ought to call this only when all the * threads are already removed, however at least Tomcat doesn't do this * properly (it waits for a while and then calls destroy anyway). *

It would be good if we could get {@link #destroy()} to call this * method however destroy() is only called once all threads are done so it's * too late. */ public void shutdown() { ServerLoadMonitor monitor = (ServerLoadMonitor) container.getBean(ServerLoadMonitor.class.getName()); monitor.shutdown(); } /* (non-Javadoc) * @see javax.servlet.http.HttpServlet#doGet(javax.servlet.http.HttpServletRequest, javax.servlet.http.HttpServletResponse) */ protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws IOException, ServletException { doPost(req, resp); } /* (non-Javadoc) * @see javax.servlet.http.HttpServlet#doPost(javax.servlet.http.HttpServletRequest, javax.servlet.http.HttpServletResponse) */ protected void doPost(HttpServletRequest request, HttpServletResponse response) throws IOException, ServletException { try { webContextBuilder.set(request, response, getServletConfig(), getServletContext(), container); ServletLoggingOutput.setExecutionContext(this); UrlProcessor processor = (UrlProcessor) container.getBean(UrlProcessor.class.getName()); processor.handle(request, response); } finally { webContextBuilder.unset(); ServletLoggingOutput.unsetExecutionContext(); } } /** * Accessor for the DWR IoC container. * @return DWR's IoC container */ public Container getContainer() { return container; } /** * Our IoC container */ private DefaultContainer container; /** * The WebContext that keeps http objects local to a thread */ private WebContextBuilder webContextBuilder; /** * The log stream */ public static final Logger log = Logger.getLogger(DwrServlet.class); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy