Перестали приходить голоса L2Top с сайта

Shtebon

Единомышленник
Пользователь
Сообщения
61
Розыгрыши
0
Репутация
0
Реакции
1
Баллы
115
Хроники
  1. Chaotic Throne: High Five
Исходники
Отсутствуют
Сборка
Rebellion
Перестали приходить голоса L2Top с сайта. Месяц назад всё работало.

файл l2top_vote-web.txt выглядел вот так:

Сейчас выглядит вот так:

на серве ничего не трогал и вдруг перестало работать.. Что посоветуете?
 
прикрутили cloudflare, вот ты проверку на бота и не проходишь, разрабы конечно сверхразумы
 
прикрутили cloudflare, вот ты проверку на бота и не проходишь, разрабы конечно сверхразумы
лечится как то? я по прямой ссылке захожу? там ничего не изменилось, статистика голосов пополняется
 
Последнее редактирование модератором:
они отключили http поменяй в настройках на https
 
Не нашли решение?
http на https менять бесполезно.
 
Покажите что вы отправляете, начиная прямо с первой строки
Например:
1676058219416.png
 
Запрещено публиковать исходный код без BB-кода — CODE
Вы об этом?

Java:
try
        {
            s = new Socket("l2top.ru", 80);

            s.setSoTimeout(30000); //Таймут 30 секунд
            String request = "GET " + address + " HTTP/1.1\r\n" +
                    "User-Agent: http:\\" + ConfigSystem.get("L2TopServerAddress") + " server\r\n" +
                    "Host: http:\\" + ConfigSystem.get("L2TopServerAddress") + " \r\n" +
                    "Accept: */*\r\n" +
                    "Connection: close\r\n" +
                    "\r\n";
            s.getOutputStream().write(request.getBytes());
            BufferedReader in = new BufferedReader(new InputStreamReader(s.getInputStream(), "Cp1251"));

            for(String line = in.readLine(); line != null; line = in.readLine())
            {
                buf.append(line);
                buf.append("\r\n");
            }
            s.close();
        }

Ничего нового никто не отправляет, изменения произошли не на серверах, а у L2Top
 
Последнее редактирование модератором:
Попробуйте порт в new Socket сменить на 443, далее по коду http на https (только GET HTTP 1/1 не трогайте). Возможно это что-то даст.

з.ы. а что у вас в + address + ? там тоже ставьте https
 
Запрещено публиковать исходный код без BB-кода — CODE
К сожалению, финт ушами не вышел. Все так же получаем результат:

Код:
HTTP/1.1 400 Bad Request
Server: cloudflare
Date: Fri, 10 Feb 2023 20:02:54 GMT
Content-Type: text/html
Content-Length: 155
Connection: close
CF-RAY: -

<html>
<head><title>400 Bad Request</title></head>
<body>
<center><h1>400 Bad Request</h1></center>
<hr><center>cloudflare</center>
</body>
</html>

В "address" так же стоит ...
Видать, действительно мешается cloudflare на той стороне провода.
 
Последнее редактирование модератором:
Вероятно стоит посмотреть в сторону другого способа получения данных.

1676060012573.png
 
Перестали приходить голоса L2Top с сайта. Месяц назад всё работало.

файл l2top_vote-web.txt выглядел вот так:

Сейчас выглядит вот так:

на серве ничего не трогал и вдруг перестало работать.. Что посоветуете?
Напишите мне в скайп, попробую решить проблему
Vladimir18962
 
Напишите мне в скайп, попробую решить проблему
Vladimir18962
нету скайпа. есть вк и телеграм

Вот нашёл исходники своего сервака
Форматирование (BB-код):
package l2r.gameserver.instancemanager;

import java.io.BufferedReader;
import java.io.File;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.Socket;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.Calendar;
import java.util.NoSuchElementException;
import java.util.StringTokenizer;
import java.util.logging.Logger;

