Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
vivo X300 Pro rappresenta un'evoluzione misurata della serie fotografica del produttore cinese, con un sistema di fotocamere migliorato, chipset Dimensity 9500 di ultima generazione e l'arrivo dell'interfaccia OriginOS 6 anche sui modelli internazionali. La scelta di limitare la batteria a 5.440mAh nel mercato europeo, rispetto ai 6.510mAh disponibili altrove, fa storcere un po' il naso
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2 è la nuova handheld PC gaming con processore AMD Ryzen Z2 Extreme (8 core Zen 5/5c, GPU RDNA 3.5 16 CU) e schermo OLED 8,8" 1920x1200 144Hz. È dotata anche di controller rimovibili TrueStrike con joystick Hall effect e una batteria da 74Wh. Rispetto al dispositivo che l'ha preceduta, migliora ergonomia e prestazioni a basse risoluzioni, ma pesa 920g e costa 1.299€ nella configurazione con 32GB RAM/1TB SSD e Z2 Extreme
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
A re:Invent 2025, AWS mostra un’evoluzione profonda della propria strategia: l’IA diventa una piattaforma di servizi sempre più pronta all’uso, con agenti e modelli preconfigurati che accelerano lo sviluppo, mentre il cloud resta la base imprescindibile per governare dati, complessità e lock-in in uno scenario sempre più orientato all’hybrid cloud
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 24-07-2010, 15:37   #1
Matrixbob
Senior Member
 
L'Avatar di Matrixbob
 
Iscritto dal: Jul 2001
Messaggi: 9947
[PHP] Cosa usate x fare escape dei caratteri in input ed evitare SqlInject?

  • addslashes
  • htmlspecialchars
  • htmlentities
  • mysql_real_escape_string
  • urlencode
  • mysqli_prepare
......................................................
__________________
Aiuta la ricerca col tuo PC: >>Calcolo distribuito BOINC.Italy: unisciti anche tu<<
Più largo è il sorriso, più affilato è il coltello.

Ultima modifica di Matrixbob : 18-09-2010 alle 10:01.
Matrixbob è offline   Rispondi citando il messaggio o parte di esso
Old 24-07-2010, 15:50   #2
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2782
addslashes: http://php.net/manual/en/function.addslashes.php

htmlspecialchars serve a sostituire i caratteri speciali (non so se si chiamano proprio così) in entità html, quindi ad esempio & verrà sostituito con &amp; e < con &lt;
E' molto utile per evitare gli attacchi xss: Prima di stampare i dati presi dal database o passati tramite post o get gli dai una passata con htmlentities.

Ultima modifica di wingman87 : 24-07-2010 alle 15:53.
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 24-07-2010, 15:52   #3
Matrixbob
Senior Member
 
L'Avatar di Matrixbob
 
Iscritto dal: Jul 2001
Messaggi: 9947
Quote:
Originariamente inviato da wingman87 Guarda i messaggi
OK, e sta famosa get_magic_quotes_gpc() ormai è dreprecata?
__________________
Aiuta la ricerca col tuo PC: >>Calcolo distribuito BOINC.Italy: unisciti anche tu<<
Più largo è il sorriso, più affilato è il coltello.
Matrixbob è offline   Rispondi citando il messaggio o parte di esso
Old 24-07-2010, 15:55   #4
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2782
Non mi sembra (da quanto leggo nella documentazione), ti conviene fare sempre il controllo
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 24-07-2010, 15:57   #5
lock cmpxchg8b %ebx
Member
 
Iscritto dal: Apr 2010
Messaggi: 56
http://www.php.net/manual/en/mysqli.prepare.php
lock cmpxchg8b %ebx è offline   Rispondi citando il messaggio o parte di esso
Old 24-07-2010, 15:58   #6
Matrixbob
Senior Member
 
L'Avatar di Matrixbob
 
Iscritto dal: Jul 2001
Messaggi: 9947
Quote:
Originariamente inviato da lock cmpxchg8b %ebx Guarda i messaggi
MySqlI non presuppone che utilizzi mysqlI?
CMQ studio anche quello, 1 altro utene sul foru postò:
PHP Security Guide
__________________
Aiuta la ricerca col tuo PC: >>Calcolo distribuito BOINC.Italy: unisciti anche tu<<
Più largo è il sorriso, più affilato è il coltello.
Matrixbob è offline   Rispondi citando il messaggio o parte di esso
Old 24-07-2010, 16:42   #7
lock cmpxchg8b %ebx
Member
 
