Oprettet tor. d. 19. februar 2009 kl. 20:59:33

moddi100
moddi100 (7.235 point. Point ude: 30)

Mysqli og SQL-injektioner

Hej,

Hvis man benytter sig af mysqli (bemærk i'et), er man så helt sikret for SQL-injektioner? Så følgende ikke vil være muligt:

$input = "' or Admin='1";
SELECT * FROM Users WHERE Id='$input'
SELECT * FROM Users WHERE Id='' or Admin=1'

Eller er der noget man skal være opmærksom på?

Skrevet tor. d. 19. februar 2009 kl. 21:06:42| #1

splazz
splazz (55.958 point)
majbom.com
jeg er selv lige begyndt så småt på mysqli og jeg har læst at hvis man bruger prepared statements, vil du fjerne muligheden for injections helt og aldeles. jeg kan ikke lige huske hvor jeg læste det, da jeg efterhånden har været lidt rundt for at se eksempler osv.

Skrevet tor. d. 19. februar 2009 kl. 21:10:51| #2

moddi100
moddi100 (7.235 point)
Har jeg også læst mig frem til. Men ønsker som sagt at være helt sikker :D

Skrevet tor. d. 19. februar 2009 kl. 21:13:34| #3

arne_v
arne_v (1.005.623 point)
Hvis du bruger mysqli og prepare boer du vaere sikret mod SQL injection.

Saadan fungerer parameters/prepared statement.

Eneste risiko er at der er en fejl i mysqli modulet og den risiko er langt mindre end risikoen for fejl i ens egen kode.

Skrevet tor. d. 19. februar 2009 kl. 21:20:06| #4

arne_v
arne_v (1.005.623 point)
Det er nok svaert at finde en officielt tekst.

Fordi det ligger i hele konceptet (og konceptet kendes fra alle mulige andre programmerinsg sprog).

Du laver din SQL saetning med spoergsmaals tegn eller andre markeringer og putter saa senere vaerdier ind for dem.

Vaerdier er per definition forskellig fra vilkaarlig SQL.

Skrevet tor. d. 19. februar 2009 kl. 21:21:57| #5

arne_v
arne_v (1.005.623 point)
Det bedste du kan finde er nok:

http://us3.php.net/ (...)

Note: The markers are legal only in certain places in SQL statements. For example, they are allowed in the VALUES()  list of an INSERT statement (to specify column values for a row), or in a comparison with a column in a WHERE clause to specify a comparison value.
However, they are not allowed for identifiers (such as table or column names), in the select list that names the columns to be returned by a SELECT statement, or to specify both operands of a binary operator such as the = equal sign. The latter restriction is necessary because it would be impossible to determine the parameter type. It's not allowed to compare marker with NULL by ? IS NULL too. In general, parameters are legal only in Data Manipulation Languange (DML) statements, and not in Data Defination Language (DDL) statements.

Skrevet tor. d. 19. februar 2009 kl. 21:23:11| #6

moddi100
moddi100 (7.235 point)
Én hovedpine mindre :D

Lig et svar begge to

Skrevet tor. d. 19. februar 2009 kl. 21:29:33| #7


Skrevet tor. d. 19. februar 2009 kl. 21:31:00| #8

moddi100
moddi100 (7.235 point)
OFF TOPIC: Dejligt at ekspertens mailsystem ikke er forsinket de 10+ min det var i det gamle system.

Skrevet tor. d. 19. februar 2009 kl. 21:31:07| #9

arne_v
arne_v (1.005.623 point)
Jeg skal lige understrege:

"SELECT * FROM tabel WHERE f = ?"

er sikker med mysqli og prepare.

"SELECT * FROM tabel WHERE f = $f"

er lige saa usikker som den altid har vaeret.

Det er brugen af parameter som goer forskellen.

Skrevet tor. d. 19. februar 2009 kl. 21:33:52| #10

splazz
splazz (55.958 point)
majbom.com
jeg skal ikke have point for den udtalels :)

jeg lærte selv lidt her, jeg er som sagt også MEGET grøn i mysqli sammenhæng :)

Skrevet tor. d. 19. februar 2009 kl. 21:39:05| #11

moddi100
moddi100 (7.235 point)
arne_v -> Når jeg nu ser dit sidste indlæg, kan jeg da godt se at mit første eksempel ikke var det bedst skrevne...

splazz -> fair nok

Skrevet tor. d. 19. februar 2009 kl. 21:51:23| #12

moddi100
moddi100 (7.235 point)
Er det egentligt muligt at lave en subquery eller er det der man skal bruge mysqli_multi_query?

SELECT Felt, (SELECT Farve FROM Farverkoder LIMIT 1) FROM Table

Skriv et indlæg




Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] [img]link til billede[/img]
Web- og emailadresser omdannes automatisk til links

Log ind

   

   

Seneste spørgsmål

Procentregning

Oprettet den 11. februar 2012 kl. 11.26
sevinding giver 60 point for svar | Giv et svar »

Ville ikke tildele at upload det til database eller komme...

Oprettet den 10. februar 2012 kl. 21.23
tobrukDk giver 15 point for svar | Giv et svar »

HTTP Post XML og modtag svar

Oprettet den 10. februar 2012 kl. 17.55
mrkaynex giver 200 point for svar | Giv et svar »

Seneste guides

Installer win 7
Den gode bruger


   




Tips & Tricks fra PC World

Teaser billede

Her er fem sjove danske websider du skal kende

Trænger dine lattermuskler til en omgang fitness på dansk? Vi viser vej til fem websider fyldt med humor og vanvittig satire.


Anmeldelser fra PC World

Teaser billede

Test: Denne super-tablet er iPads hårdeste konkurrent

Eee Pad Transformer Prime er frygtindgydende med sin quadcore processor og evne til at trylle sig om til bærbar. Apple bør kigge i bagspejlet, for Asus' tablet-pc kommer buldrende - og gør det...


Seneste blogindlæg

Teaser billede

Tvangslukke spørgsmål: Hvad er den bedste løsning?

Hej Vi har mange åbne spørgsmål på Eksperten. Vi ville gerne tvangslukke dem - så et spørgsmål efter f.eks. 6 måneder lukkes. Men der er et par uklarheder som ville være gode at få lidt input til:...


Nyheder fra PC World

Teaser billede

Nu kan du snart hente Windows 8

Den nye offentlige betaversion af Windows 8 er klar i denne måned.


Nyheder fra Computerworld

Teaser billede

Måske snart slut med Androids helt store problem

Android-platformen har længe været plaget af et særligt problem. Men måske er problemet nu ved at være elimineret.


Kurser
Samarbejdspartnere

Udgiver · © 2012 IDG Danmark A/S · Hørkær 18 · 2730 Herlev · Tlf.: 77 300 300 · Fax: 77 300 301 · Brug af personoplysninger