import l2r.commons.dbutils.DbUtils;
import l2r.gameserver.Config;
import l2r.gameserver.ThreadPoolManager;
import l2r.gameserver.database.DatabaseFactory;
import l2r.gameserver.model.GameObjectsStorage;
import l2r.gameserver.model.Player;
import l2r.gameserver.utils.Log;

public class L2TopManager
{
    private static Logger _log = Logger.getLogger(L2TopManager.class.getName());

    private static final String SELECT_PLAYER_OBJID = "SELECT obj_Id FROM characters WHERE char_name=?";
    private static final String SELECT_CHARACTER_MMOTOP_DATA = "SELECT * FROM character_l2top_votes WHERE id=? AND date=? AND multipler=?";
    private static final String INSERT_L2TOP_DATA = "INSERT INTO character_l2top_votes (date, id, nick, multipler) values (?,?,?,?)";
    private static final String DELETE_L2TOP_DATA = "DELETE FROM character_l2top_votes WHERE date<?";
    private static final String SELECT_MULTIPLER_L2TOP_DATA = "SELECT multipler FROM character_l2top_votes WHERE id=? AND has_reward=0";
    private static final String UPDATE_L2TOP_DATA = "UPDATE character_l2top_votes SET has_reward=1 WHERE id=?";

    private final static String voteWeb = Config.DATAPACK_ROOT + "/data/l2top_vote-web.txt";
    private final static String voteSms = Config.DATAPACK_ROOT + "/data/l2top_vote-sms.txt";

    private static L2TopManager _instance;

    public static L2TopManager getInstance()
    {
        if(_instance == null && Config.L2_TOP_MANAGER_ENABLED)
            _instance = new L2TopManager();
        return _instance;
    }

    public L2TopManager()
    {
        ThreadPoolManager.getInstance().scheduleAtFixedRate(new ConnectAndUpdate(), Config.L2_TOP_MANAGER_INTERVAL, Config.L2_TOP_MANAGER_INTERVAL);
        ThreadPoolManager.getInstance().scheduleAtFixedRate(new Clean(), Config.L2_TOP_MANAGER_INTERVAL, Config.L2_TOP_MANAGER_INTERVAL);
        ThreadPoolManager.getInstance().scheduleAtFixedRate(new GiveReward(), Config.L2_TOP_MANAGER_INTERVAL, Config.L2_TOP_MANAGER_INTERVAL);
        _log.info("L2TopManager: loaded sucesfully");
    }

    private void update()
    {
        String out_sms = getPage(Config.L2_TOP_SMS_ADDRESS);
        String out_web = getPage(Config.L2_TOP_WEB_ADDRESS);

        File sms = new File(voteSms);
        File web = new File(voteWeb);
        FileWriter SaveWeb = null;
        FileWriter SaveSms = null;

        try
        {
            SaveSms = new FileWriter(sms);
            SaveSms.write(out_sms);
            SaveWeb = new FileWriter(web);
            SaveWeb.write(out_web);
        }

        catch(IOException e)
        {
            e.printStackTrace();
        }

        finally
        {
            try
            {
                if(SaveSms != null)
                    SaveSms.close();
                if(SaveWeb != null)
                    SaveWeb.close();
            }
            catch(Exception e1)
            {
                e1.printStackTrace();
            }
        }
    }

    private static String getPage(String address)
    {
        StringBuffer buf = new StringBuffer();
        Socket s;
        try
        {
            s = new Socket("l2top.ru", 80);

            s.setSoTimeout(30000);
            String request = "GET " + address + " HTTP/1.1\r\n" + "User-Agent: http:\\" + Config.EXTERNAL_HOSTNAME + " server\r\n" + "Host: http:\\" + Config.EXTERNAL_HOSTNAME + " \r\n" + "Accept: */*\r\n" + "Connection: close\r\n" + "\r\n";
            s.getOutputStream().write(request.getBytes());
            BufferedReader in = new BufferedReader(new InputStreamReader(s.getInputStream(), "Cp1251"));

            for(String line = in.readLine(); line != null; line = in.readLine())
            {
                buf.append(line);
                buf.append("\r\n");
            }
            s.close();
        }
        catch(Exception e)
        {
            buf.append("Connection error");
        }
        return buf.toString();
    }

