18 посетителей на сайте. Из них:
Пользователи5
Роботы13
Список пользователей
Zona Сейчас на сайте
Maenkov6666 Сейчас на сайте
Ага Сейчас на сайте
kirill pozdnaikov Сейчас на сайте
Никита Зюкин Сейчас на сайте
Коля Рожков Был(a) в сети 7 минут назад
sally sssally Был(a) в сети 12 минут назад
Алексей Ефименко Был(a) в сети 13 минут назад
Артур Был(a) в сети 14 минут назад
Рустам Довыдов Был(a) в сети 19 минут назад
Анастасия Басова Был(a) в сети 28 минут назад
Анатолий Бандит Был(a) в сети 39 минут назад
Nikita Был(a) в сети 39 минут назад
Алексей Гиниатуллин Был(a) в сети 42 минуты назад
conexion Был(a) в сети 42 минуты назад
Саша Сытник Был(a) в сети 43 минуты назад
Nikita Bot Был(a) в сети 46 минут назад
Серëга Трунов Был(a) в сети 51 минуту назад
Vanez Spartakov Был(a) в сети 57 минут назад
Abdulloh Gafurov Был(a) в сети 1 час назад
Квенси Мирнов Был(a) в сети 1 час назад
benz Был(a) в сети 1 час назад
Valik Tomko Был(a) в сети 1 час назад
Егор Бондов Был(a) в сети 1 час назад
Armyashka Был(a) в сети 1 час назад
Илья Был(a) в сети 2 часа назад
Сергей Куликов Был(a) в сети 2 часа назад
Артём Гусаров Был(a) в сети 2 часа назад
Richard Был(a) в сети 3 часа назад
Артём Магамедов Был(a) в сети 3 часа назад
Егор Был(a) в сети 3 часа назад
Grom_777 Valeron Был(a) в сети 3 часа назад
Был(a) в сети 3 часа назад
saba saba Был(a) в сети 4 часа назад
Илья Был(a) в сети 5 часов назад
chettaz0r Был(a) в сети 5 часов назад
Просто Я Был(a) в сети 5 часов назад
Артём Груздов Был(a) в сети 5 часов назад
sobesednik Был(a) в сети 6 часов назад
Ваня Старков иван Был(a) в сети 6 часов назад
Даниил Девелоп Был(a) в сети 6 часов назад
FF: Grotenk Был(a) в сети 6 часов назад
イロタナ リトラクタ Был(a) в сети 7 часов назад
Pumpkin Head Был(a) в сети 7 часов назад
Алексей Кандрин Был(a) в сети 7 часов назад
Вадим Новиков Был(a) в сети 7 часов назад
Алексей Был(a) в сети 8 часов назад
Был(a) в сети 10 часов назад
Aga Был(a) в сети 11 часов назад
Дмитрий ㅤ Был(a) в сети 11 часов назад
Дмитрий Был(a) в сети 11 часов назад
Marhan Был(a) в сети 11 часов назад
Ахмед Таджиков Был(a) в сети 11 часов назад
Leshiy Narezochnik Был(a) в сети 12 часов назад
MAerk Был(a) в сети 12 часов назад
Ramio Gaming Был(a) в сети 12 часов назад
Savaya Grill Был(a) в сети 12 часов назад
Madastick Был(a) в сети 12 часов назад
Артём Был(a) в сети 12 часов назад
RUOK FF ❶ Был(a) в сети 12 часов назад
юрий ларин Был(a) в сети 12 часов назад
Magomed Tataev Был(a) в сети 12 часов назад
Виктор Моисеенко Был(a) в сети 12 часов назад
Вадим Аккстим Был(a) в сети 12 часов назад
Александр Куртыгин Был(a) в сети 12 часов назад
Mot Был(a) в сети 12 часов назад
Arman Azizyan Был(a) в сети 12 часов назад
Cai Был(a) в сети 12 часов назад
Список ботов
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, Статьи

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