Torna indietro   Hardware Upgrade Forum > Software > Programmazione

L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint
L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint
Abbiamo intervistato Sumit Dhawan, CEO di Proofpoint, per capire come stia cambiando il mondo della sicurezza con l'avvento dell'intelligenza artificiale e con il ritmo sempre più serrato a cui vengono trovate vulnerabilità nel software. Un problema significativo, che richiederà del tempo per essere risolto (o quantomeno arginato)
L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026
L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026
La parola d'ordine al Nextcloud Summit 2026, che si è tenuto a Monaco, è stata "sovranità". Non come è spesso usato questo termine in politica ma, al contrario, come capacità positiva di decidere il proprio destino tecnologico, con modalità collaborative e aperte. L'Europa dice già molto nel mondo open source, che viene visto come mezzo per ottenere la tanto agognata autonomia digitale
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più
Dreame X60 Pro Ultra Complete implementa due bracci estensibili, per spazzola e moccio, che si spingono ben oltre quanto visto sino ad oggi permettendo una pulizia di casa ancor più capillare e precisa
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 24-05-2007, 14:23   #1
santaclause83
Member
 
Iscritto dal: Mar 2006
Messaggi: 131
[C]ripulire le stringhe fino al loro ultimo contenuto significativo...

una volta che ho copiato una stringa dentro un buffer,rimangono delle posizioni del buffer inizializzate a caratteri incomprensibili.

come faccio a ripulire la stringa fino all'ultimo carattere significativo?

avevo pensato ad allocare un altra area di memoria con un altro puntatore a stringa grande quanto strlen(stringa sporca),ma stampandone il risultato sembra che strlen tenga conto dello spazio inutilizzato...
santaclause83 è offline   Rispondi citando il messaggio o parte di esso
Old 24-05-2007, 14:32   #2
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Messaggi: 5206
Quote:
Originariamente inviato da santaclause83 Guarda i messaggi
una volta che ho copiato una stringa dentro un buffer,rimangono delle posizioni del buffer inizializzate a caratteri incomprensibili.

come faccio a ripulire la stringa fino all'ultimo carattere significativo?
Probabilmente non hai fatto la copia come si deve. Una stringa deve essere terminata dal carattere nullo, in caso contrario puoi avere brutte sorprese ...
Posta il codice che vediamo.
__________________
Andrea, Senior Java developerSCJP 5 (91%) • SCWCD 5 (94%)
Java Versions Cheat Sheet
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 24-05-2007, 14:47   #3
santaclause83
Member
 
Iscritto dal: Mar 2006
Messaggi: 131
il problema è un pò più complicato,devo prendere una stringa e a seconda degli argomenti,decidere cosa fare.

ho fatto una sscanf sulla stringa in input con il numero massimo degli argomenti da leggere,con i rispettivi caratteri di formattazione.

il problema è che quando c'è un comando che richiede argomenti minori del massimo,per fare le cose fatte bene devo verificare che le altre aree riservate alle stringhe non siano inizializzate,o abbiano un contenuto insignificvativo.

ad esempio,un comando che ha la semantica PRINT NOMEFILE,se dopo l'utente scrive altre cose,devo far si che il comando non abbia più alcun senso,se invece controllo solo i primi due argomenti e gli altri li lascio perdere l'utente potrebbe permettersi di scrivere quello che gli pare,avendo comunque attivato il comando..

insomma avevo pensato a una cosa simile...

ti passo un frammento:

arg2 = (char *)malloc(sizeof(char)*N);

diff = strlen(comandi);
effettivo = (char *)malloc(sizeof(char)*diff);
strcpy(effettivo,comandi);

sscanf(effettivo,"%s %s %s %s",arg1,arg2,arg3,arg4);

//controllo sulla stringa per vedere cosa ho inizializzato
printf("arg1 = %s arg2 = %s arg3 = %s arg4 = %s\n",arg1,arg2,arg3,arg4);