Iscritto dal: Apr 2010
Messaggi: 56
Quote:
Originariamente inviato da Matrixbob Guarda i messaggi
MySqlI non presuppone che utilizzi mysqlI?
Si, perché?
È soltanto un modulo di PHP diverso, il database d'appoggio è sempre MySQL.
lock cmpxchg8b %ebx è offline   Rispondi citando il messaggio o parte di esso
Old 24-07-2010, 17:56   #8
Matrixbob
Senior Member
 
L'Avatar di Matrixbob
 
Iscritto dal: Jul 2001
Messaggi: 9947
Quote:
Originariamente inviato da lock cmpxchg8b %ebx Guarda i messaggi
Si, perché?
È soltanto un modulo di PHP diverso, il database d'appoggio è sempre MySQL.
Ah ok, tutto pienamente compatibile?
__________________
Aiuta la ricerca col tuo PC: >>Calcolo distribuito BOINC.Italy: unisciti anche tu<<
Più largo è il sorriso, più affilato è il coltello.
Matrixbob è offline   Rispondi citando il messaggio o parte di esso
Old 24-07-2010, 17:56   #9
Matrixbob
Senior Member
 
L'Avatar di Matrixbob
 
Iscritto dal: Jul 2001
Messaggi: 9947
Quote:
Originariamente inviato da lock cmpxchg8b %ebx Guarda i messaggi
Si, perché?
È soltanto un modulo di PHP diverso, il database d'appoggio è sempre MySQL.
Ah ok, tutto pienamente compatibile?
__________________
Aiuta la ricerca col tuo PC: >>Calcolo distribuito BOINC.Italy: unisciti anche tu<<
Più largo è il sorriso, più affilato è il coltello.
Matrixbob è offline   Rispondi citando il messaggio o parte di esso
Old 24-07-2010, 17:56   #10
Matrixbob
Senior Member
 
L'Avatar di Matrixbob
 
Iscritto dal: Jul 2001
Messaggi: 9947
Quote:
Originariamente inviato da lock cmpxchg8b %ebx Guarda i messaggi
Si, perché?
È soltanto un modulo di PHP diverso, il database d'appoggio è sempre MySQL.
Ah ok, tutto pienamente compatibile?
__________________
Aiuta la ricerca col tuo PC: >>Calcolo distribuito BOINC.Italy: unisciti anche tu<<
Più largo è il sorriso, più affilato è il coltello.
Matrixbob è offline   Rispondi citando il messaggio o parte di esso
Old 24-07-2010, 18:27   #11
dojolab
Senior Member
 
L'Avatar di dojolab
 
Iscritto dal: Jun 2010
Città: Varese
Messaggi: 996
Quote:
Originariamente inviato da Matrixbob Guarda i messaggi
OK, e sta famosa get_magic_quotes_gpc() ormai è dreprecata?
Si può disattivare dal PHP.ini, solo in PHP6 verrà tolta (così si dice).
Io uso una mia funzione che elimina determinati caratteri (in sequenza) ed esegue l'escape finale con addslashes.
__________________
Il mercatino di dojolab: VENDO UN PO' DI COSE! VAI
Vendo Libro Oracle 10g GUIDA COMPLETA della Oracle Press, ITALIANO: LINK
dojolab è offline   Rispondi citando il messaggio o parte di esso
Old 26-07-2010, 10:36   #12
Hiskrtapps
Senior Member
 
L'Avatar di Hiskrtapps
 
Iscritto dal: Nov 2000
Città: Bussero (MI)
Messaggi: 1263
Quote:
Originariamente inviato da Matrixbob Guarda i messaggi
Ah ok, tutto pienamente compatibile?
Si, ed è la soluzione più corretta.
Hiskrtapps è offline   Rispondi citando il messaggio o parte di esso
Old 26-07-2010, 10:58   #13
Matrixbob
Senior Member
 
L'Avatar di Matrixbob
 
Iscritto dal: Jul 2001
Messaggi: 9947
Quote:
Originariamente inviato da Matrixbob Guarda i messaggi
?
  • htmlspecialchars
  • htmlentities
  • mysql_real_escape_string
  • urlencode
Quindi basta la sola mysqli_prepare? Stop? Nessuna di queste altre?
Non funzionasse sugli Host tipo Aruba/Netsons sarebbe perchè non hanno caricato il modulo?
Oppure non c'è possibilità che non funzioni? Dove c'è PHP5 c'è questo set di funzioni?

Ho visto che c'è sia OO che procedurale, dato che restituisce la stessa cosa "mysqli_stmt" posso usare nella mia procedura anche quella ad oggetti o è meglio non mischiare?
Quote:
Object oriented style
Codice PHP:
mysqli_stmt mysqli::prepare string $query 
Procedural style
Codice PHP:
mysqli_stmt mysqli_prepare mysqli $link string $query 
Noto:
Codice PHP:
$link mysqli_connect("localhost""my_user""my_password""world"); 
devo cambiare tutte le varie aperture/chiusure con le nuove mysqli_X?
__________________
Aiuta la ricerca col tuo PC: >>Calcolo distribuito BOINC.Italy: unisciti anche tu<<
Più largo è il sorriso, più affilato è il coltello.

