[TuT] Izrada MYSQL Systema

Započeo LuKsA, Avgust 28, 2010, 11:44:38 PRE PODNE

prethodna tema - sledeća tema

0 članova i 2 gostiju pregledaju ovu temu.

Izrada MYSQL Systema! by: [HiC]TheKiller

Sta je potrebno?

     
Napomena: Ovaj tutorial je za malo bolje skriptere, ukoliko se ne smatrate time, nemojte niti pocet radit.. Takoder zahtijeva dosta dobro poznavanje HTML | PHP i CSSa

Koraci

#1

Napocetku, treba pokrenuti WAMP server i MYSQL plugin, kada ste zavrsili krenite na #2 korak.

#2

Sada kada je WAMP i MYSQL plugin slozen, sada mozemo poceti praviti MYSQL System.

#include <a_samp>
#include <a_mysql>
//DCMD - za register i login komandu
#define dcmd(%1,%2,%3) if (!strcmp((%3)[1], #%1, true, (%2)) && ((((%3)[(%2) + 1] == '\0') && (dcmd_%1(playerid, ""))) || (((%3)[(%2) + 1] == ' ') && (dcmd_%1(playerid, (%3)[(%2) + 2]))))) return 1
//WAMP
#define SQL_HOST "localhost" //WAMP host, ako je externi, promjenite ovo
#define SQL_USER "root" //WAMP User
#define SQL_PASS "" //WAMP PW(default - nema PWa)
#define SQL_DB "sa-mp" //Databazu koju ste kreirali(kasnije u koracima)
#define mysql_fetch_row(%1) mysql_fetch_row_format(%1,"|")


public OnGameModeInit()
{
    if(!mysql_connect(SQL_HOST, SQL_USER, SQL_DB, SQL_PASS))
    {
        print("SQL connection attempt 1 FAILED!");
        if(!mysql_connect(SQL_HOST, SQL_USER, SQL_DB, SQL_PASS))
        {
            print("SQL connection attempt 2 FAILED!");
            if(!mysql_connect(SQL_HOST, SQL_USER, SQL_DB, SQL_PASS))
            {
                print("SQL connection attempt 3 FAILED!");
                return 1;
            }
        }
    }
    return 1;
}


public OnPlayerConnect(playerid)
{
    new Query[200], Pname[24]; //Kreira Query i Pname
    GetPlayerName(playerid, Pname, 24); //Uzima igracevo ime
    format(Query, sizeof(Query), "SELECT * FROM `playerinfo` WHERE `user` = '%s'", Pname); //Selektira liniju gdje 'playername' je igrac
    mysql_query(Query);
    mysql_store_result();
    if(mysql_num_rows() != 0) //Ako je igrac pronaden
    {
        new PIP[56]; //Kreira IP String
        GetPlayerIp(playerid, PIP, 56); //Uzima igracev IP
        format(Query, sizeof(Query), "SELECT * FROM `playerinfo` WHERE `user` = '%s' AND `IP` = '%s'", Pname, PIP); //Gleda dali je IP igraca isti kao i prosle konekcije, ako je = autologin
        mysql_query(Query);
        mysql_store_result();
        if(mysql_num_rows() != 0) // Ako je igracev IP isti ko i prosle konekcije
        {
            new line[750];
            SetPVarInt(playerid, "Logged", 1); //Stavlja igracu da je logiran
            SendClientMessage(playerid, 0x009600AA, "Automatski ste Logirani!");
            if(mysql_fetch_row(line))
            {
                   new data[3][50]; //Data stringovi
                   new data2[4]; //Data varijable
                   sscanf(line, "p|ssdddds", data[0], data[1], data2[0], data2[1], data2[2], data2[3], data[2]); //Razdvojava linije pomocu sscanfa
                   SetPVarInt(playerid, "Kills", data2[0]); //Stavlja Pvarove
                   SetPVarInt(playerid, "Logged", 1); //Stavlja Pvarove
                   SetPVarInt(playerid, "Deaths", data2[1]); //Stavlja Pvarove
                   SetPlayerScore(playerid, data2[2]); //Stavlja igracev Score
                   GivePlayerMoney(playerid, data2[3]); //Stavlja igracu novac
                   mysql_free_result();
               }
        }
        if(!mysql_num_rows())
        {
            SendClientMessage(playerid, 0x009600AA, "Ovaj korisnicki racun je registriran, molimo logirajte se"); //Igrac je vec registriran, ali se IP ne podudara s proslom konekcijom
            ShowPlayerDialog(playerid, 15000, DIALOG_STYLE_INPUT , "Login", "Ovaj korisnicki racun je registriran, molimo logirajte se", "OK", "Izlaz");
        }
    }
    else
    {
        ShowPlayerDialog(playerid, 14600, DIALOG_STYLE_INPUT , "Registracija", "Ovaj korisnicki Racun nije registriran, molimo registrirajte se!", "OK", "Izlaz");
        SendClientMessage(playerid, 0x009600AA, "Ovaj korisnicki racun nije registriran, registirajte se!"); //Igrac nije registriran
    }
    mysql_free_result();
    return 1;
}


