Avatar billede badal Nybegynder
04. maj 2004 - 12:46 Der er 1 kommentar og
2 løsninger

SQL injections

Jeg benytter Rowfilter i et dataset objekt til at filtere data. Hvordan kan jeg tage højde for at en SQL injection ikke opstår i nedenstående sætning?

dataview.RowFilter = " subject = '" + txtSearch.Text + "' ";
Avatar billede jimmidreng Nybegynder
04. maj 2004 - 13:45 #1
txtSearch.Text.Replace("'", "").Replace(Chr(34), "").Replace(";","")

giver en ok sikker løsning, da man så ikke kan hoppe ud af klausulen.
Avatar billede jimmidreng Nybegynder
04. maj 2004 - 13:52 #2
Du kan også bruge en funktion jeg lavede til det samme engang:
husk Imports System.Text.RegularExpressions i toppen.

Function InjProtect(ByVal Query As String) As String
Dim RX As New Regex("/(\%27)|(\')|(\-\-)|(\%23)|(#)/ix", RegexOptions.Singleline)
Query = RX.Replace(Query, "")
Return Query
End Function

så kalder du den bare således:
dataview.RowFilter = " subject = '" + injProtect(txtSearch.Text) + "' ";
Avatar billede badal Nybegynder
04. maj 2004 - 16:40 #3
Jeg kunne godt bruge det første svar. Jeg lavede en funktionen ud af det, som kan ses i C# udgave:
private string InjProtect(string StrSql)
{
return StrSql.Replace("'", "").Replace(Convert.ToChar(34),Convert.ToChar("")).Replace(";","");
}

Desuden vil jeg høre, hvordan man kan nå frem til følgende udtryk?
Regex("/(\%27)|(\')|(\-\-)|(\%23)|(#)/ix", RegexOptions.Singleline)
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
IT-kurser om Microsoft 365, sikkerhed, personlig vækst, udvikling, digital markedsføring, grafisk design, SAP og forretningsanalyse.

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester