Huis Persoonlijke financiën Hoe code-injectie te voorkomen in C ++ - dummies

Hoe code-injectie te voorkomen in C ++ - dummies

Video: Web Programming - Computer Science for Business Leaders 2016 2024

Video: Web Programming - Computer Science for Business Leaders 2016 2024
Anonim

De eerste regel om code-injecties te vermijden in C ++ -programma's is nooit ooit, toegestaan ​​dat gebruikersinvoer kan worden verwerkt door een meertalige taalinterpreter. Een veel voorkomende fout bij SQL-injectie is dat het programma gebruikersinvoer accepteert als altijd acceptabel en invoegt in een SQL-query die vervolgens wordt verzonden naar de database-engine voor verwerking.

Als voorbeeld kan een programma dat om gebruikersinvoer vraagt ​​op een datum, worden gehackt. De veiligste en meest gebruiksvriendelijke benadering zou zijn om de gebruiker een kalenderafbeelding te geven waaruit hij de begin- en einddatum zou kunnen kiezen. Het programma zou dan een datum creëren op basis van waar de gebruiker op geklikt heeft.

Als dit niet mogelijk is, moet het programma zorgvuldig de invoer controleren om te controleren of de invoer in het juiste formaat was voor een datum, in dit geval jjjj / mm / dd < - met andere woorden, vier cijfers gevolgd door een schuine streep gevolgd door twee cijfers en een schuine streep en ten slotte nog twee cijfers. Niets anders zou als acceptabele input moeten worden beschouwd. Soms kun je niet zo specifiek zijn over het formaat. Als u de gebruiker in staat moet stellen flexibele tekst in te voeren, kunt u op zijn minst speciale tekens vermijden. Het is bijvoorbeeld vrijwel onmogelijk om SQL-code-injectie uit te voeren zonder een enkel of dubbel aanhalingsteken te gebruiken.

U kunt geen HTML-tags invoegen zonder een minder dan () -teken te gebruiken. Of u kunt gewoon de benadering aannemen dat iets anders dan ASCII-tekst niet wordt getolereerd:

// controleer wat string 's' om er zeker van te zijn dat het straight ASCII size_type off = s is. find_first_not_of ("abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ01234567890_"); if (off! = string:: npos) {cerr << "errorn";}

Deze code doorzoekt de string

s naar een teken dat niet een van de tekens A tot en met Z is, a tot en met z, 0 t / m 9, of onderstrepingsteken. Als het een dergelijk teken vindt, wijst het programma de invoer af.

Als u alleen de hier getoonde Latijnse tekens toestaat, zal uw toepassing niet bruikbaar zijn op veel buitenlandse markten, zoals landen die geen gebruik maken van Engelse tekensets (zoals Arabisch, Chinees, Hebreeuws of Russisch, om er maar een paar te noemen). Misschien moet je de tegenovergestelde benadering nemen en gewoon op zoek naar de slechte karakters.
Hoe code-injectie te voorkomen in C ++ - dummies

Bewerkers keuze

Een Oracle-omgeving instellen - dummies

Een Oracle-omgeving instellen - dummies

Als u een typische PL / SQL-omgeving wilt instellen, hebt u de volgende componenten: Databaseserver: dit is een computer (of een reeks computers) die de Oracle-database uitvoert. Oracle werkt in veel populaire computeromgevingen. De meest gebruikte met Oracle zijn UNIX, Linux of een versie van Microsoft Windows. PL / SQL wordt meestal uitgevoerd ...

SQL-rijwaarden en -waarden - dummies

SQL-rijwaarden en -waarden - dummies

De waarden die worden bewaard in de cellen die de snijpunten van de SQL-database vormen De rijen en kolommen van de tabel zijn de grondstoffen waaruit u zinvolle relaties en trends kunt afleiden. Rijwaarden De meest zichtbare waarden in een database zijn tabelrijwaarden. Dit zijn de waarden die elke rij van een databasetabel ...