public OnDialogResponse(playerid, dialogid, response, listitem, inputtext[])
{
    if(dialogid == 14600)
    {
       if(response)
       {
            if(!strlen(inputtext)) //Ako igrac nije unesio PW
            {
                ShowPlayerDialog(playerid, 14600, DIALOG_STYLE_INPUT , "Registracija", "Ovaj korisnicki racun nije registriran, registrirajte se!", "OK", "Izlaz");
                SendClientMessage(playerid, 0xF60000AA, "Molimo unesite PW.");
            }
            new PIP[50];
            new Query[200], Pname[24];
            GetPlayerName(playerid, Pname, 24); //Igracevo ime
            GetPlayerIp(playerid, PIP, 50); //Igracev IP
            format(Query, sizeof(Query), "INSERT INTO `playerinfo` (`user`, `password`, `kills`, `deaths`, `score`, `money`, IP) VALUES ('%s', '%s', 0, 0, 0, 0, '%s')", Pname, inputtext, PIP); //Unosava string
            mysql_query(Query);
            GameTextForPlayer(playerid, "~g~Registrirani", 2000, 3);
            SendClientMessage(playerid, 0x0000D9AA, "Vi ste registrirani i logirani na svoj korisnicki racun!");
            SetPVarInt(playerid, "Logged", 1);
        }
    }
    if(dialogid == 15000)
    {
       if(response)
       {
           new Query[200], Pname[24];
           GetPlayerName(playerid, Pname, 24);
           format(Query, sizeof(Query), "SELECT * FROM `playerinfo` WHERE `user` = '%s' AND `password` = '%s'", Pname, inputtext);
           mysql_query(Query);
           mysql_store_result();
           if(!mysql_num_rows())
           {
               SendClientMessage(playerid, 0xF60000AA, "Pogresna lozinka!");
               SetPVarInt(playerid, "WrongPass", GetPVarInt(playerid, "WrongPass") + 1);
               ShowPlayerDialog(playerid, 15000, DIALOG_STYLE_INPUT , "Login", "Ovaj korisnicki racun je registriran, molimo logirajte se", "OK", "Izlaz");
               if(GetPVarInt(playerid, "WrongPass") == 3)
               {
                   SendClientMessage(playerid, 0xF60000AA, "Izbaceni ste, jer ste pogrijesili PW 3 puta!!");
                   Kick(playerid);
               }
           }
           else
           {
               new line[750];
               if(mysql_fetch_row(line))
               {
                   new data[3][50]; //Data string
                   new data2[4]; //Data varijable
                   sscanf(line, "p|ssdddds", data[0], data[1], data2[0], data2[1], data2[2], data2[3], data[2]); //Razdvojava liniju putem sscanfa
                   SetPVarInt(playerid, "Kills", data2[0]); //Stavlja Pvar
                   SetPVarInt(playerid, "Logged", 1); //Stavlja Pvar
                   SetPVarInt(playerid, "Deaths", data2[1]); //Stavlja Pvar
                   SetPlayerScore(playerid, data2[2]); //Stavlja igracev Score
                   SetPVarInt(playerid, "MoneyGiven", data2[3]); //Stavlja igracu novac
                   SendClientMessage(playerid, 0x0000D9AA, "Logirani ste!");
                   mysql_free_result();
               }
           }
       }
    }
    return 1;
}


public OnPlayerRequestSpawn(playerid)
{
    if(GetPVarInt(playerid, "Logged") == 0)
    {
        new Query[200], Pname[24]; //Varijable
        GetPlayerName(playerid, Pname, 24); //Uzima igracevo ime
        format(Query, sizeof(Query), "SELECT * FROM `playerinfo` WHERE `user` = '%s'" , Pname); //MySQL string
        mysql_query(Query);
        mysql_store_result();
        if(!mysql_num_rows()) ShowPlayerDialog(playerid, 14600, DIALOG_STYLE_INPUT , "Registracija", "Ovaj korisnicki racun nije registriran, registrirajte se!", "OK", "Izlaz"); //Ako igrac nije registriran, prikazuje Dialog
        else ShowPlayerDialog(playerid, 15000, DIALOG_STYLE_INPUT , "Login", "Ovaj korisnicki racun je registriran, logirajte se", "OK", "Izlaz"); //Ako je igrac registriran, prikazuje dialog za login
        return 0;
    }
    return 1;
}


