14 посетителей на сайте. Из них:
Пользователи1
Роботы13
Список пользователей
Raf Сейчас на сайте
sergy Был(a) в сети 9 минут назад
Artem Gusarov Был(a) в сети 12 минут назад
Artem UARP Был(a) в сети 15 минут назад
hootan Был(a) в сети 16 минут назад
Hp Hp Был(a) в сети 23 минуты назад
Dato Guliazali195 Был(a) в сети 33 минуты назад
Sergo MSK Был(a) в сети 33 минуты назад
ElephantStore Был(a) в сети 39 минут назад
James_ LP Был(a) в сети 47 минут назад
dava days Был(a) в сети 55 минут назад
сергей белых Был(a) в сети 56 минут назад
Илья Галко Был(a) в сети 1 час назад
андрей старосвеский Был(a) в сети 1 час назад
Печка TV Был(a) в сети 1 час назад
sabanovandre11 Был(a) в сети 1 час назад
Богдан Был(a) в сети 1 час назад
Виталий Ткачев Был(a) в сети 2 часа назад
Артем Папович Был(a) в сети 2 часа назад
Илья Осипов Был(a) в сети 2 часа назад
Patlican Был(a) в сети 2 часа назад
Даниил Девелоп Был(a) в сети 2 часа назад
0987654321 Был(a) в сети 2 часа назад
Юлія Вознюк-Саверіна Был(a) в сети 3 часа назад
Rolepoy Был(a) в сети 3 часа назад
Марк Игоревич Был(a) в сети 4 часа назад
GStar Ink Был(a) в сети 4 часа назад
Barny Black Был(a) в сети 4 часа назад
Ilias Schmitd Был(a) в сети 4 часа назад
Михаил Калашнеков Был(a) в сети 4 часа назад
Gredex ❶ Был(a) в сети 5 часов назад
Руслан Жиналеев Был(a) в сети 5 часов назад
Demon Был(a) в сети 5 часов назад
Дмитрий Лордецкий Был(a) в сети 6 часов назад
Андрей Был(a) в сети 8 часов назад
Максим Был(a) в сети 8 часов назад
Horizon Был(a) в сети 8 часов назад
Микола Был(a) в сети 8 часов назад
Али Был(a) в сети 8 часов назад
Lost Angel Был(a) в сети 8 часов назад
Данил Был(a) в сети 9 часов назад
ДМИТРИЙ Кирпичев Был(a) в сети 9 часов назад
Hazrat Был(a) в сети 9 часов назад
Роман Римар Был(a) в сети 9 часов назад
Был(a) в сети 9 часов назад
monsterkill Был(a) в сети 9 часов назад
Mahmut Был(a) в сети 9 часов назад
Shuher Был(a) в сети 10 часов назад
qwe we Был(a) в сети 10 часов назад
Alexey Badenof Был(a) в сети 10 часов назад
ARSKY Был(a) в сети 10 часов назад
Артем Был(a) в сети 10 часов назад
Danger Karleon Был(a) в сети 10 часов назад
Антон Демин Был(a) в сети 10 часов назад
Стас Глуздеев Был(a) в сети 10 часов назад
Арсений Сергеевич Был(a) в сети 10 часов назад
Александр Скребков Был(a) в сети 10 часов назад
Александр Калашников Был(a) в сети 10 часов назад
Юрій Надольський Был(a) в сети 11 часов назад
Vovka_14YT Михеев Был(a) в сети 11 часов назад
Vait Shop Был(a) в сети 11 часов назад
mimiha Был(a) в сети 11 часов назад
XIOMI REDMI 10 PRO Был(a) в сети 11 часов назад
Список ботов
rambler (13)

Следите за нами!

LUA | Привязка к IP

Описание

Всем привет, мутил привязку, решил поделится с вами
Будем использовать lua + php + MySQL.
Начнем с создания DB.

1. Переходим в ваш сайт.ру/phpmyadmin, создаем базу данных с любым именем, я создам new_db.
2. Создаем таблицу, я назову users, в ней 2 колонки у меня это: code, date. code - будет ключ клиента, date - дата окончания действия ключа.

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

Вот сразу код:

PHP:
<!DOCTYPE html>
<head>
  <title>Auth</title>
  <meta charset="utf-8">
</head>
<body>
  <?php
  $mysqli = new mysqli("localhost", "123", "321", "new_db"); # 123 - user; 321- pass;
  $mysqli->set_charset("utf8");
  if ($mysqli->connect_errno){
  $json_array = array("error" => 1, "message" => "Ошибка подключения к БД");
  $json = json_encode($json_array, JSON_UNESCAPED_UNICODE);
  exit($json);
  }
  else {
    if (isset($_GET['code'])) {
      $query = "SELECT * FROM `users` WHERE CODE=".$_GET['code'];
      $sql = mysqli_query($mysqli,$query) or die(mysqli_error());
      if (mysqli_num_rows($sql) > 0) {
            $myrow = mysqli_fetch_array($sql);
            $date = date_create($myrow['date']);
            $curdate = date("d.m.Y");
            if (strtotime($curdate) < strtotime(date_format($date, 'd.m.y')))
            {
                $interval = date_diff($date, date_create($curdate));
                echo $interval->format("%d");
            }
            else
            {
                echo "The duration of the key has expired.";
            }
      }else{
        echo '-1';
      }
    }
  }
  ?>
