Я использую Tomcat 8 в качестве сервера с моим веб-приложением java, это онлайн-игра с крестиками-ноликами.
У меня настроена конечная точка сервера с использованием класса javax.websocket.Server.ServerEndpoint
, но при попытке импортироватьресурс в нем дает мне NullPointerException
, когда я пытаюсь установить соединение.Это работает нормально, когда я получаю это соединение от моих сервлетов, но только в конечной точке сервера дает мне ноль. Строка с ошибкой прокомментирована ниже:
Также здесь находится хранилище со всем файлом, если это помогает: https://github.com/EduardValentin/TicTacToe-WebApp---Java-Servlets/tree/master/Web%20Client/src/java
@ApplicationScoped
@ServerEndpoint("/websocketendpoint")
public class MatchMaker {
private final SessionHandler sessionHandler = SessionHandler.getInstance();
@Resource(name = "jdbc/TicTacToeDb")
private DataSource dbResource;
@OnOpen
public void onOpen(Session session,EndpointConfig config) throws IOException{
System.out.println("Open Connection ...");
}
@OnClose
public void onClose(){
System.out.println("Close Connection ...");
}
@OnMessage
public void onMessage(String message,Session session) throws IOException, SQLException{
System.out.println("Message from the client: " + message);
String[] parts = message.split("\\|");
String typeOfOperation = parts[0];
String from = null;
System.out.println(typeOfOperation);
switch(typeOfOperation) {
case "JOIN":
String playerUsername = parts[1];
System.out.println(playerUsername + " yayaya");
PlayerModel newPlayer = new PlayerModel(playerUsername,session);
if(sessionHandler.playersInQueue() == false){
// Nu sunt jucatori care asteapta in coada ,deci nu are cu cine sa joace
sessionHandler.addInQueue(newPlayer);
} else {
PlayerModel opponent = sessionHandler.removeFromQueue(); // Ia cel mai vechi jucator ce asteapta la coada
opponent.setOpponent(playerUsername);
newPlayer.setOpponent(opponent.getUsername());
sessionHandler.addPlaying(newPlayer, opponent);
String first;
if(Math.random() >= 0.5) {
first = newPlayer.getUsername();
} else {
first = opponent.getUsername();
}
sessionHandler.sendMessageTo(playerUsername,"PLAYING|"+opponent.getUsername()+"|"+first);
sessionHandler.sendMessageTo(opponent.getUsername(),"PLAYING|"+newPlayer.getUsername()+"|"+first);
}
break;
case "MOVE" :
from = parts[1];
String to = parts[2];
String squareNr = parts[3];
System.out.println("From:" + from + " | To: " + to + " | Move: " + squareNr);
sessionHandler.sendMessageTo(to, "MOVE|"+squareNr);
break;
case "WON" :
from = parts[1];
to = parts[2];
System.out.println(from + " won the game.");
// we need to save the game to database
String insertQuery = "INSERT INTO games(won,lost,game_date) VALUES (?,?,TO_DATE(?,'day-mon-yyyy hh24:mi:ss'))";
try(Connection con = (Connection) dbResource.getConnection()){ // HERE I GET NULL POINTER EXCEPTION WHEN I TRY TO GET CONNECTION
PreparedStatement ps = con.prepareStatement(insertQuery);
ps.setString(1, from);
ps.setString(2, to);
DateFormat dateFormat = new SimpleDateFormat("dd-mm-yyyy HH:mm:ss");
Date date = new Date();
System.out.println(dateFormat.format(date)); //2016/11/16 12:08:43
ps.setString(3,dateFormat.format(date));
ps.executeUpdate();
ps.close();
}
sessionHandler.removeFromPlaying(to);
sessionHandler.removeFromPlaying(from);
break;
default :
System.out.println("Invalid message");
}
}
@OnError
public void onError(Throwable e){
e.printStackTrace();
}
}
А вот мой context.xml:
<?xml version="1.0" encoding="UTF-8"?>
<Context path="/TicTacToeWeb">
<Resource name="jdbc/TicTacToeDb" auth="Container"
type="javax.sql.DataSource"
username="admin" password="superduperpwd"
driverClassName="com.mysql.jdbc.Driver"
url="jdbc:mysql://localhost/tictactoedb" maxActive="15" maxIdle="3" />
Редактировать: похоже, что я не использую пул соединений и просто подключаюсь из драйвераменеджер вроде:
try {
Class.forName("com.mysql.jdbc.Driver");
} catch(ClassNotFoundException e) {
System.out.println("Class not found "+ e);
}
System.out.println("JDBC Class found");
try( Connection con = (Connection) DriverManager.getConnection (
"jdbc:mysql://localhost/tictactoedb","admin", "superduperpwd")){
PreparedStatement ps = con.prepareStatement(insertQuery);
ps.setString(1, from);
ps.setString(2, to);
DateFormat dateFormat = new SimpleDateFormat("dd-mm-yyyy HH:mm:ss");
Date date = new Date();
System.out.println(dateFormat.format(date)); //2016/11/16 12:08:43
ps.setString(3,dateFormat.format(date));
ps.executeUpdate();
ps.close();
}
он работает, но мне интересно, почему он не может дать мне соединение через пул соединений.Кто-нибудь знает?