public OnPlayerSpawn(playerid)
{
    if(GetPVarInt(playerid, "Logged") == 1 && GetPVarInt(playerid, "MoneyGiven") > 0)
    {
        GivePlayerMoney(playerid, GetPVarInt(playerid, "MoneyGiven"));
        SetPVarInt(playerid, "MoneyGiven", 0);
    }
    return 1;
}


public OnPlayerDeath(playerid, killerid, reason)
{
    SetPVarInt(playerid, "Deaths", GetPVarInt(playerid, "Deaths") + 1); //Stavlja smrti igracu +1 koji je umro(playerid)
    if(killerid != INVALID_PLAYER_ID) SetPVarInt(playerid, "Kills", GetPVarInt(playerid, "Kills") + 1); // Dodaje kill igracu koji je ubio +1 (killerid)
    return 1;
}


public OnPlayerDisconnect(playerid, reason)
{
    if(GetPVarInt(playerid, "Logged") == 1) //Samo ako je igrac bio logiran
    {
        new query[300]; //Varijable
        new Pname[24]; //Varijable
        GetPlayerName(playerid, Pname, 24); //Uzima igracevo ime
        format(query, sizeof(query), "UPDATE `playerinfo` SET `score` = '%d',`money` = '%d', `kills` = '%d', `deaths` = '%d'  WHERE `user` = '%s'", GetPlayerScore(playerid), GetPlayerMoney(playerid), GetPVarInt(playerid, "Kills"), GetPVarInt(playerid, "Deaths"), Pname); //Uzima info igraca
        mysql_query(query);
        mysql_free_result();
    }
    return 1;
}


stock sscanf(string[], format[], {Float,_}:...)
{
    #if defined isnull
        if (isnull(string))
    #else
        if (string[0] == 0 || (string[0] == 1 && string[1] == 0))
    #endif
        {
            return format[0];
        }
    #pragma tabsize 4
    new
        formatPos = 0,
        stringPos = 0,
        paramPos = 2,
        paramCount = numargs(),
        delim = ' ';
    while (string[stringPos] && string[stringPos] <= ' ')
    {
        stringPos++;
    }
    while (paramPos < paramCount && string[stringPos])
    {
        switch (format[formatPos++])
        {
            case '\0':
            {
                return 0;
            }
            case 'i', 'd':
            {
                new
                    neg = 1,
                    num = 0,
                    ch = string[stringPos];
                if (ch == '-')
                {
                    neg = -1;
                    ch = string[++stringPos];
                }
                do
                {
                    stringPos++;
                    if ('0' <= ch <= '9')
                    {
                        num = (num * 10) + (ch - '0');
                    }
                    else
                    {
                        return -1;
                    }
                }
                while ((ch = string[stringPos]) > ' ' && ch != delim);
                setarg(paramPos, 0, num * neg);
            }
            case 'h', 'x':
            {
                new
                    num = 0,
                    ch = string[stringPos];
                do
                {
                    stringPos++;
                    switch (ch)
                    {
                        case 'x', 'X':
                        {
                            num = 0;
                            continue;
                        }
                        case '0' .. '9':
                        {
                            num = (num << 4) | (ch - '0');
                        }
                        case 'a' .. 'f':
                        {
                            num = (num << 4) | (ch - ('a' - 10));
                        }
                        case 'A' .. 'F':
                        {
                            num = (num << 4) | (ch - ('A' - 10));
                        }
                        default:
                        {
                            return -1;
                        }
                    }
                }
                while ((ch = string[stringPos]) > ' ' && ch != delim);
                setarg(paramPos, 0, num);
            }
            case 'c':
            {
                setarg(paramPos, 0, string[stringPos++]);
            }
            case 'f':
            {

                new changestr[16], changepos = 0, strpos = stringPos;   
                while(changepos < 16 && string[strpos] && string[strpos] != delim)
                {
                    changestr[changepos++] = string[strpos++];
                    }
                changestr[changepos] = '\0';
                setarg(paramPos,0,_:floatstr(changestr));
            }
            case 'p':
            {
                delim = format[formatPos++];
                continue;
            }
            case '\'':
            {
                new
                    end = formatPos - 1,
                    ch;
                while ((ch = format[++end]) && ch != '\'') {}
                if (!ch)
                {
                    return -1;
                }
                format[end] = '\0';
                if ((ch = strfind(string, format[formatPos], false, stringPos)) == -1)
                {
                    if (format[end + 1])
                    {
                        return -1;
                    }
                    return 0;
                }
                format[end] = '\'';
                stringPos = ch + (end - formatPos);
                formatPos = end + 1;
            }
            case 'u':
            {
                new
                    end = stringPos - 1,
                    id = 0,
                    bool:num = true,
                    ch;
                while ((ch = string[++end]) && ch != delim)
                {
                    if (num)
                    {
                        if ('0' <= ch <= '9')
                        {
                            id = (id * 10) + (ch - '0');
                        }
                        else
                        {
                            num = false;
                        }
                    }
                }
                if (num && IsPlayerConnected(id))
                {
                    setarg(paramPos, 0, id);
                }
                else
                {
                    #if !defined foreach
                        #define foreach(%1,%2) for (new %2 = 0; %2 < MAX_PLAYERS; %2++) if (IsPlayerConnected(%2))
                        #define __SSCANF_FOREACH__
                    #endif
                    string[end] = '\0';
                    num = false;
                    new
                        name[MAX_PLAYER_NAME];
                    id = end - stringPos;
                    foreach (Player, playerid)
                    {
                        GetPlayerName(playerid, name, sizeof (name));
                        if (!strcmp(name, string[stringPos], true, id))
                        {
                            setarg(paramPos, 0, playerid);
                            num = true;
                            break;
                        }
                    }
                    if (!num)
                    {
                        setarg(paramPos, 0, INVALID_PLAYER_ID);
                    }
                    string[end] = ch;
                    #if defined __SSCANF_FOREACH__
                        #undef foreach
                        #undef __SSCANF_FOREACH__
                    #endif
                }
                stringPos = end;
            }
            case 's', 'z':
            {
                new
                    i = 0,
                    ch;
                if (format[formatPos])
                {
                    while ((ch = string[stringPos++]) && ch != delim)
                    {
                        setarg(paramPos, i++, ch);
                    }
                    if (!i)
                    {
                        return -1;
                    }
                }
                else
                {
                    while ((ch = string[stringPos++]))
                    {
                        setarg(paramPos, i++, ch);
                    }
                }
                stringPos--;
                setarg(paramPos, i, '\0');
            }
            default:
            {
                continue;
            }
        }
        while (string[stringPos] && string[stringPos] != delim && string[stringPos] > ' ')
        {
            stringPos++;
        }
        while (string[stringPos] && (string[stringPos] == delim || string[stringPos] <= ' '))
        {
            stringPos++;
        }
        paramPos++;
    }
    do
    {
        if ((delim = format[formatPos++]) > ' ')
        {
            if (delim == '\'')
            {
                while ((delim = format[formatPos++]) && delim != '\'') {}
            }
            else if (delim != 'z')
            {
                return delim;
            }
        }
    }
    while (delim > ' ');
    return 0;
}


