Hjem Personlig finansiering Sådan undgår du kodeinjektion i C ++ - dummies

Sådan undgår du kodeinjektion i C ++ - dummies

Video: Sådan undgår du indbrud i julen 2024

Video: Sådan undgår du indbrud i julen 2024
Anonim

Den første regel om at undgå kodeinjektion ind i C ++ programmer er aldrig nogensinde tillade brugerindgang til at blive behandlet af en almindelig sprogtolk. En almindelig fejl ved SQL-indsprøjtning er, at programmet accepterer brugerinddata, som om det altid var acceptabelt og indsætter det i en SQL-forespørgsel, som det derefter sender ud til databasemotoren til behandling.

Som et eksempel kan et program, der beder om brugerindgang på en dato, blive hacket. Den sikreste og mest brugervenlige tilgang ville være at give brugeren en kalender grafik, hvorfra han kunne vælge start- og slutdatoer. Programmet vil derefter oprette en dato baseret på, hvad brugeren klikker på.

Hvis dette ikke er muligt, skal programmet omhyggeligt kontrollere indgangen for at sikre, at indgangen var i korrekt format for en dato, i dette tilfælde yyyy / mm / dd < - med andre ord fire cifre efterfulgt af et skråstreg efterfulgt af to cifre og en skråstreg og endelig to yderligere cifre. Intet andet skal betragtes som acceptabel input. Nogle gange kan du ikke være så specifik om formatet. Hvis du skal give brugeren mulighed for at indtaste fleksibel tekst, kan du i det mindste undgå specialtegn. For eksempel er det stort set umuligt at lave SQL-kodeinjektion uden at bruge enten et enkelt eller dobbelt citat.

Du kan ikke indsætte HTML-tags uden at bruge et mindre end () tegn. Eller du kan bare tage tilnærmelsen om, at alt andet end ASCII-tekst ikke tolereres:

// Tjek nogle snor 's for at sikre, at det er lige ASCII size_type off = s. find_first_not_of ("abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ01234567890_"); hvis (off! = string:: npos) {cerr << "errorn";}

Denne kode søger strengen

s for et tegn, der ikke er et af tegnene A til Z, a til og med z, 0 til 9 eller understregning. Hvis den finder et sådant tegn, afviser programmet indgangen.

Hvis du kun tillader de latinske tegn, der vises her, vil din ansøgning ikke være anvendelig på mange udenlandske markeder som dem, der ikke bruger engelske tegnsæt (såsom arabisk, kinesisk, hebraisk eller Russisk, for blot at nævne nogle få). Du må muligvis tage den modsatte tilgang og bare kigge efter de dårlige tegn.
Sådan undgår du kodeinjektion i C ++ - dummies

Valg af editor

Routingprotokollvalgskriterier - dummies

Routingprotokollvalgskriterier - dummies

Folk bruger to grundlæggende metoder til klassificering af ruteprotokoller - hvor de bruges og af hvordan de beregner routing. Du kan se, hvordan du vælger protokoller baseret på, hvor du planlægger at bruge dem, måden protokollen håndterer data på, og hvordan din router vælger hvilken protokol der skal bruges, når mere end en ...

Indstilling af Cisco Device Timeouts - dummies

Indstilling af Cisco Device Timeouts - dummies

Uden at indstille timeout-indstillinger for Cisco Device Privileged EXEC-tilstand, dine sessioner forbliver åbne på ubestemt tid. Dette er især farligt for konsolporten. Uden timeout parametre aktiveret, hvis administratoren ikke logger ud, har en indtrenger adgang og ingen problemer får forhøjede tilladelser. For at undgå denne potentielt farlige situation behøver du kun skrive a ...

Router Ethernet-interfacekonfiguration - dummies

Router Ethernet-interfacekonfiguration - dummies

Du starter processen med at konfigurere router Ethernet-grænseflader ved at foretage en fysisk forbindelse til din router. Når du har etableret forbindelsen, kan du fortsætte med den grundlæggende konfiguration af Ethernet-, Fast Ethernet- eller Gigabit Ethernet-forbindelser. Tilslutning til din router For at starte din konfiguration skal du oprette forbindelse til din router og komme ind i ...

Valg af editor

Med fokus på nogle hurtige løsninger til fotofile - dummier

Med fokus på nogle hurtige løsninger til fotofile - dummier

På trods af alle kameraproducenters forsøg på at gør fotografering idiotsikker, vi laver alle stadig mindre end perfekte billeder. Nogle gange er vi problemet - vi er for tætte eller for langt væk, eller kan ikke finde ud af, hvordan du bruger kameraets tåbebeskyttelsesfunktioner. Nogle gange er problemet, at virkeligheden nøjagtigt nægter at overholde vores forventninger: Himlen er ...

Lær at kende dine Manga Studio Layer Typer - Dummies

Lær at kende dine Manga Studio Layer Typer - Dummies

Manga Studio giver et udvalg af lag typer til brug i dit arbejde. Når du lærer at forstå og forstå, hvordan lag fungerer, vil du spekulere på, hvordan du nogensinde har arbejdet uden dem. Her er en introduktion til, hvad Manga Studio har til opbevaring for dig i sin lag lineup: Raster Layer: Dette er det grundlæggende ...

Få dit mobilwebsted tildelt på sociale bogmærker - dummies

Få dit mobilwebsted tildelt på sociale bogmærker - dummies

Populariteten af ​​websider med antallet af stemmer, de får. Resultatet er, at disse websteder er gode ressourcer til folk, der ønsker at holde øje med, hvad der er populært online. De fleste tilbyder speciel software, der gør det nemt for alle at stemme på et websted. Få dit websted opført ...

Valg af editor

Automatisk opdatering af din journal i Outlook 2000 - dummies

Automatisk opdatering af din journal i Outlook 2000 - dummies

Stardat 2001: På Star Trek, Virksomheden gør trofast daglige poster i kaptajnens log. Kaptajnen registrerer oplysninger om de planeter, besætningen har udforsket, udlændinge, de har kæmpet, og de bizarre fænomener, de har observeret ud i det dybe rum, hvor ingen er gået før! Nu er det din tur. Bare ...

Slet og gendan kontakter i Outlook - dummies

Slet og gendan kontakter i Outlook - dummies

Med Outlook, du behøver ikke at rive sider ud af en papir adressebog for at slippe af med en persons oplysninger; bare slet kontakten. Slettede kontakter går til mappen Slette emner i Outlook, indtil næste gang du tømmer mappen Slette elementer, så du kan hente dem derfra, hvis du laver ...