Ultima modifica di Matrixbob : 28-07-2010 alle 17:35.
Matrixbob è offline   Rispondi citando il messaggio o parte di esso
Old 26-07-2010, 11:14   #14
Matrixbob
Senior Member
 
L'Avatar di Matrixbob
 
Iscritto dal: Jul 2001
Messaggi: 9947
Piccolo
voi per caso utilizzate anche
Codice PHP:
mysql_free_result($result); 
oppure a fine script c'è auto dispose del fetch?
__________________
Aiuta la ricerca col tuo PC: >>Calcolo distribuito BOINC.Italy: unisciti anche tu<<
Più largo è il sorriso, più affilato è il coltello.
Matrixbob è offline   Rispondi citando il messaggio o parte di esso
Old 28-07-2010, 17:34   #15
Matrixbob
Senior Member
 
L'Avatar di Matrixbob
 
Iscritto dal: Jul 2001
Messaggi: 9947
UP!
Questo lo chiudiamo con la soluzione: "mysqli_prepare"?
__________________
Aiuta la ricerca col tuo PC: >>Calcolo distribuito BOINC.Italy: unisciti anche tu<<
Più largo è il sorriso, più affilato è il coltello.
Matrixbob è offline   Rispondi citando il messaggio o parte di esso
Old 29-07-2010, 00:37   #16
malocchio
Senior Member
 
L'Avatar di malocchio
 
Iscritto dal: Feb 2007
Città: Verona
Messaggi: 1060
Quote:
Originariamente inviato da Matrixbob Guarda i messaggi
UP!
Questo lo chiudiamo con la soluzione: "mysqli_prepare"?
Mi permetto di fare il pignolo e precisare che la soluzione non è "mysqli_prepare", ma l'utilizzo dei Prepared Statements (supportati appunto solo dalla libreria MySQLi). La funzione mysqli_prepare è solo il primo passo per ottenere un resultset da uno statement.
La cosa interessante è che viene fatto automaticamente dal sistema l'escaping dei valori assegnati ai parametri dello statement.

Attenzione che però la libreria MySQLi non è supportata da tutti gli hosting, soprattutto quelli gratuiti, quindi informarsi bene prima di utilizzarla.
__________________
malocchio è offline   Rispondi citando il messaggio o parte di esso
Old 18-09-2010, 10:04   #17
Matrixbob
Senior Member
 
L'Avatar di Matrixbob
 
Iscritto dal: Jul 2001
Messaggi: 9947
Quote:
Originariamente inviato da lock cmpxchg8b %ebx Guarda i messaggi
Rieccomi rientrato da vacanze e tour in London per vedre se migrare spero vi siate riposati a che voi! [chiuso ]
Effettivamente vedo che ritorna un mysqli statemant
Quote:
mysqli_stmt mysqli_prepare ( mysqli $link , string $query )
, quindi non un testo normale che posso inserire, ma qualcosa a usare con altri mysqli:qualcosa?
__________________
Aiuta la ricerca col tuo PC: >>Calcolo distribuito BOINC.Italy: unisciti anche tu<<
Più largo è il sorriso, più affilato è il coltello.

Ultima modifica di Matrixbob : 18-09-2010 alle 10:06.
Matrixbob è offline   Rispondi citando il messaggio o parte di esso
Old 18-09-2010, 10:09   #18
Matrixbob
Senior Member
 
L'Avatar di Matrixbob
 
Iscritto dal: Jul 2001
Messaggi: 9947
Quote:
Originariamente inviato da Matrixbob Guarda i messaggi
Rieccomi rientrato da vacanze e tour in London per vedre se migrare spero vi siate riposati a che voi! [chiuso ]
Effettivamente vedo che ritorna un mysqli statemant

, quindi non un testo normale che posso inserire, ma qualcosa a usare con altri mysqli:qualcosa?
Eh si, intuitivamente direi di si leggendo la spiegazione del prepare
Quote:
Procedural style only: A link identifier returned by mysqli_connect() or mysqli_init()
, devo passare i mysql_ a mysqli_