#3

Postavljanje PhpMyAdmin-a je korak 3.

1. Idite u MYSQL stranicu

     
  • External (Ne na vasem compu) - Idite na web stranicu
  • Internal (Wamp | na vasem compu) - idite do localhost/phpmyadmin

2. Pronadite i napravite novu databazu imena sa-mp.

3. Pronadite gdje pise "Create new table on database sa-mp" i napisite "playerinfo" sa 7 polja(field)

4. Unesite sljedece informacije u svaku liniju

1 linija:
Field - user
Type - varchar
Length - 24

2 linija:
Field - password
Type - varchar
Length - 24

3 linija:
Field - kills
Type - int
Length - 11

4 linija:
Field - deaths
Type - int
Length - 11

5 linija:
Field - score
Type - int
Length - 11

6 linija:
Field - money
Type - int
Length - 11

7 linija:
Field - IP
Type - varchar
Length - 50

5. Pritisnite Save gumb(Spremi)

#4

Pravljenje websitea, UCP-a(User Control Panel) u PHPu

File: database.php
Info: Ovo je prvi file koji trebate imati da bi se Web spojio na MYSQL databazu i koji bude includan(ubacen) u vecinu vasih web stranica UCPa.

<?php$con = mysql_connect("localhost","root","");mysql_select_db("sa-mp");//Ako koristite externi(tj. server negdje na web stranici, a ne na vasem compu) onda ne zaboravite promjeniti: (mysql_connect(server[],user[],pass[]);?>


File: index.php
Info: Prva web stranica na koju ide igrac

<html>
<body>
<form action="Logged.php" method="post">
<b><font size="4" color="#000080">Dobrodosli na UCP</font></b>
<p>Ime_Prezime <input type="text" name="User" size="20" /> </p>
<p>Lozinka&nbsp; <input type="password" name="Password" size="20" /></p>
<p>&nbsp;<input type="submit" />
<input type="reset" /> </p>
<p>Molimo logirajte se</p>
</form>
</body>
</html>


File: Logged.php
Info: Nakon sto se igrac ulogira, bit ce ovdje redirektan(prebacen).

