java.net.SocketException: Connection reset by peer. In custom twitch bot

148
22 мая 2019, 03:10

Я создал кастомного твич бота с использованием библиотеки cavariux. Вызвал по очереди методы в main классе.

    bot.setOauth_Key("oauth:key_Value");
    bot.connect();
    bot.joinChannel(channel.toString());
    bot.start();

Примерно один из 5-6 запусков бота сопровождается ошибкой java.net.SocketException: Connection reset by peer. Стек трейс указывает на то, что ошибка начинается в этой строке.

while ((line = this.reader.readLine( )) != null && !stopped)

класса TwitchBot в методе start(). Никаким образом эту библиотеку не изменял кроме добавления кодировки в метод connect(String ip, int port)

this.writer = new BufferedWriter(new OutputStreamWriter(socket.getOutputStream(), StandardCharsets.UTF_8));
this.reader = new BufferedReader(new InputStreamReader(socket.getInputStream(), StandardCharsets.UTF_8));

Тестил у некоторых людей на компьютере своего бота, у некоторых ошибка происходит чаще. Метод start() класса TwitchBоt.

public final void start()
    {
        if (isRunning()) return;
        String line = "";
        stopped = false;
        try {
            while ((line = this.reader.readLine( )) != null && !stopped) {
                if (line.toLowerCase( ).startsWith("ping")) {
                    LOGGER.log(Level.INFO,"> PING");
                    LOGGER.log(Level.INFO,"< PONG " + line.substring(5));
                    this.writer.write("PONG " + line.substring(5) + "\r\n");
                    this.writer.flush();
                } else if (line.contains("PRIVMSG"))
                {
                    String str[];
                    str = line.split("!");
                    final User msg_user = User.getUser(str[0].substring(1, str[0].length()));
                    str = line.split(" ");
                    Channel msg_channel;
                    msg_channel = Channel.getChannel(str[2], this);
                    String msg_msg = line.substring((str[0].length() + str[1].length() + str[2].length() + 4), line.length());
                    LOGGER.log(Level.INFO,"> " + msg_channel + " | " + msg_user + " >> " +  msg_msg);
                    if (msg_msg.startsWith(commandTrigger))
                        onCommand(msg_user, msg_channel, msg_msg.substring(1));
                    if (msg_user.toString().equals("jtv") && msg_msg.contains("now hosting")) {
                        String hoster = msg_msg.split(" ")[0];
                        onHost(User.getUser(hoster), msg_channel);
                    }
                    onMessage(msg_user, msg_channel, msg_msg);
                } else if (line.contains(" JOIN ")) {
                    String[] p = line.split(" ");
                    String[] pd = line.split("!");
                    if (p[1].equals("JOIN"))
                        userJoins(User.getUser(pd[0].substring(1)), Channel.getChannel(p[2], this));
                } else if (line.contains(" PART ")) {
                    String[] p = line.split(" ");
                    String[] pd = line.split("!");
                    if (p[1].equals("PART"))
                        userParts(User.getUser(pd[0].substring(1)), Channel.getChannel(p[2], this));
                } else if (line.contains(" WHISPER ")) {
                    String[] parts = line.split(":");
                    final User wsp_user = User.getUser(parts[1].split("!")[0]);
                    String message = parts[2];
                    onWhisper(wsp_user, message);
                } else if (line.startsWith(":tmi.twitch.tv ROOMSTATE")) {
                } else if (line.startsWith(":tmi.twitch.tv NOTICE"))
                {
                    String[] parts = line.split(" ");
                    if (line.contains("This room is now in slow mode. You may send messages every"))
                    {
                        LOGGER.log(Level.INFO,"> Chat is now in slow mode. You can send messages every " + parts[15] + " sec(s)!");
                    } else if (line.contains("subscribers-only mode")) {
                        if (line.contains("This room is no longer"))
                            LOGGER.log(Level.INFO,"> The room is no longer Subscribers Only!");
                        else
                            LOGGER.log(Level.INFO,"> The room has been set to Subscribers Only!");
                    } else {
                        LOGGER.log(Level.INFO,line);
                    }
                } else if (line.startsWith(":jtv MODE "))
                {
                    String[] p = line.split(" ");
                    if (p[3].equals("+o")) {
                        LOGGER.log(Level.INFO,"> +o " + p[4]);
                    } else {
                        LOGGER.log(Level.INFO,"> -o " + p[4]);
                    }
                } else if (line.toLowerCase().contains("disconnected"))
                {
                    LOGGER.log(Level.INFO, line);
                    this.connect();
                } else
                {
                    LOGGER.log(Level.INFO,"> " + line);
                }
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

метод connect() класса TwitchBot

public void connect(String ip, int port)
    {
        if (isRunning()) return;
        try{
            if (user == null || user == "")
            {
                LOGGER.log(Level.SEVERE, "Please select a valid Username");
                System.exit(1);
                return;
            }
            if (oauth_key == null || oauth_key == "")
            {
                LOGGER.log(Level.SEVERE,"Please select a valid Oauth_Key");
                System.exit(2);
                return;
            }
            @SuppressWarnings("resource")
            Socket socket = new Socket(ip, port);
            this.writer = new BufferedWriter(new OutputStreamWriter(socket.getOutputStream(), StandardCharsets.UTF_8));
            this.reader = new BufferedReader(new InputStreamReader(socket.getInputStream(),StandardCharsets.UTF_8));
            this.writer.write("PASS " + oauth_key + "\r\n");
            this.writer.write("NICK " + user + "\r\n");
            this.writer.write("USER " + this.getVersion() + " \r\n");
            this.writer.write("CAP REQ :twitch.tv/commands \r\n");
            this.writer.write("CAP REQ :twitch.tv/membership \r\n");
            this.writer.flush();
            String line = "";
            while ((line = this.reader.readLine()) != null)
            {
                 if (line.indexOf("004") >= 0) {
                        LOGGER.log(Level.INFO,"Connected >> " + user + " ~ irc.twitch.tv");
                        break;
                    }else {
                        LOGGER.log(Level.INFO,line);
                    }
            }
        } catch (IOException e)
        {
            e.printStackTrace();
        }
    }

Заранее благодарен за помощь.

READ ALSO
Java в чем смысл инструментов для сборки [закрыт]

Java в чем смысл инструментов для сборки [закрыт]

Я как понял, если я хочу скомпилировать код, в котором используются различные сторонние библиотеки, то мне необходимо будет писать кучу доппараметров,...

135
Как удалить слово из файла

Как удалить слово из файла

Программа находит длинное слово в файле, подскажите как его можно удалить?

156
бинарное дерево Java, метод clear()

бинарное дерево Java, метод clear()

Реализую бинарное дерево, и нужно переопределить метод clear(), который удалит все элементы из коллекцииВопрос - правильно ли я делаю (пикча...

168
SQLite прочитать базу после очистки кэша

SQLite прочитать базу после очистки кэша

У меня есть Sqlite база , которую я читаю из файла AssetsВот встал вопрос как правильно обойти один момент

185