    private void parse(boolean sms)
    {
        try
        {
            BufferedReader in = new BufferedReader(new FileReader(sms ? voteSms : voteWeb));
            String line = in.readLine();
            while(line != null)
            {
                Calendar cal = Calendar.getInstance();
                int year = cal.get(Calendar.YEAR);
                if(line.startsWith("" + year))
                    try
                    {
                        StringTokenizer st = new StringTokenizer(line, "\t -:");
                        cal.set(Calendar.YEAR, Integer.parseInt(st.nextToken()));
                        cal.set(Calendar.MONTH, Integer.parseInt(st.nextToken()));
                        cal.set(Calendar.DAY_OF_MONTH, Integer.parseInt(st.nextToken()));
                        cal.set(Calendar.HOUR_OF_DAY, Integer.parseInt(st.nextToken()));
                        cal.set(Calendar.MINUTE, Integer.parseInt(st.nextToken()));
                        cal.set(Calendar.SECOND, Integer.parseInt(st.nextToken()));
                        cal.set(Calendar.MILLISECOND, 0);
                        String nick = st.nextToken();
                        int mult = 1;
                        if(sms)
                            mult = Integer.parseInt(new StringBuffer(st.nextToken()).delete(0, 1).toString());
                        if(cal.getTimeInMillis() + Config.L2_TOP_SAVE_DAYS * 86400000 > System.currentTimeMillis())
                            checkAndSaveFromDb(cal.getTimeInMillis(), nick, mult);
                    }
                    catch(NoSuchElementException nsee)
                    {
                        continue;
                    }
                line = in.readLine();
            }
        }
        catch(Exception e)
        {
            e.printStackTrace();
        }
    }

    private synchronized void clean()
    {
        Calendar cal = Calendar.getInstance();
        cal.add(Calendar.DAY_OF_YEAR, -Config.L2_TOP_SAVE_DAYS);
        Connection con = null;
        PreparedStatement statement = null;
        try
        {
            con = DatabaseFactory.getInstance().getConnection();
            statement = con.prepareStatement(DELETE_L2TOP_DATA);
            statement.setLong(1, cal.getTimeInMillis());
            statement.execute();
        }
        catch(SQLException e)
        {
            e.printStackTrace();
        }
        finally
        {
            DbUtils.closeQuietly(con, statement);
        }
    }

    private synchronized void checkAndSaveFromDb(long date, String nick, int mult)
    {
        Connection con = null;
        PreparedStatement selectObjectStatement = null, selectL2topStatement = null, insertStatement = null;
        ResultSet rsetObject = null, rsetL2top = null;
        try
        {
            con = DatabaseFactory.getInstance().getConnection();
            selectObjectStatement = con.prepareStatement(SELECT_PLAYER_OBJID);
            selectObjectStatement.setString(1, nick);
            rsetObject = selectObjectStatement.executeQuery();
            int objId = 0;
            if(rsetObject.next())
                objId = rsetObject.getInt("obj_Id");
            if(objId > 0)
            {
                selectL2topStatement = con.prepareStatement(SELECT_CHARACTER_MMOTOP_DATA);
                selectL2topStatement.setInt(1, objId);
                selectL2topStatement.setLong(2, date);
                selectL2topStatement.setInt(3, mult);
                rsetL2top = selectL2topStatement.executeQuery();
                if(!rsetL2top.next())
                {
                    insertStatement = con.prepareStatement(INSERT_L2TOP_DATA);
                    insertStatement.setLong(1, date);
                    insertStatement.setInt(2, objId);
                    insertStatement.setString(3, nick);
                    insertStatement.setInt(4, mult);
                    insertStatement.execute();
                    insertStatement.close();
                }
            }
        }
        catch(SQLException e)
        {
            e.printStackTrace();
        }
        finally
        {
            DbUtils.closeQuietly(con, selectObjectStatement, rsetObject);
            DbUtils.closeQuietly(con, selectL2topStatement, rsetL2top);
            DbUtils.closeQuietly(con, insertStatement);
        }
    }

