Skip to content


Subversion checkout URL

You can clone with
Download ZIP
WebSockets for JBoss AS7
Failed to load latest commit information.
src Fixed #6 so the response header Sec-WebSocket-Protocol is set to null
.gitignore add .gitignore fix README
pom.xml refactor

WebSockets for JBoss AS 7.1.2+

NOTE: This does not currently work on versions of AS older than 7.1.2. It also requires use of the Apache Portable Runtime connector (APR). This limitation will be addressed in a future version of AS.

To Configure APR in JBoss AS 7.1.x:

  1. In domain/configuration/domain.xml: Change Line:

     <subsystem xmlns="urn:jboss:domain:web:1.1" default-virtual-server="default-host" native="false">           


     <subsystem xmlns="urn:jboss:domain:web:1.1" default-virtual-server="default-host" native="true">
  2. Okay, done.

Using the WebsocketServlet:

Once AS 7.1.2+ is configured as specified above, using websockets is as simple as implementing a Servlet which extends and implements its abstract methods. You map the servlet as you normally would, and that servlet mapping will become the upgradable WebSocket path.

Example Implementation:

public class MyWebSocketServlet extends WebSocketServlet {

  protected void onSocketOpened(WebSocket socket) throws IOException {
    System.out.println("Websocket opened :)");

  protected void onSocketClosed(WebSocket socket) throws IOException {
    System.out.println("Websocket closed :(");

  protected void onReceivedFrame(WebSocket socket) throws IOException {
    final Frame frame = socket.readFrame();
    if (frame instanceof TextFrame) {
      final String text = ((TextFrame) frame).getText();
      if ("Hello".equals(text)) {
        socket.writeFrame(TextFrame.from("Hey, there!"));


  1. Message fragmentation is not yet supported.

Known Compatibility

  • Confirmed Working:
    • Chrome 18
    • Firefox 11
    • Safari 5.1
    • MobileSafari on iOS 5.1

Want to Contribute?

Just fork.

Something went wrong with that request. Please try again.