I am using OpenShift and WildFly 8.2.1 final to implement the new HTML5 websocket. I used this tutorial to set this project up.
Whenever I open my MyTest.html, this is what the JavaScript logs:
JS: Server Connected...
JS: Server Disconnected...
The server connects and then immediately disconnects. Why? What am I doing wrong? Is there something that I am missing?
Here is mode code -->
serverendpoint.java
package testing;
import javax.websocket.OnClose;
import javax.websocket.OnError;
import javax.websocket.OnMessage;
import javax.websocket.OnOpen;
import javax.websocket.server.ServerEndpoint;
@ServerEndpoint("/serverendpoint")
public class serverendpoint {
@OnOpen
public void handleOpen () {
System.out.println("JAVA: Client is now connected...");
}
@OnMessage
public String handleMessage (String message) {
System.out.println("JAVA: Received from client: "+ message);
String replyMessage = "echo "+ message;
System.out.println("JAVA: Send to client: "+ replyMessage);
return replyMessage;
}
@OnClose
public void handleClose() {
System.out.println("JAVA: Client is now disconnected...");
}
@OnError
public void handleError (Throwable t) {
t.printStackTrace();
}
}
MyTest.html:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>My WS Website</title>
</head>
<body>
<form>
<input id="textMessage" type="text">
<input onclick="sendMessage();" value="Send Message" type="button">
</form>
<br>
<textarea id="messageTextArea" rows="10" cols="50"></textarea>
<script type="text/javascript">
var wsUri = "ws://" + document.location.hostname + ":8000" + document.location.pathname + "serverendpoint";
var webSocket = new WebSocket(wsUri);
var messageTextArea = document.getElementById("messageTextArea");
webSocket.onopen = function(message) { processOpen(message);};
webSocket.onmessage = function(message) { processMessage(message);};
webSocket.onclose = function(message) { processClose(message);};
webSocket.onerror = function(message) { processError(message);};
function processOpen (message) {
messageTextArea.value += "JS: Server Connected..."+"\n";
}
function processMessage(message) {
messageTextArea.value += "JS: Receive from Server ==> "+message.data+"\n";
}
function sendMessage () {
if (textMessage.value !="close") {
webSocket.send(textMessage.value);
messageTextArea.value += "JS: Send to Server ==> "+textMessage.value+"\n";
textMessage.value="";
} else webSocket.close();
}
function processClose(message) {
webSocket.send("JS: Client disconnected...")
messageTextArea.value += "JS: Server Disconnected..."+"\n";
}
function processError (message) {
messageTextArea.value += "JS: error ..."+"\n";
}
</script>
</body>
</html>
And the pom.xml file:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>testing</groupId>
<artifactId>testing</artifactId>
<packaging>war</packaging>
<version>1.0-SNAPSHOT</version>
<name>testing</name>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
</properties>
<dependencies>
<dependency>
<groupId>javax</groupId>
<artifactId>javaee-api</artifactId>
<version>7.0</version>
<scope>provided</scope>
</dependency>
</dependencies>
<profiles>
<profile>
<!-- When built in OpenShift the 'openshift' profile will be used when invoking mvn. -->
<!-- Use this profile for any OpenShift specific customization your app will need. -->
<!-- By default that is to put the resulting archive into the 'deployments' folder. -->
<!-- http://maven.apache.org/guides/mini/guide-building-for-different-environments.html -->
<id>openshift</id>
<build>
<finalName>testing</finalName>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-war-plugin</artifactId>
<version>2.3</version>
<configuration>
<failOnMissingWebXml>false</failOnMissingWebXml>
<outputDirectory>deployments</outputDirectory>
<warName>ROOT</warName>
</configuration>
</plugin>
</plugins>
</build>
</profile>
</profiles>
</project>
Thank you for your help!