    private synchronized void giveReward()
    {
        Connection con = null;
        PreparedStatement selectMultStatement = null, updateStatement = null;
        ResultSet rsetMult = null;
        try
        {
            con = DatabaseFactory.getInstance().getConnection();
            for(Player player : GameObjectsStorage.getAllPlayers())
            {
                int objId = player.getObjectId();
                int mult = 0;
                selectMultStatement = con.prepareStatement(SELECT_MULTIPLER_L2TOP_DATA);
                selectMultStatement.setInt(1, objId);
                rsetMult = selectMultStatement.executeQuery();
                while(rsetMult.next())
                    mult += rsetMult.getInt("multipler");

                updateStatement = con.prepareStatement(UPDATE_L2TOP_DATA);
                updateStatement.setInt(1, objId);
                updateStatement.executeUpdate();
                if(mult > 0)
                {
                    if(player.getVar("lang@").equalsIgnoreCase("ru"))
                        player.sendMessage("Спасибо за Ваш голос в рейтинге L2Top. C наилучшими пожеланиями " + Config.L2_TOP_SERVER_ADDRESS);
                    else
                        player.sendMessage("Thank you for your vote in L2Top raiting. Best regards " + Config.L2_TOP_SERVER_ADDRESS);
                    for(int i = 0; i < Config.L2_TOP_REWARD.length; i += 2)
                    {
                        if(Config.L2_TOP_REWARD == -100) // PC Bang
                        {
                            player.addPcBangPoints((Config.L2_TOP_REWARD[i + 1] * mult), false);
                            Log.add(player.getName() + " | " + player.getObjectId() + " | L2Top reward item ID | " + Config.L2_TOP_REWARD + " | L2Top reward count | " + (Config.L2_TOP_REWARD[i + 1] * mult) + " |", "l2top");
                        }
                        else if(Config.L2_TOP_REWARD == -200) // Clan reputation
                        {
                            player.getClan().incReputation((Config.L2_TOP_REWARD[i + 1] * mult));
                            Log.add(player.getName() + " | " + player.getObjectId() + " | L2Top reward item ID | " + Config.L2_TOP_REWARD + " | L2Top reward count | " + (Config.L2_TOP_REWARD[i + 1] * mult) + " |", "l2top");
                        }
                        else if(Config.L2_TOP_REWARD == -300) // Fame
                        {
                            player.setFame(player.getFame() + (Config.L2_TOP_REWARD[i + 1] * mult));
                            Log.add(player.getName() + " | " + player.getObjectId() + " | L2Top reward item ID | " + Config.L2_TOP_REWARD + " | L2Top reward count | " + (Config.L2_TOP_REWARD[i + 1] * mult) + " |", "l2top");
                        }
                        else
                        {
                            player.getInventory().addItem(Config.L2_TOP_REWARD, (Config.L2_TOP_REWARD[i + 1] * mult));
                            Log.add(player.getName() + " | " + player.getObjectId() + " | L2Top reward item ID | " + Config.L2_TOP_REWARD + " | L2Top reward count | " + (Config.L2_TOP_REWARD[i + 1] * mult) + " |", "l2top");
                        }
                    }
                }
            }
        }
        catch(SQLException e)
        {
            e.printStackTrace();
        }
        finally
        {
            DbUtils.closeQuietly(con, selectMultStatement, rsetMult);
            DbUtils.closeQuietly(con, updateStatement);
        }
    }

    private class ConnectAndUpdate implements Runnable
    {
        @Override
        public void run()
        {
            update();
            parse(true);
            parse(false);
        }
    }

    private class Clean implements Runnable
    {
        @Override
        public void run()
        {
            clean();
        }
    }

    private class GiveReward implements Runnable
    {
        @Override
        public void run()
        {
            giveReward();
        }
    }
}


