Hem Personliga finanser Hur man undviker kodinjicering i C ++-dummies

Hur man undviker kodinjicering i C ++-dummies

Video: 10 Tips på hur du undviker en blind mördare 2024

Video: 10 Tips på hur du undviker en blind mördare 2024
Anonim

Den första regeln att undvika kodinjektion in i C ++ -programmen är aldrig någonsin tillåta användarinmatning att behandlas av en tolkare med allmänt ändamål. Ett vanligt fel med SQL-injektion är att programmet accepterar användarinmatning som om det alltid var acceptabelt och lägger in det i en SQL-fråga som sedan skickas till databasmotorn för bearbetning.

Som ett exempel kan ett program som frågar efter användardata på ett datum hackas. Det säkraste och mest användarvänliga tillvägagångssättet är att ge användaren en kalendergrafik från vilken han kunde välja start- och slutdatum. Programmet skulle då skapa ett datum baserat på vad användaren klickade på.

Om detta inte är möjligt bör programmet noggrant kontrollera ingången för att se till att ingången var i rätt format för ett datum, i det här fallet yyyy / mm / dd < - med andra ord fyra siffror följt av ett snedstreck följt av två siffror och ett snedstreck och äntligen ytterligare två siffror. Inget annat bör anses vara acceptabel input. Ibland kan du inte vara så specifik om formatet. Om du måste tillåta användaren att skriva in flexibel text kan du åtminstone undvika specialtecken. Till exempel är det ganska mycket omöjligt att göra SQL-kodinsprutning utan att använda antingen en enkel eller dubbel citat.

Du kan inte infoga HTML-taggar utan att använda ett mindre än () tecken. Eller du kan bara ta tillvägagångssättet att något annat än ASCII-text inte tolereras:

// kolla några strängar för att se till att det är rakt ASCII size_type off = s. find_first_not_of ("abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ01234567890_"); om {av! = sträng:: npos) {cerr << "errorn";}

Denna kod söker strängen

s för ett tecken som inte är ett av tecknen A till och med Z, a till och med z, 0 till 9, eller understrykning. Om det finns ett sådant tecken, avvisar programmet ingången.

Om du bara tillåter de latinska tecknen som visas här, kommer din ansökan inte att användas på många utländska marknader som de som inte använder engelska teckenuppsättningar (som arabiska, kinesiska, hebreiska eller Ryska, för att bara nämna några). Du kanske måste ta det motsatta tillvägagångssättet och leta efter de dåliga karaktärerna.
Hur man undviker kodinjicering i C ++-dummies

Redaktörens val

Hur man tar bort eller minimerar webbdelar i SharePoint 2013 - dummies

Hur man tar bort eller minimerar webbdelar i SharePoint 2013 - dummies

Du har två alternativ för att ta bort en webbdel från din SharePoint-sida - stängning eller radering. Att stänga en webbdel lämnar webbdelen på sidan så att du kan aktivera den igen för framtida användning. Att ta bort webbdelen tar bort webbdelen från din sida (men tar inte bort den från SharePoint). Till ...

För att ladda ner Apps från SharePoint Store - dummies

För att ladda ner Apps från SharePoint Store - dummies

Förutom de appar som följer med SharePoint, Du kan också lägga till appar från tredje part. Dessa tredjepartsprogram visas i SharePoint-butiken. Om du använder SharePoint Online har du tillgång till hela butiken. Om du använder SharePoint On-Premise kan dina lokala IT-administratörer ha låst ned de appar som ...

Hur man visar visningar via webbdelar i SharePoint 2013 - dummies

Hur man visar visningar via webbdelar i SharePoint 2013 - dummies

Du vill visa din SharePoint appdata med annan text och webbdelar på flera platser, till exempel hemsidor för hemsida, webbsidor eller publiceringssidor. I dessa situationer vill du inte att dina användare ska interagera med själva appen med alla redigeringsalternativ. Du vill bara att de ska se flera ...

Redaktörens val

Vad är Kik? - dummies

Vad är Kik? - dummies

Grundades 2009, är Kik en gratis snabbmeddelandeprogram utvecklad från Kik Interactive. Kik är tillgängligt på Android, Windows Phone och iOS-enheter. Applikationen är modellerad efter BlackBerry Messenger. Kik använder den befintliga smarttelefonens dataplan eller Wi-Fi för att skicka och ta emot meddelanden, videoklipp, foton, mobila webbsidor, skisser och annat innehåll. ...

ÖVersätt Twitter Slang och Jargon - dummies

ÖVersätt Twitter Slang och Jargon - dummies

Diskussioner om och om Twitter är fulla med alla slags förkortningar och jargong som kan förvirra nya Twitter-användare. Vad talar folk om (och tweeting) om? Följande ordlista definierar några av de förvirrande förkortningarna och Twitter-lingo du kan komma över. AFAIK: Så vitt jag vet. bot: Ett konto som drivs av en ...

Vad är Letgo? - dummies

Vad är Letgo? - dummies

Letgo är en mobil klassificerad applikation som tillåter användare att köpa från och sälja till andra lokalt. Du kan använda Letgo till fyndbutik eller slutligen släppa på saker som samlar damm runt ditt hus. I likhet med andra classifieds-applikationer som Wallapop eller Craigslist kommer säljare att skicka ett objekt och vänta på en köpare ...

Redaktörens val

Vanliga kodningsfel - dummies

Vanliga kodningsfel - dummies

Koden fungerar inte? Här är några vanliga misstag som kan gå upp till och med även den mest erfarna kodaren. Om din kod inte kommer att köras, försök att springa ned den här checklistan för att se om du har några av dessa fel: Har inte en slutlig HTML-tagg efter varje öppnande HTML-tagg . Saknade parentes i ...

Grundläggande kodningsordförråd - dummies

Grundläggande kodningsordförråd - dummies

Kodning har ett omfattande vokabulär som för lekmän kan verka som ogenomtränglig technobabble. Oavsett om du läser kodningsrelaterad artikel online eller pratar med en utvecklare på jobbet hörs det kanske ord som du inte har hört förut eller som har en annan mening i en kodande kontext. Här är några vanliga ordförrådsord att veta: Allmänt ...