<?phpinclude("database.php");session_start();if (!$con)  {  die('Could not connect: ' . mysql_error());  }  if(isset($_SESSION["Username"]))  {    $user = $_SESSION["Username"];    $pass = $_SESSION["Password"];  }  else  {    $user = $_POST["User"];     $pass = $_POST["Password"];    $_SESSION['Username'] = $user;    $_SESSION['Password'] = $pass;  }  $query = "SELECT * FROM playerinfo WHERE user = '$user'";  $result = mysql_query($query);  $username_exist = mysql_num_rows($result);  if($username_exist == 0)  {    echo('Taj nick ne postoji');    echo '<a href="index.php"">Natrag</a>';    unset($_SESSION['Username']);    unset($_SESSION['Password']);    die;  }    $row = mysql_fetch_row($result);  if($row[1] !== $pass)  {    echo('Kriva lozinka!');    echo '<a href="index.php"">Natrag</a>';    unset($_SESSION['Username']);    unset($_SESSION['Password']);  }  $str = '<b><font size="4" color="#000080"> Dobrodosli na UCP! </font></b>';  echo $str;  echo "<table>";  echo "  <tr>  <td>Nick:</td>  <td>$row[0]</td>  </tr>";  echo "  <tr>  <td>Ubojstva:</td>  <td>$row[2]</td>  </tr>";  echo "  <tr>  <td>Smrti:</td>  <td>$row[3]</td>  </tr>";  echo "  <tr>  <td>Skor:</td>  <td>$row[4]</td>  </tr>";    echo "  <tr>  <td>Novac:</td>  <td> $$row[5]</td>  </tr>";  echo "</table>";  echo '<a href="NewPassword.php"">Promijena Lozinke</a>';  echo '<p><a href="Stats.php"">Pogledajte statistike igraca</a></p>'?>


File: NewPassword.php
Info: Ovo je gdje igrac mjenja svoj PW.

<html>
<body>
<form action="Newpass.php" method="post">
<b><font size="4" color="#000080">Promijena lozinke! </font></b>
<p>Stara lozinka <input type="password" name="P1" size="20" /> </p>
<p>Nova lozinka &nbsp; <input type="password" name="P2" size="20" /></p>
<p>Potvrda nove lozinke &nbsp; <input type="password" name="P3" size="20" /></p>
<p>&nbsp;<input type="submit" />
<input type="reset" /> </p>
<a href="Logged.php"">Natrag</a>
</form>
</body>
</html>


File: Newpass.php
Info: Provijerava dal je sve uredu u newpassword-u.

<?phpsession_start();$pass1 = $_POST["P1"];$pass2 = $_POST["P2"];$pass3 = $_POST["P3"];$user = $_SESSION['Username'];if(!isset($_SESSION['Username'])){    echo('Ulogirani ste!');    echo '<a href="index.php"">Natrag</a>';    die;}include("database.php");$query = "SELECT * FROM playerinfo WHERE user = '$user'";$result = mysql_query($query);$row = mysql_fetch_row($result);if (!$con)  {  die('Could not connect: ' . mysql_error());  }  $username_exist = mysql_num_rows($result);  if($username_exist == 0)  {    echo('Nick ne postoji');    echo '<a href="NewPassword.php"">Natrag</a>';    die;  }    if($pass1 !== $row[1])  {    echo("Pogresan stari PW!");    echo '<a href="New Password.php"">Natrag</a>';     die;  }  if($pass2 !== $pass3)  {    echo("Nove lozinke vam se ne podudaraju!");    echo '<a href="NewPassword.php"">Natrag</a>';     die;  }    $query = "UPDATE playerinfo SET password = '$pass3' WHERE user= '$user'";  $result = mysql_query($query);  echo 'Password Changed!';   $_SESSION['Password'] = $pass3;  echo '<a href="Logged.php"">Natrag</a>';?>


File: Stats.php
Info: Statsi igraca

<html>
<body>
<form action="ShowStats.php" method="post">
<b><font size="4" color="#000080">Statsi drugih igraca</font></b>
<p>Nick <input type="text" name="User" size="20" /> </p>
<p>&nbsp;<input type="submit" />
<input type="reset" /> </p>
</form>
<p><font face="Arial" color="#000080" size="2"><b><a href="Logged.php">Natrag</a></b></font></p>
</body>
</html>


File: ShowStats.php
Info: Ubacuje ime igraca za stats

