Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Cineca inaugura Pitagora, il supercomputer Lenovo per la ricerca sulla fusione nucleare
Cineca inaugura Pitagora, il supercomputer Lenovo per la ricerca sulla fusione nucleare
Realizzato da Lenovo e installato presso il Cineca di Casalecchio di Reno, Pitagora offre circa 44 PFlop/s di potenza di calcolo ed è dedicato alla simulazione della fisica del plasma e allo studio dei materiali avanzati per la fusione, integrandosi nell’ecosistema del Tecnopolo di Bologna come infrastruttura strategica finanziata da EUROfusion e gestita in collaborazione con ENEA
Mova Z60 Ultra Roller Complete: pulisce bene grazie anche all'IA
Mova Z60 Ultra Roller Complete: pulisce bene grazie anche all'IA
Rullo di lavaggio dei pavimenti abbinato a un potente motore da 28.000 Pa e a bracci esterni che si estendono: queste, e molte altre, le caratteristiche tecniche di Z60 Ultra Roller Complete, l'ultimo robot di Mova che pulisce secondo le nostre preferenze oppure lasciando far tutto alla ricca logica di intelligenza artificiale integrata
Renault Twingo E-Tech Electric: che prezzo!
Renault Twingo E-Tech Electric: che prezzo!
Renault annuncia la nuova vettura compatta del segmento A, che strizza l'occhio alla tradizione del modello abbinandovi una motorizzazione completamente elettrica e caratteristiche ideali per i tragitti urbani. Renault Twingo E-Tech Electric punta su abitabilità, per una lunghezza di meno di 3,8 metri, abbinata a un prezzo di lancio senza incentivi di 20.000€
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: 2780
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: 2780
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


Cineca inaugura Pitagora, il supercomputer Lenovo per la ricerca sulla fusione nucleare Cineca inaugura Pitagora, il supercomputer Lenov...
Mova Z60 Ultra Roller Complete: pulisce bene grazie anche all'IA Mova Z60 Ultra Roller Complete: pulisce bene gra...
Renault Twingo E-Tech Electric: che prezzo! Renault Twingo E-Tech Electric: che prezzo!
Il cuore digitale di F1 a Biggin Hill: l'infrastruttura Lenovo dietro la produzione media Il cuore digitale di F1 a Biggin Hill: l'infrast...
DJI Osmo Mobile 8: lo stabilizzatore per smartphone con tracking multiplo e asta telescopica DJI Osmo Mobile 8: lo stabilizzatore per smartph...
Tesla aggiorna il camion Semi, e sposta ...
Come funziona la carta Klarna: tre livel...
I Funko Pop potrebbero sparire per sempr...
Windows 98 in crash davanti a migliaia d...
Samsung Smart TV 85'' Neo QLED Mini LED ...
TikTok rafforza la sicurezza degli acqui...
Samsung Galaxy S25 Ultra 256 GB a ...
Sanzione ridotta per TIM: l'azienda paga...
DJI Osmo 360 in super offerta su Amazon:...
Moto Watch Fit con Moto AI a metà prezzo...
Batterie ibride plug-in: la classifica d...
Ayaneo Next 2 è ufficiale: presta...
Windows 11 26H1 è ufficiale, ma &...
Archive.is nel mirino: l'FBI vuole saper...
CMF by Nothing Buds 2a: le cuffie ANC co...
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:37.


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