if(strcmp(arg1,"print") == 0 && arg2 != 0 && arg3 == 0 && arg4 == 0){
printf("%s %s\n",arg1,arg2);
return 3;//ritornami il valore corrispondente al codice operativo print
}
else if....controllo simile,ma per altri comandi+

alla fine faccio ritornare un valore di errore dove so che il comando o non è stato scritto o è stato scritto male.

spero di essere stato chiaro...

grazie
santaclause83 è offline   Rispondi citando il messaggio o parte di esso
Old 24-05-2007, 15:06   #4
santaclause83
Member
 
Iscritto dal: Mar 2006
Messaggi: 131
il problema si risolve in parte se inizializzo ogni "arg" come puntatore a char,nel senso che quelli vuoti adesso se li stampo rimangono vuoti.

soltanto che non riesco a trovare il termine di confronto che nella guardia dell'if li fa riconoscere come inutilizzati..

NULL non funziona
EOF mi dice che comparison between pointer e integer non si può fare
"\0" non funziona


santaclause83 è offline   Rispondi citando il messaggio o parte di esso
Old 24-05-2007, 15:10   #5
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Messaggi: 5206
Quote:
Originariamente inviato da santaclause83 Guarda i messaggi
diff = strlen(comandi);
effettivo = (char *)malloc(sizeof(char)*diff);
strcpy(effettivo,comandi);
'diff' contiene il numero di caratteri della stringa, escluso il carattere nullo. La allocazione è sbagliata perché allochi spazio solo per i caratteri della stringa ma non per il nullo. Usando poi strcpy però vengono copiati tutti i caratteri compreso il nullo. Pertanto vai fuori dall'area di memoria allocata.

Per il resto ... vedo che ci sono diverse altre variabili, arg3, arg4, ecc... che non sono come sono dichiarate. Se sono variabili 'automatiche' (locali ad una funzione) e non le hai inizializzate, chiaramente puoi avere molte brutte sorprese.
__________________
Andrea, Senior Java developerSCJP 5 (91%) • SCWCD 5 (94%)
Java Versions Cheat Sheet
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 24-05-2007, 15:20   #6
santaclause83
Member
 
Iscritto dal: Mar 2006
Messaggi: 131
arg3 e arg4 le alloco con una malloc all'inizio della funzione di grandezza prefissata.

se le inizalizzo a NULL i controlli mi funzionano!!


sul problema di diff non mi dava segmentation fault,ma l'ho corretto ugualmente

per ora considero il problema risolto alla prossima e grazie
santaclause83 è offline   Rispondi citando il messaggio o parte di esso
Old 24-05-2007, 15:27   #7
santaclause83
Member
 
Iscritto dal: Mar 2006
Messaggi: 131
PROBLEMA:se inizializzo un puntatore a char come NULL e poi con la sscanf ci vado a scrivere dentro perchè mi restituisce cmque NULL???????
santaclause83 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint L'IA cambia tutte le regole della sicurezza tra ...
L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026 L'Europa conta nella tecnologia e può ess...
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più Dreame X60 Pro Ultra Complete: i bracci si esten...
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati TCL 65C8L, la recensione del SQD-Mini LED da 440...
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro MSI Maestro 500 Wireless: ANC e 90 ore di autono...
I nuovi Samsung Galaxy Watch 9 si mostra...
Einsten aveva ragione, di nuovo: captate...
Top 10 offerte Amazon: 5 sono partite qu...
AI Conf 2026: l'intelligenza artificiale...
Samsung Galaxy S26 scende a 711,49€: un ...
Dopo il maxi blackout, la Spagna cambia ...
Costa meno di un MacBook e fa molto di p...
Ecco tutti i robot aspirapolvere rimasti...
Più partite da seguire in contemporanea?...
389€ sono veramente pochi per questo PC ...
Vesuvius Challenge: srotolato in digital...
Torna oggi a soli 101,79€ grazie a un co...
Steam Machine: addio al 4K 60 fps. Valve...
Cosa aumenterà di prezzo dopo com...
Altro che 2028: Micron ha blindato prezz...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 12:43.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v