// --------------------------------------------------------------------------- // jWebSocket - Copyright (c) 2010 Innotrade GmbH // --------------------------------------------------------------------------- // This program is free software; you can redistribute it and/or modify it // under the terms of the GNU Lesser General Public License as published by the // Free Software Foundation; either version 3 of the License, or (at your // option) any later version. // This program is distributed in the hope that it will be useful, but WITHOUT // ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or // FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for // more details. // You should have received a copy of the GNU Lesser General Public License along // with this program; if not, see <http://www.gnu.org/licenses/lgpl.html>. // --------------------------------------------------------------------------- package org.jwebsocket.appserver; import java.io.IOException; import java.io.PrintWriter; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.apache.log4j.Logger; import org.jwebsocket.api.WebSocketPacket; import org.jwebsocket.factory.JWebSocketFactory; import org.jwebsocket.kit.WebSocketServerEvent; import org.jwebsocket.listener.WebSocketServerTokenEvent; import org.jwebsocket.listener.WebSocketServerTokenListener; import org.jwebsocket.logging.Logging; import org.jwebsocket.server.TokenServer; import org.jwebsocket.token.Token; /** * * @author aschulze */ public class WebSocketDemo extends HttpServlet implements WebSocketServerTokenListener { private static final long serialVersionUID = 1L; private static Logger mLog = null; /** * Processes requests for both HTTP <code>GET</code> and <code>POST</code> methods. * @param request servlet request * @param response servlet response * @throws ServletException if a servlet-specific error occurs * @throws IOException if an I/O error occurs */ protected void processRequest(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { response.setContentType("text/plain;charset=UTF-8"); PrintWriter out = response.getWriter(); try { out.println("This session: " + request.getSession().getId()); out.println("Http sessions: " + WebSocketHttpSessionMerger.getHttpSessionsCSV()); out.println("WebSocket sessions: " + WebSocketHttpSessionMerger.getWebSocketSessionsCSV()); } finally { out.close(); } } @Override public void init() { mLog = Logging.getLogger(WebSocketDemo.class); mLog.info("Adding servlet '" + getClass().getSimpleName() + "' to WebSocket listeners..."); TokenServer lServer = (TokenServer) JWebSocketFactory.getServer("ts0"); if (lServer != null) { lServer.addListener(this); } } @Override public void processOpened(WebSocketServerEvent aEvent) { mLog.info("Opened WebSocket session: " + aEvent.getSession().getSessionId()); // if a new web socket connection has been started, // update the session tables accordingly WebSocketHttpSessionMerger.addWebSocketSession(aEvent.getSession()); } @Override public void processPacket(WebSocketServerEvent aEvent, WebSocketPacket aPacket) { mLog.info("Received WebSocket packet: " + aPacket.getASCII()); } @Override public void processToken(WebSocketServerTokenEvent aEvent, Token aToken) { mLog.info("Received WebSocket token: " + aToken.toString()); } @Override public void processClosed(WebSocketServerEvent aEvent) { mLog.info("Closed WebSocket session: " + aEvent.getSession().getSessionId()); // if a web socket connection has been terminated, // update the session tables accordingly WebSocketHttpSessionMerger.removeWebSocketSession(aEvent.getSession()); } // <editor-fold defaultstate="collapsed" desc="HttpServlet methods. Click on the + sign on the left to edit the code."> /** * Handles the HTTP <code>GET</code> method. * @param request servlet request * @param response servlet response * @throws ServletException if a servlet-specific error occurs * @throws IOException if an I/O error occurs */ @Override protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { processRequest(request, response); } /** * Handles the HTTP <code>POST</code> method. * @param request servlet request * @param response servlet response * @throws ServletException if a servlet-specific error occurs * @throws IOException if an I/O error occurs */ @Override protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { processRequest(request, response); } /** * Returns a short description of the servlet. * @return a String containing servlet description */ @Override public String getServletInfo() { return "Short description"; }// </editor-fold> }