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

org.eclipse.jetty.websocket.servlet.WebSocketServlet Maven / Gradle / Ivy

There is a newer version: 3.9
Show newest version
//
//  ========================================================================
//  Copyright (c) 1995-2013 Mort Bay Consulting Pty. Ltd.
//  ------------------------------------------------------------------------
//  All rights reserved. This program and the accompanying materials
//  are made available under the terms of the Eclipse Public License v1.0
//  and Apache License v2.0 which accompanies this distribution.
//
//      The Eclipse Public License is available at
//      http://www.eclipse.org/legal/epl-v10.html
//
//      The Apache License v2.0 is available at
//      http://www.opensource.org/licenses/apache2.0.php
//
//  You may elect to redistribute this code under either of these licenses.
//  ========================================================================
//

package org.eclipse.jetty.websocket.servlet;

import java.io.IOException;
import java.util.Iterator;
import java.util.ServiceLoader;

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

import org.eclipse.jetty.websocket.api.WebSocketBehavior;
import org.eclipse.jetty.websocket.api.WebSocketPolicy;
import org.eclipse.jetty.websocket.api.annotations.WebSocket;

/**
 * Abstract Servlet used to bridge the Servlet API to the WebSocket API.
 * 

* To use this servlet, you will be required to register your websockets with the {@link WebSocketServerFactory} so that it can create your websockets under the * appropriate conditions. *

* The most basic implementation would be as follows. * *

 * package my.example;
 * 
 * import org.eclipse.jetty.websocket.servlet.WebSocketServlet;
 * import org.eclipse.jetty.websocket.servlet.WebSocketServletFactory;
 * 
 * public class MyEchoServlet extends WebSocketServlet
 * {
 *     @Override
 *     public void configure(WebSocketServletFactory factory)
 *     {
 *         // set a 10 second idle timeout
 *         factory.getPolicy().setIdleTimeout(10000);
 *         // register my socket
 *         factory.register(MyEchoSocket.class);
 *     }
 * }
 * 
* * Note: that only request that conforms to a "WebSocket: Upgrade" handshake request will trigger the {@link WebSocketServerFactory} handling of creating * WebSockets.
* All other requests are treated as normal servlet requests. * *

* Configuration / Init-Parameters:
* Note: If you use the {@link WebSocket @WebSocket} annotation, these configuration settings can be specified on a per WebSocket basis, vs a per Servlet * basis. * *

*
maxIdleTime
*
set the time in ms that a websocket may be idle before closing
* *
maxMessagesSize
*
set the size in bytes that a websocket may be accept before closing
* *
inputBufferSize
*
set the size in bytes of the buffer used to read raw bytes from the network layer
*
*/ @SuppressWarnings("serial") public abstract class WebSocketServlet extends HttpServlet { private WebSocketServletFactory factory; public abstract void configure(WebSocketServletFactory factory); @Override public void destroy() { factory.cleanup(); } /** * @see javax.servlet.GenericServlet#init() */ @Override public void init() throws ServletException { try { WebSocketPolicy policy = new WebSocketPolicy(WebSocketBehavior.SERVER); String max = getInitParameter("maxIdleTime"); if (max != null) { policy.setIdleTimeout(Long.parseLong(max)); } max = getInitParameter("maxMessageSize"); if (max != null) { policy.setMaxMessageSize(Long.parseLong(max)); } max = getInitParameter("inputBufferSize"); if (max != null) { policy.setInputBufferSize(Integer.parseInt(max)); } WebSocketServletFactory baseFactory; Iterator factories = ServiceLoader.load(WebSocketServletFactory.class).iterator(); if (factories.hasNext()) { baseFactory = factories.next(); } else { // Load the default class if ServiceLoader mechanism isn't valid in this environment. (such as OSGi) ClassLoader loader = Thread.currentThread().getContextClassLoader(); @SuppressWarnings("unchecked") Class wssf = (Class)loader .loadClass("org.eclipse.jetty.websocket.server.WebSocketServerFactory"); baseFactory = wssf.newInstance(); } factory = baseFactory.createFactory(policy); configure(factory); factory.init(); } catch (Exception x) { throw new ServletException(x); } } /** * @see javax.servlet.http.HttpServlet#service(javax.servlet.http.HttpServletRequest, javax.servlet.http.HttpServletResponse) */ @Override protected void service(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { if (factory.isUpgradeRequest(request,response)) { // We have an upgrade request if (factory.acceptWebSocket(request,response)) { // We have a socket instance created return; } // If we reach this point, it means we had an incoming request to upgrade // but it was either not a proper websocket upgrade, or it was possibly rejected // due to incoming request constraints (controlled by WebSocketCreator) if (response.isCommitted()) { // not much we can do at this point. return; } } // All other processing super.service(request,response); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy