@Override
protected void processIncomingMessage(String message) {
// Выводим текст сообщения в консоль
ConsoleHelper.writeMessage(message);
// Отделяем отправителя от текста сообщения
String userNameDelimiter = ": ";
String[] split = message.split(userNameDelimiter);
if (split.length != 2) return;
String messageWithoutUserName = split[1];
// Подготавливаем формат для отправки даты согласно запросу
String format = null;
switch (messageWithoutUserName) {
case "дата":
format = "d.MM.YYYY";
break;
case "день":
format = "d";
break;
case "месяц":
format = "MMMM";
break;
case "год":
format = "YYYY";
break;
case "время":
format = "H:mm:ss";
break;
case "час":
format = "H";
break;
case "минуты":
format = "m";
break;
case "секунды":
format = "s";
break;
}
if (format != null) {
String answer = new SimpleDateFormat(format).format(Calendar.getInstance().getTime());
BotClient.this.sendTextMessage("Информация для " + split[0] + ": " + answer);
}
}
это ответ из "правильного решения", у меня все то же самое как по мне, почему валидатор не принимает вывод на экран в моем случае?
клас BotClient
строка 23package com.javarush.task.task30.task3008;
import java.io.IOException;
import java.net.ServerSocket;
import java.net.Socket;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
public class Server {
private static Map<String, Connection> connectionMap = new ConcurrentHashMap<>();
public static void main(String[] args) {
ConsoleHelper.writeMessage("Введите порт сервера:");
int port = ConsoleHelper.readInt();
try (ServerSocket serverSocket = new ServerSocket(port)) {
ConsoleHelper.writeMessage("Чат сервер запущен.");
while (true) {
// Ожидаем входящее соединение и запускаем отдельный поток при его принятии
Socket socket = serverSocket.accept();
new Handler(socket).start();
}
} catch (Exception e) {
ConsoleHelper.writeMessage("Произошла ошибка при запуске или работе сервера.");
}
}
private static class Handler extends Thread {
private Socket socket;
public Handler(Socket socket) {
this.socket = socket;
}
@Override
public void run() {
ConsoleHelper.writeMessage("Установлено новое соединение с " + socket.getRemoteSocketAddress());
String userName = null;
try (Connection connection = new Connection(socket)) {
userName = serverHandshake(connection);
// Сообщаем всем участникам, что присоединился новый участник
sendBroadcastMessage(new Message(MessageType.USER_ADDED, userName));
// Сообщаем новому участнику о существующих участниках
notifyUsers(connection, userName);
// Обрабатываем сообщения пользователей
serverMainLoop(connection, userName);
} catch (IOException | ClassNotFoundException e) {
ConsoleHelper.writeMessage("Ошибка при обмене данными с " + socket.getRemoteSocketAddress());
}
if (userName != null) {
connectionMap.remove(userName);
sendBroadcastMessage(new Message(MessageType.USER_REMOVED, userName));
}
ConsoleHelper.writeMessage("Соединение с " + socket.getRemoteSocketAddress() + " закрыто.");
}
private String serverHandshake(Connection connection) throws IOException, ClassNotFoundException {
while (true) {
connection.send(new Message(MessageType.NAME_REQUEST));
Message message = connection.receive();
if (message.getType() != MessageType.USER_NAME) {
ConsoleHelper.writeMessage("Получено сообщение от " + socket.getRemoteSocketAddress() + ". Тип сообщения не соответствует протоколу.");
continue;
}
String userName = message.getData();
if (userName.isEmpty()) {
ConsoleHelper.writeMessage("Попытка подключения к серверу с пустым именем от " + socket.getRemoteSocketAddress());
continue;
}
if (connectionMap.containsKey(userName)) {
ConsoleHelper.writeMessage("Попытка подключения к серверу с уже используемым именем от " + socket.getRemoteSocketAddress());
continue;
}
connectionMap.put(userName, connection);
connection.send(new Message(MessageType.NAME_ACCEPTED));
return userName;
}
}
private void notifyUsers(Connection connection, String userName) throws IOException {
for (String name : connectionMap.keySet()) {
if (name.equals(userName))
continue;
connection.send(new Message(MessageType.USER_ADDED, name));
}
}
private void serverMainLoop(Connection connection, String userName) throws IOException, ClassNotFoundException {
while (true) {
Message message = connection.receive();
if (message.getType() == MessageType.TEXT) {
String data = message.getData();
sendBroadcastMessage(new Message(MessageType.TEXT, userName + ": " + data));
} else {
ConsoleHelper.writeMessage("Получено сообщение от " + socket.getRemoteSocketAddress() + ". Тип сообщения не соответствует протоколу.");
}
}
}
}
public static void sendBroadcastMessage(Message message) {
// Рассылаем сообщение по всем соединениям
for (Connection connection : connectionMap.values()) {
try {
connection.send(message);
} catch (IOException e) {
ConsoleHelper.writeMessage("Не смогли отправить сообщение " + connection.getRemoteSocketAddress());
}
}
}
}