<?phpinclude("database.php");if (!$con)  {  die('Could not connect: ' . mysql_error());  }  $user = $_POST["User"];   $query = "SELECT * FROM playerinfo WHERE user= '$user'";  $result = mysql_query($query);  $username_exist = mysql_num_rows($result);  if($username_exist == 0)  {    echo('Nick ne postoji');    echo('<p><font face="Arial" color="#000080" size="2"><b><a href="stats.php">Natrag</a></b></font></p>');    die;  }    $row = mysql_fetch_row($result);  $message = "<b><font size='4' color='#000080'> Statsi od | $user</font></b>";  echo $message;  echo "<table>";  echo "  <tr>  <td>Nick:</td>  <td>$row[0]</td>  </tr>";  echo "  <tr>  <td>Ubojstva:</td>  <td>$row[2]</td>  </tr>";  echo "  <tr>  <td>Smrti:</td>  <td>$row[3]</td>  </tr>";    echo "  <tr>  <td>Skor:</td>  <td>$row[4]</td>  </tr>";  echo "  <tr>  <td>Novac:</td>  <td>$$row[5]</td>  </tr>";  echo "</table>";    echo'<p><font face="Arial" color="#000080" size="2"><b><a href="stats.php">Pronadi statse drugog igraca</a></b></font></p>';?>


Nadam se da vam se tut svida, kao i moje prevodenje ;)..

original: http://forum.sa-mp.com/showthread.php?t=159785
Poslednja Izmena: April 17, 2012, 14:30:51 POSLE PODNE od joXy_
Aequam memento rebus in arduis servare mentem.

Nije lose...


RESPECT 4 EVER: John, GLC,bAndzi, Nikola, Sop, Zoki, Bruno_Venuti, Mele, Luka P,ExtremePower,Wang(neki kineski frajer)

NAJBOLJI CITATI:
Citat: [GF]Alive poslato Jun 24, 2010, 18:20:19 POSLE PODNE
Paizte ljud mozda je KayLoger! ! !
MOJI RADOVI:
[FS]Trofeji

Tut je poprilicno lose napravio TheKiller,

1. Nigdje ne sprjecava SQL injection
2. ne koristi Threadane querye
3. postoji bolji nacin od selektiranja svega cim se igrac spoji, npr selektiranje prvo IDa pa da vidi dal igrac uopce postoji
4. umjesto da fetcha cijeli row moze ici polje po polje (field by field)

5. ovo je vise stats page nego ucp, i niti u njemu se ne brine za nikakvu sigurnost oko SQL Injectiona ili session hijackinga


Za one koji misle ovo koristit  :)


I da sto sam zaboravio je da je WAMP server postao XAMPP te WAMP vjerojatno nema najnoviji PHP ili MySQL
Poslednja Izmena: Avgust 28, 2010, 12:18:54 POSLE PODNE od John

A za cega ovo sluzi ako smem da pitam ?  :D :D :D

Citat: John poslato Avgust 28, 2010, 12:18:09 POSLE PODNE
Tut je poprilicno lose napravio TheKiller,

1. Nigdje ne sprjecava SQL injection
2. ne koristi Threadane querye
3. postoji bolji nacin od selektiranja svega cim se igrac spoji, npr selektiranje prvo IDa pa da vidi dal igrac uopce postoji
4. umjesto da fetcha cijeli row moze ici polje po polje (field by field)

5. ovo je vise stats page nego ucp, i niti u njemu se ne brine za nikakvu sigurnost oko SQL Injectiona ili session hijackinga


Za one koji misle ovo koristit  :)


I da sto sam zaboravio je da je WAMP server postao XAMPP te WAMP vjerojatno nema najnoviji PHP ili MySQL

Aha, to nije on napravio. Ja mislio da je on pa s obzirom da je on pocetnik je dobro.


RESPECT 4 EVER: John, GLC,bAndzi, Nikola, Sop, Zoki, Bruno_Venuti, Mele, Luka P,ExtremePower,Wang(neki kineski frajer)

NAJBOLJI CITATI:
Citat: [GF]Alive poslato Jun 24, 2010, 18:20:19 POSLE PODNE
Paizte ljud mozda je KayLoger! ! !
MOJI RADOVI:
[FS]Trofeji

Citat: LordShigi poslato Avgust 28, 2010, 12:25:16 POSLE PODNE
Citat: John poslato Avgust 28, 2010, 12:18:09 POSLE PODNE
Tut je poprilicno lose napravio TheKiller,

1. Nigdje ne sprjecava SQL injection
2. ne koristi Threadane querye
3. postoji bolji nacin od selektiranja svega cim se igrac spoji, npr selektiranje prvo IDa pa da vidi dal igrac uopce postoji
4. umjesto da fetcha cijeli row moze ici polje po polje (field by field)

5. ovo je vise stats page nego ucp, i niti u njemu se ne brine za nikakvu sigurnost oko SQL Injectiona ili session hijackinga


Za one koji misle ovo koristit  :)


I da sto sam zaboravio je da je WAMP server postao XAMPP te WAMP vjerojatno nema najnoviji PHP ili MySQL

Aha, to nije on napravio. Ja mislio da je on pa s obzirom da je on pocetnik je dobro.

da dobro je preveo, a ovaj je lose napravio   :) :D

