Casa Finanza personale Come evitare l'iniezione di codice in C ++ - dummies

Come evitare l'iniezione di codice in C ++ - dummies

Video: Pulizia sensore pressione Punto mk2 1.2 16V 2024

Video: Pulizia sensore pressione Punto mk2 1.2 16V 2024
Anonim

La prima regola di evitare l'iniezione di codice nei programmi C ++ non è mai, mai, consentire l'input dell'utente per essere elaborato da un interprete di linguaggio generico. Un errore comune con SQL-injection è che il programma accetta l'input dell'utente come se fosse sempre accettabile e lo inserisce in una query SQL che viene quindi inviata al motore di database per l'elaborazione.

Ad esempio, un programma che richiede l'input dell'utente in una data potrebbe essere compromesso. L'approccio più sicuro e intuitivo sarebbe fornire all'utente un grafico del calendario da cui selezionare le date di inizio e di fine. Il programma creerebbe quindi una data in base a ciò che l'utente ha fatto clic.

Se ciò non è possibile, il programma dovrebbe controllare attentamente l'input per assicurarsi che l'input fosse nel formato corretto per una data, in questo caso yyyy / mm / dd < - in altre parole, quattro cifre seguite da una barra seguita da due cifre e una barra e infine altre due cifre. Nient'altro dovrebbe essere considerato input accettabile. A volte non puoi essere così specifico riguardo al formato. Se devi consentire all'utente di inserire un testo flessibile, puoi almeno evitare caratteri speciali. Ad esempio, è praticamente impossibile eseguire l'iniezione di codice SQL senza utilizzare virgolette singole o doppie.

Non è possibile inserire tag HTML senza utilizzare un segno minore di (). O potresti semplicemente prendere l'approccio che non sarà tollerato niente di diverso dal testo ASCII:

// controlla alcune stringhe 's' per assicurarti che sia dritto ASCII size_type off = s. find_first_not_of ("abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ01234567890_"); if (off! = stringa:: npos) {cerr << "errorn";}

Questo codice cerca la stringa

s per un personaggio che non è uno dei caratteri dalla A alla Z, dalla a alla z, Da 0 a 9, o trattino basso. Se trova un tale carattere, il programma rifiuta l'input.

Se si accettano solo i caratteri latini mostrati qui, la propria applicazione non sarà utilizzabile in molti mercati esteri come quelli che non usano set di caratteri inglesi (come arabo, cinese, ebraico o Russo, per citarne solo alcuni). Potrebbe essere necessario prendere l'approccio opposto e cercare i personaggi cattivi.
Come evitare l'iniezione di codice in C ++ - dummies

Scelta dell'editore

Come utilizzare le funzionalità dell'app Klout su dispositivi Apple - dummies

Come utilizzare le funzionalità dell'app Klout su dispositivi Apple - dummies

L'esperienza mobile di Klout è più limitato rispetto al sito web completo. Tuttavia, molte funzionalità sono ancora disponibili con l'app per dispositivi mobili, incluso dare + K ai tuoi influenzatori, controllare il tuo punteggio Klout e apportare semplici modifiche al tuo profilo. E con l'implementazione di Klout per il tuo iPhone Passbook puoi persino usare Klout per ottenere ...

Metriche dei social media: App Android SDK di Google Analytics - dummies

Metriche dei social media: App Android SDK di Google Analytics - dummies

Tracciamento delle metriche di un'applicazione ( un'app) è stata semplificata, ma le app sono ancora isolate. Puoi tenere traccia di ogni app, ma le soluzioni sono ancora in fase di creazione per tenere traccia di tutte le app. Per andare avanti con Google Analytics SDK per la tua app Android, segui questi passaggi: Scarica l'SDK di Google Analytics per Android. Aggiungi la libreria libGoogleanalytics. jar ...

Metriche sui social media: individuazione del momento di trazione con Google+ - dummies

Metriche sui social media: individuazione del momento di trazione con Google+ - dummies

In i social media, il momento di trazione potrebbe anche essere chiamato il "miglior tempo per condividere su Google+ o altri siti sociali. "Il momento migliore per te potrebbe non essere il momento migliore per i tuoi colleghi generatori di contenuti. (Il merito di questo suggerimento principale va a Christopher Penn che per primo condivise la sua osservazione sulla ricerca ...

Scelta dell'editore

Combinazione di due foto sulla tua Nikon D3400 con sovrapposizione immagini - manichini

Combinazione di due foto sulla tua Nikon D3400 con sovrapposizione immagini - manichini

L'opzione Sovrapposizione immagini sulla Il menu di ritocco di Nikon D3400 consente di unire due foto in una. Questa opzione è stata utilizzata per combinare una foto di un lupo mannaro, mostrato a sinistra, con una scena da giardino notturno, mostrata nel mezzo. Il risultato è l'immagine spettrale mostrata a destra. Oooh, spaventoso! Su ...

Scelta di una modalità Esposizione per una Nikon DSLR - manichini

Scelta di una modalità Esposizione per una Nikon DSLR - manichini

La prima impostazione da prendere in considerazione quando si le riprese con la tua Nikon D3100, D5100 o D7000 sono la modalità di esposizione, che puoi selezionare tramite la ghiera dei modi. La tua scelta determina la quantità di controllo che hai rispetto a due impostazioni di esposizione critiche - diaframma e tempo di posa - oltre a molte altre opzioni, incluse quelle relative ...

Scelta del formato immagine JPEG per una reflex Nikon - dummies

Scelta del formato immagine JPEG per una reflex Nikon - dummies

Offerte Nikon D3100, D5100 o D7000 i due tipi di file comuni nella maggior parte delle fotocamere digitali odierne: JPEG e Camera Raw, o semplicemente Raw in breve, che passa dallo specifico moniker NEF (Nikon Electronic Format) sulle fotocamere Nikon. Il tipo di file, talvolta noto anche come formato file, determina come i dati dell'immagine ...

Scelta dell'editore

Comprensione della struttura delle classi Java - dummies

Comprensione della struttura delle classi Java - dummies

Impossibile creare un'applicazione Java senza creare una classe. Tuttavia, i modi in cui si usano le classi all'inizio quando si apprendono su di essi sono stati relativamente semplicistici - Java è in grado di avere una complessità considerevolmente maggiore, che è il punto di questo capitolo. Le classi hanno una struttura specifica. Proprio come i progetti ...

Come utilizzare i metodi astratti in Java - dummies

Come utilizzare i metodi astratti in Java - dummies

Sia le interfacce che le classi astratte hanno metodi astratti in Java. Ma i metodi astratti giocano ruoli leggermente diversi in questi due tipi di tipi di riferimento. Come puoi tenere tutto dritto nella tua mente? La prima cosa da fare è ricordare che nessuno impara a conoscere i concetti di programmazione orientata agli oggetti senza ottenere molti ...

Come utilizzare l'interfaccia CharSequence in Java - dummies

Come utilizzare l'interfaccia CharSequence in Java - dummies

L'API Java include un'interfaccia utile chiamata CharSequence. Tutte e tre queste classi - String, StringBuilder e StringBuffer - implementano questa interfaccia. Questo metodo esiste principalmente per consentire di utilizzare String, StringBuilder e StringBuffer in modo intercambiabile. A tal fine, molti dei metodi delle classi String, StringBuilder e StringBuffer utilizzano CharSequence come parametro ...