Mysql
 sql >> Datenbank >  >> RDS >> Mysql

PDO-Einfügungsanweisung mit Schleife durch das $_POST-Array

Wie die anderen gesagt haben, bleibt die Möglichkeit, dass ein böswilliger Benutzer die Namen von Feldern im DOM bearbeitet, aber das Folgende könnte von Interesse sein.

$sql='insert into `claims_motor` (`'.implode( '`,`', array_keys( $_POST ) ) .'`) values (:'.implode(',:',array_keys( $_POST ) ).');';
foreach( $_POST as $field => $value ) $params[":{$field}"]=$value;

$statement = $pdo->prepare( $sql );
$statement->execute( $params );

Als Antwort auf Ihre Frage zum Entfernen von falschem HTML aus den Eingabedaten könnten Sie Folgendes versuchen:

$options=array( 'flags'=>FILTER_FLAG_NO_ENCODE_QUOTES | FILTER_FLAG_STRIP_LOW | FILTER_FLAG_STRIP_HIGH | FILTER_FLAG_ENCODE_LOW | FILTER_FLAG_ENCODE_HIGH | FILTER_FLAG_ENCODE_AMP );

function filterfield( $field ){
    global $options;
    return ":".strip_tags( filter_var( $field, FILTER_SANITIZE_STRING, $options ) );
}
function filtervalue( $field ){
    global $options;
    return strip_tags( filter_input( INPUT_POST, $field,  FILTER_SANITIZE_STRING, $options ) );
}
function isfield( &$field, $key, $fields ){
    $field=in_array( $field, $fields ) ? $field : false;
}

$sql='insert into `claims_motor` (`'.implode( '`,`', array_keys( $_POST ) ) .'`) values (:'.implode(',:',array_keys( $_POST ) ).');';
foreach( $_POST as $field => $value ) $params[ filterfield( $field ) ]=filtervalue( $field );

Ich schlage nicht vor, dass dies eine perfekte Lösung ist, aber es beantwortet mehr oder weniger Ihre ursprüngliche Frage. Hier erfahren Sie mehr über Filter

Ich habe dies mit PDO mit einem enthaltenen DROP versucht Aussage in den Wert und das war OK - wurde als String-Daten eingefügt. Als ich versuchte, einen Feldnamen zu ändern, verursachte dies eine PDOException und tat nichts anderes....

Um die von Ihnen vorgeschlagenen Spaltennamen zu erhalten, können Sie Folgendes versuchen:-

$sql="select group_concat(`column_name`) as 'cols' 
        from `information_schema`.`columns` 
        where `table_schema`=database() and `table_name`=:table;";

$params=array(':table' => 'claims_motor');
$statement = $pdo->prepare( $sql );
$statement->execute( $params );

/* Process the recordset */
$cols=$rs->cols; /* or whatever method to access the record */


/* Filter fields that were not in form - if any */
$cols=explode( ',', $cols );
array_walk( $cols, 'isfield', array_keys( $_POST ) );
$fields = array_filter( $cols );

/* Prepare sql for the insert statment */
$sql_insert='insert into `claims_motor` (`'.implode( '`,`', $fields ) .'`) values (:'.implode( ',:', $fields ).');';

/* reset params array */
$params=array();

/* Construct new array of bound variables / params */
foreach( $_POST as $field => $value ) $params[ filterfield( $field ) ]=filtervalue( $field );

/* add the data to db */
$statement = $pdo->prepare( $sql );
$statement->execute( $params );