Dobro je to za pocetnike :D.. ovaj je i sam napisao da ne sprecava injection ovo..
Aequam memento rebus in arduis servare mentem.

pogle gresku ... valjda uocavas


sscanf(line, "p|ssdddds", data[0], data[1], data2[0], data2[1], data2[2], data2[3], data[2]); //Razdvojava linije pomocu sscanfa

nastoe

Lol napises da je za bolje skriptere a tutorial pun gresaka naveo si sve jezike da treba poznavati a nisi sami SQL jezik ako nisi znao to je isto jezik

sve je to ok, al realno cemu msql baza za samp server, po meni nepotrebno... zanimljive sam postove bas jucer citao od y_lessa o brzini zapisivanja, i sto on kaze, a i sam se slazem pored svih sistema zapisivanja podataka fwrite je najbrzi, tako da nema potrebe, osim ako ne zelis povezat u jednu bazu i server i forum acc ili iz vec nekog drugog meni nepoznatog razloga...

Po meni postoje dva razloga. Jedan je da je sve puno lakÅ¡e upravo zbog tabličnog povezivanja podataka, jednostavnije za ureÄ'ivati = viÅ¡e volje za rad = bolje skripte.
A Drugi je kao Å¡to si i sam rekao povezivanje baza, Control Paneli i takve stvari...


RESPECT 4 EVER: John, GLC,bAndzi, Nikola, Sop, Zoki, Bruno_Venuti, Mele, Luka P,ExtremePower,Wang(neki kineski frajer)

NAJBOLJI CITATI:
Citat: [GF]Alive poslato Jun 24, 2010, 18:20:19 POSLE PODNE
Paizte ljud mozda je KayLoger! ! !
MOJI RADOVI:
[FS]Trofeji

Citat: LordShigi poslato Avgust 28, 2010, 19:53:58 POSLE PODNE
Po meni postoje dva razloga. Jedan je da je sve puno lakÅ¡e upravo zbog tabličnog povezivanja podataka, jednostavnije za ureÄ'ivati = viÅ¡e volje za rad = bolje skripte.
A Drugi je kao Å¡to si i sam rekao povezivanje baza, Control Paneli i takve stvari...

ako imas msql bazu uopce ne mora znacit da ces napravit bolju skriptu, o njoj ovisi samo onaj mali djelic tvog moda, a on je u dva callbacka - ucitavanje i pisanje podataka, apsolutno nikakve veze sa dobrim/losim modom ili ikakvom voljom za radom na modu msql nema...

Citat: Dude poslato Avgust 28, 2010, 19:43:44 POSLE PODNE
sve je to ok, al realno cemu msql baza za samp server, po meni nepotrebno... zanimljive sam postove bas jucer citao od y_lessa o brzini zapisivanja, i sto on kaze, a i sam se slazem pored svih sistema zapisivanja podataka fwrite je najbrzi, tako da nema potrebe, osim ako ne zelis povezat u jednu bazu i server i forum acc ili iz vec nekog drugog meni nepoznatog razloga...

Mislim da je to bila rasprava o custom libaryi-ima (dini, dudb) vs fwrite i naravno pobjedio je fwrite i tu uopce nema rasprave, a vidio sam da se Y_Less prije zalagao za koristenje SQL Litea koji je ugradjen u SA:MP server  :)

Svako ima svoj ukus i svoj system koji preferira. Meni je to MySql odnosno SQLite.


RESPECT 4 EVER: John, GLC,bAndzi, Nikola, Sop, Zoki, Bruno_Venuti, Mele, Luka P,ExtremePower,Wang(neki kineski frajer)

NAJBOLJI CITATI:
Citat: [GF]Alive poslato Jun 24, 2010, 18:20:19 POSLE PODNE
Paizte ljud mozda je KayLoger! ! !
MOJI RADOVI:
[FS]Trofeji

Tex