Sto iniziando col cambiare il tipico
Codice PHP:
//Stringa di connessione
$connessione=@mysql_connect($server$utente$password) or die(errore());
//selezione del database
$db=mysql_select_db($database$connessione) or die(errore()); 
con
Codice PHP:
//Stringa di connessione e selezione del database
$link = @mysqli_connect($server$utente$password$database);
/* check connection */
if (!$link) {
    die(
'Connect Error: ' mysqli_connect_error() . ' ' mysqli_connect_errno());

__________________
Aiuta la ricerca col tuo PC: >>Calcolo distribuito BOINC.Italy: unisciti anche tu<<
Più largo è il sorriso, più affilato è il coltello.

Ultima modifica di Matrixbob : 18-09-2010 alle 11:19.
Matrixbob è offline   Rispondi citando il messaggio o parte di esso
Old 18-09-2010, 10:27   #19
Matrixbob
Senior Member
 
L'Avatar di Matrixbob
 
Iscritto dal: Jul 2001
Messaggi: 9947
Ma nell'esempio del manuale online qui sotto riportato
Codice PHP:
$city "Amersfoort";
$link mysqli_connect("localhost""my_user""my_password""world");

/* create a prepared statement */
if ($stmt mysqli_prepare($link"SELECT District FROM City WHERE Name=?")) {

    
/* bind parameters for markers */
    
mysqli_stmt_bind_param($stmt"s"$city);

    
/* execute query */
    
mysqli_stmt_execute($stmt);

    
/* bind result variables */
    
mysqli_stmt_bind_result($stmt$district);

    
/* fetch value */
    
mysqli_stmt_fetch($stmt);

    
printf("%s is in district %s\n"$city$district);

    
/* close statement */
    
mysqli_stmt_close($stmt);

, a che servono i due "bind"
Codice PHP:
/* bind parameters for markers */
mysqli_stmt_bind_param($stmt"s"$city); 
e
Codice PHP:
/* bind result variables */
mysqli_stmt_bind_result($stmt$district); 
, sono obbligatori altrimenti exec e fetch non funzionano?
__________________
Aiuta la ricerca col tuo PC: >>Calcolo distribuito BOINC.Italy: unisciti anche tu<<
Più largo è il sorriso, più affilato è il coltello.
Matrixbob è offline   Rispondi citando il messaggio o parte di esso
Old 18-09-2010, 10:57   #20
Matrixbob
Senior Member
 
L'Avatar di Matrixbob
 
Iscritto dal: Jul 2001
Messaggi: 9947
Ok funziona. Ma in questo modo non devo fare l'escape di nient'altro? Only mysqli statement and stop?

Codice PHP:
<?php
    
include("connetti.php");
    
$titolo strtoupper($titolo);
    
$datatime date('Y-m-d H:i:s');
    
$query "INSERT INTO privato (u_modifica, titolo, testo) VALUES (?, ?, ?)";                
    if (
$stmt mysqli_prepare($link$query))
        {
        
mysqli_stmt_bind_param($stmt'sss'$datatime$titolo$testo);
        print(
"<font color=\"green\">Elemento:<br />$titolo<br />inserito correttamente.</font><br />");
        
mysqli_stmt_execute($stmt);
        }
    else{ die(
errore()); }                                         
    include(
"disconnetti.php");
    print(
"<meta http-equiv=\"Refresh\" content=\"5; url=http://$HTTP_HOST/ciccio/pasticcio.php\" />");
?>
__________________
Aiuta la ricerca col tuo PC: >>Calcolo distribuito BOINC.Italy: unisciti anche tu<<
Più largo è il sorriso, più affilato è il coltello.

Ultima modifica di Matrixbob : 18-09-2010 alle 13:31.
Matrixbob è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria Recensione vivo X300 Pro: è ancora lui il...
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'...
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti AWS re:Invent 2025: inizia l'era dell'AI-as-a-Se...
Cos'è la bolla dell'IA e perché se ne parla Cos'è la bolla dell'IA e perché se...
BOOX Palma 2 Pro in prova: l'e-reader diventa a colori, e davvero tascabile BOOX Palma 2 Pro in prova: l'e-reader diventa a ...
Alcuni rivenditori giapponesi bloccano l...
Le feste non placano Amazon, anzi: aggio...
Roborock Q10 S5+ a un super prezzo: robo...
Formula sceglie WINDTRE BUSINESS per gar...
EXPO 1.20: AMD migliora il supporto all'...
MacBook Pro con chip M4, 24GB di RAM e 1...
Lefant M330 da 6.000Pa a 139€ o ECOVACS ...
Tornano gli sconti anche sulle scope ele...
Le scope elettriche Dreame H12, H14 e H1...
Il nucleo della cometa interstellare 3I/...
La Russia potrebbe sviluppare un'arma pe...
Manda la RAM Corsair in assistenza, rice...
ASUS ROG G1000 con 'AniMe Holo': saranno...
Un test di longevità ha messo alla prova...
Incat inizia i test dell'incredibile tra...
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:53.


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