Сделал вообщем так:
в настройках прописал L2TopWebAddress =
в исходниках прописал s = new Socket("192.168.0.3", 80);
закинул файл l2top.txt на веб сервер (находится на одной машине с игровым сервером)
выставил Apache-2.2+Nginx-1.10 на веб сервере

При заходе с браузера отображается так:

Это логи веб сервера:

Почему от гейм сервера не поступают запросы? в файл l2top_vote-web.txt пишет всё также:
HTTP/1.1 400 Bad Request
Server: cloudflare
Date: Tue, 21 Feb 2023 06:10:35 GMT
Content-Type: text/html
Content-Length: 155
Connection: close
CF-RAY: -

<html>
<head><title>400 Bad Request</title></head>
<body>
<center><h1>400 Bad Request</h1></center>
<hr><center>cloudflare</center>
</body>
</html>
 
Java:
    private static String getPage(String address)
    {
        StringBuffer buf = new StringBuffer();
        
        try
        {
            URL url = new URL( address );
            
            HttpURLConnection req = ( HttpURLConnection ) url.openConnection();
            req.setRequestMethod( "GET" );
            req.connect();
    
            BufferedReader in = new BufferedReader( new InputStreamReader(req.getInputStream(), "CP1251"));

            String line = null;
            while ( ( line = in.readLine() ) != null )
            {
                buf.append(line + "\r\n");
            }
        }
        catch(Exception e)
        {
            buf.append(e.toString());
        }
        
        return buf.toString();
    }

Тест1:
Java:
String web = getPage( "https://l2top.ru/editServ/?adminAct=lastVotes&uid=28053_web&key=3d2fe6fb8588efde6a78bda97d946f23" );

System.out.println( web );
Результат:
Код:
Статистика web голосования для сервера http://totalwar.pro

Тест2:
Java:
String sms = getPage( "https://l2top.ru/editServ/?adminAct=lastVotes&uid=28053_sms&key=3d2fe6fb8588efde6a78bda97d946f23" );

System.out.println( sms );
Результат:
Код:
Статистика sms голосования для сервера http://totalwar.pro
2014-10-04 23:35:26    Stalia    x3
2014-09-10 05:44:00    BornToRise    x1
2014-07-20 14:43:47    TipTop    x1

п.с. - урлы для теста с гитхаба :LOL:
 

    Shtebon

    Баллов: 1
    помог!
Почему от гейм сервера не поступают запросы? в файл l2top_vote-web.txt пишет всё также:
Потому что Cloudflare не дает открыть вам websocket. Переходите к реализации через класс URL.
 
Потому что Cloudflare не дает открыть вам websocket. Переходите к реализации через класс URL.
так а причём тут Cloudflare если сервер делает запрос на мой же веб сервер в локальной сети на тот же IP внутри сети (Open Server 5.2.2)
1679063739909.png
в настройках прописал L2TopWebAddress =
в исходниках прописал s = new Socket("192.168.0.3", 80);
закинул файл l2top.txt на веб сервер (находится на одной машине с игровым сервером)
выставил Apache-2.2+Nginx-1.10 на веб сервере



и один фиг он выдаёт
HTTP/1.1 400 Bad Request
Server: cloudflare
Date: Tue, 21 Feb 2023 06:10:35 GMT
Content-Type: text/html
Content-Length: 155
Connection: close
CF-RAY: -
 
так а причём тут Cloudflare если сервер делает запрос на мой же веб сервер в локальной сети на тот же IP внутри сети (Open Server 5.2.2)
Посмотреть вложение 48404
в настройках прописал L2TopWebAddress =
в исходниках прописал s = new Socket("192.168.0.3", 80);
закинул файл l2top.txt на веб сервер (находится на одной машине с игровым сервером)
выставил Apache-2.2+Nginx-1.10 на веб сервере



и один фиг он выдаёт
HTTP/1.1 400 Bad Request
Server: cloudflare
Date: Tue, 21 Feb 2023 06:10:35 GMT
Content-Type: text/html
Content-Length: 155
Connection: close
CF-RAY: -

при том что вы пытаетесь открыть веб-сокет.
 
Назад
Сверху Снизу