SQL eerste, tweede en derde normale vormen - dummies

SQL eerste, tweede en derde normale vormen - dummies

Er zijn drie bronnen van wijzigingsanomalieën in SQL Deze worden gedefinieerd als eerste, tweede en derde normale vormen (1NF, 2NF, 3NF). Deze normale vormen fungeren als remedies voor het wijzigen van anomalieën. Eerste normale vorm Om in de eerste normale vorm (1NF) te zijn, moet een tabel de volgende eigenschappen hebben: De tabel is tweedimensionaal met rijen en ...

Bewerkers keuze

Een kijkje nemen in het syndroom van Empty-Nest - dummies

Een kijkje nemen in het syndroom van Empty-Nest - dummies

Een veel voorkomende misvatting is dat wanneer de kinderen van een stel vertrekken thuis, zullen pappa en mama het syndroom van empty-nest ontwikkelen. Ja, ze hebben misschien een leeg nest, maar voor sommige paren bloeit hun liefdesleven in deze periode van hun leven. De slachtoffers van het syndroom zijn de paren waarvan de relatie uit elkaar valt als zij de enige ...

STD's: wat u moet weten over herpes - dummies

STD's: wat u moet weten over herpes - dummies

Herpes, veroorzaakt door het herpes simplex-virus (HSV) ), is een ongeneeslijke SOA. Herpes heeft eigenlijk twee vormen: herpes simplex-type 1 (HSV-1) en herpes simplex-type 2 (HSV-2). HSV-1 wordt meestal geassocieerd met koortsblaasjes en koortsblaren boven de taille. "Ongeveer 80 procent van de Amerikaanse volwassenen heeft orale herpes. Ongeveer 25 procent van ...

Tiener Geslacht: hoe te weten Hoe ver te gaan - dummies

Tiener Geslacht: hoe te weten Hoe ver te gaan - dummies

Een van de grootste vragen voor tieners is niet "Zou ik seks moeten hebben? "Maar" Hoe ver moet ik gaan? "Terwijl het eigen comfortniveau en dat van de partner de topprioriteit zou moeten zijn in deze beslissing, spelen andere factoren een rol, vooral als tieners dat amorfe concept van" het derde honk overwegen. "" Derde basis "...

Bewerkers keuze

Tien voorwaarden American Football Announcers Gebruik - dummies

Tien voorwaarden American Football Announcers Gebruik - dummies

Een van de moeilijkste en meest intimiderende onderdelen over het volgen van een Amerikaans voetbalwedstrijd is dat de presentatoren soms een vreemde taal lijken te spreken die alleen bekend is bij echte voetballiefhebbers. Maar als je een aantal belangrijke termen onthoudt, ben je ver voor op het spel. Hier zijn enkele voetbaltermen die je misschien hoort, ...

Het begin van een voetbalspel: The Kickoff - dummies

Het begin van een voetbalspel: The Kickoff - dummies

Voor Amerikaanse voetbalfans, de openingsaftrap is een opwindende start voor elke game. Ze zien de tweezijdige sensatie van het ene team dat probeert het andere te blokkeren en helpt de herhaler om door en voorbij 11 snelladers van het trapende team te rennen. (Wel, maak die tien spelers.De kicker staat meestal rond de 50-yard-lijn, ...

Uw voetbalcoachtoelen afstemmen op een leeftijdsgroep - dummies

Uw voetbalcoachtoelen afstemmen op een leeftijdsgroep - dummies

Elk kind in uw team is anders zoveel manieren. Sommigen zijn begaafde hardlopers, anderen kunnen duizelingwekkende vangsten maken en wat moeite om simpelweg de basistechnieken van het spel te vatten. Ongeacht de sterke en zwakke punten van de kinderen, die overal op de kaart staan, hebben jongeren algemene kenmerken die worden beïnvloed ...