</body>

Если ключ есть в бд и он не истек, выводим остаток дней, если истек, пишем:
"The duration of the key has expired."
Если ключа вообще нет, то пишем:
-1


 

Чтоб в ручную не добавлять ключи через PMA, напишем php, который будет принимать:
Ключ, количество дней на которое активируем его, пароль, который будете знать только вы.
PHP:
<!DOCTYPE html>

<head>
    <title>ADD KEY</title>
</head>
<body>

<?php
$mysqli = new mysqli("localhost", "123", "321", "new_db"); # 123 - user; 321- pass; new_db - base
$mysqli->set_charset("utf8");
if ($mysqli->connect_errno) {
    $json_array = array("error" => 1, "message" => "Ошибка подключения к БД");
    $json = json_encode($json_array, JSON_UNESCAPED_UNICODE);
    exit($json);
} else {
    echo('Успешное подключение!');
    if (isset($_POST["code"])) {
        if (!strcmp($_POST["pass"],"123456")){
          $date = new DateTime('NOW');
          $date->add(new DateInterval('P'.$_POST["days"].'D'));
          $sql = "INSERT INTO `users` (`code`, `date`) VALUES ('".$_POST['code']."', '".$date->format('d.m.y')."' )";
          $mysqli->query($sql);
           if ($sql) {
               echo "<p>Данные успешно добавлены в таблицу.</p>";
           } else {
               echo "<p>Произошла ошибка.</p>";
           }
        } else {
            echo "<p>Неверный пароль.</p>";
        }
    }
}
?>
<table>
    <form action="" method="post">
        <tr>
            <td>KEY:</td>
            <td><input type="text" name="code"></td>
        </tr>
        <tr>
            <td>DAYS:</td>
            <td><input type="text" name="days"></td>
        </tr>
        <tr>
            <td>PASSWORD:</td>
            <td><input type="text" name="pass"></td>
        </tr>
        <tr>
            <td colspan="2"><input type="submit" value="OK"></td>
        </tr>
    </form>
</table>
</body>

 

Теперь переходим к луа.

Для работы потребуется библиотека lua requests

Lua:
requests = require('requests')

function getserial()
    local ffi = require("ffi")
    ffi.cdef[[
    int __stdcall GetVolumeInformationA(
    const char* lpRootPathName,
    char* lpVolumeNameBuffer,
    uint32_t nVolumeNameSize,
    uint32_t* lpVolumeSerialNumber,
    uint32_t* lpMaximumComponentLength,
    uint32_t* lpFileSystemFlags,
    char* lpFileSystemNameBuffer,
    uint32_t nFileSystemNameSize
    );
    ]]
    local serial = ffi.new("unsigned long[1]", 0)
    ffi.C.GetVolumeInformationA(nil, nil, 0, serial, nil, nil, nil, 0)
    return serial[0]
end

function main()
    if not isSampfuncsLoaded() or not isSampLoaded() then return end
    while not isSampAvailable() do wait(100) end
    checkKey()
    wait(-1)
end

function checkKey()
        response = requests.get('сайт.ру/auth.php?code='..getserial())
        if not response.text:match("<body>(.*)</body>"):find("-1") then -- Если ключ есть в бд
            if not response.text:match("<body>(.*)</body>"):find("The duration of the key has expired.") then -- Если сервер не ответил что ключ истек.
                sampAddChatMessage("До окончания лицензии осталось:"..response.text:match("<body>(.*)</body>"), -1) --  Выводим кол-во дней до конца лицензии
            else
                sampAddChatMessage(response.text:match("Срок действия лицензии истек."), -1)
            end
        else
            sampAddChatMessage("Ключ не активирован.", -1)
        end
end


Да и вообщем все.
В lua использовалась функция от




Автор публикации:

WiseBear WiseBear

Скачать:

Скачать

Дата:
Автор ресурса:

TRADARENA

Обучение LUA
Обучение LUA
24.12.2020, Статьи
Готовый сайт для SAMP проекта
Готовый сайт для SAMP проекта
07.12.2024, Скрипты сайтов / PREMIUM WEB
Мануал по настройке MYSQL услуги
Мануал по настройке MYSQL услуги
11.11.2023, Модули EGP
Введение в скриптинг
Введение в скриптинг
12.02.2021, Статьи

Нет комментариев.Оставишь комментарий?