stock sscanf(string[], format[], {Float,_}:...)
{
    #if defined isnull
        if (isnull(string))
    #else
        if (string[0] == 0 || (string[0] == 1 && string[1] == 0))
    #endif
        {
            return format[0];
        }
    #pragma tabsize 4
    new
        formatPos = 0,
        stringPos = 0,
        paramPos = 2,
        paramCount = numargs(),
        delim = ' ';
    while (string[stringPos] && string[stringPos] <= ' ')
    {
        stringPos++;
    }
    while (paramPos < paramCount && string[stringPos])
    {
        switch (format[formatPos++])
        {
            case '\0':
            {
                return 0;
            }
            case 'i', 'd':
            {
                new
                    neg = 1,
                    num = 0,
                    ch = string[stringPos];
                if (ch == '-')
                {
                    neg = -1;
                    ch = string[++stringPos];
                }
                do
                {
                    stringPos++;
                    if ('0' <= ch <= '9')
                    {
                        num = (num * 10) + (ch - '0');
                    }
                    else
                    {
                        return -1;
                    }
                }
                while ((ch = string[stringPos]) > ' ' && ch != delim);
                setarg(paramPos, 0, num * neg);
            }
            case 'h', 'x':
            {
                new
                    num = 0,
                    ch = string[stringPos];
                do
                {
                    stringPos++;
                    switch (ch)
                    {
                        case 'x', 'X':
                        {
                            num = 0;
                            continue;
                        }
                        case '0' .. '9':
                        {
                            num = (num << 4) | (ch - '0');
                        }
                        case 'a' .. 'f':
                        {
                            num = (num << 4) | (ch - ('a' - 10));
                        }
                        case 'A' .. 'F':
                        {
                            num = (num << 4) | (ch - ('A' - 10));
                        }
                        default:
                        {
                            return -1;
                        }
                    }
                }
                while ((ch = string[stringPos]) > ' ' && ch != delim);
                setarg(paramPos, 0, num);
            }
            case 'c':
            {
                setarg(paramPos, 0, string[stringPos++]);
            }
            case 'f':
            {

                new changestr[16], changepos = 0, strpos = stringPos;
                while(changepos < 16 && string[strpos] && string[strpos] != delim)
                {
                    changestr[changepos++] = string[strpos++];
                    }
                changestr[changepos] = '\0';
                setarg(paramPos,0,_:floatstr(changestr));
            }
            case 'p':
            {
                delim = format[formatPos++];
                continue;
            }
            case '\'':
            {
                new
                    end = formatPos - 1,
                    ch;
                while ((ch = format[++end]) && ch != '\'') {}
                if (!ch)
                {
                    return -1;
                }
                format[end] = '\0';
                if ((ch = strfind(string, format[formatPos], false, stringPos)) == -1)
                {
                    if (format[end + 1])
                    {
                        return -1;
                    }
                    return 0;
                }
                format[end] = '\'';
                stringPos = ch + (end - formatPos);
                formatPos = end + 1;
            }
            case 'u':
            {
                new
                    end = stringPos - 1,
                    id = 0,
                    bool:num = true,
                    ch;
                while ((ch = string[++end]) && ch != delim)
                {
                    if (num)
                    {
                        if ('0' <= ch <= '9')
                        {
                            id = (id * 10) + (ch - '0');
                        }
                        else
                        {
                            num = false;
                        }
                    }
                }
                if (num && IsPlayerConnected(id))
                {
                    setarg(paramPos, 0, id);
                }
                else
                {
                    #if !defined foreach
                        #define foreach(%1,%2) for (new %2 = 0; %2 < MAX_PLAYERS; %2++) if (IsPlayerConnected(%2))
                        #define __SSCANF_FOREACH__
                    #endif
                    string[end] = '\0';
                    num = false;
                    new
                        name[MAX_PLAYER_NAME];
                    id = end - stringPos;
                    foreach (Player, playerid)
                    {
                        GetPlayerName(playerid, name, sizeof (name));
                        if (!strcmp(name, string[stringPos], true, id))
                        {
                            setarg(paramPos, 0, playerid);
                            num = true;
                            break;
                        }
                    }
                    if (!num)
                    {
                        setarg(paramPos, 0, INVALID_PLAYER_ID);
                    }
                    string[end] = ch;
                    #if defined __SSCANF_FOREACH__
                        #undef foreach
                        #undef __SSCANF_FOREACH__
                    #endif
                }
                stringPos = end;
            }
            case 's', 'z':
            {
                new
                    i = 0,
                    ch;
                if (format[formatPos])
                {
                    while ((ch = string[stringPos++]) && ch != delim)
                    {
                        setarg(paramPos, i++, ch);
                    }
                    if (!i)
                    {
                        return -1;
                    }
                }
                else
                {
                    while ((ch = string[stringPos++]))
                    {
                        setarg(paramPos, i++, ch);
                    }
                }
                stringPos--;
                setarg(paramPos, i, '\0');
            }
            default:
            {
                continue;
            }
        }
        while (string[stringPos] && string[stringPos] != delim && string[stringPos] > ' ')
        {
            stringPos++;
        }
        while (string[stringPos] && (string[stringPos] == delim || string[stringPos] <= ' '))
        {
            stringPos++;
        }
        paramPos++;
    }
    do
    {
        if ((delim = format[formatPos++]) > ' ')
        {
            if (delim == '\'')
            {
                while ((delim = format[formatPos++]) && delim != '\'') {}
            }
            else if (delim != 'z')
            {
                return delim;
            }
        }
    }
    while (delim > ' ');
    return 1;
}


Kad ovo ubacim u Pawno,izbaci mi da zatvorim pawno! sta da uradim?

About

Welcome to the community!