sql >> Databáze >  >> RDS >> Mysql

Příkaz vložení PDO se smyčkou přes pole $_POST

Jak uvedli ostatní, zůstává zde možnost, že by uživatel se zlými úmysly mohl upravit názvy polí v DOM, ale to znamená, že by vás mohlo zajímat následující.

$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 );

V odpovědi na vaši otázku o odstranění falešného html ze vstupních dat můžete zkusit něco v následujícím smyslu:

$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 );

Netvrdím, že je to dokonalé řešení, ale víceméně to odpovídá na vaši původní otázku. Další informace o filtrech naleznete zde

Zkoušel jsem to pomocí PDO s přiloženým DROP příkaz v hodnotě a to bylo v pořádku - byl vložen jako data řetězce. Když jsem se pokusil upravit název pole, způsobilo to PDOException a neudělal nic jiného....

Chcete-li získat názvy sloupců, jak navrhujete, můžete zkusit:-

$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 );



  1. Řádek aktualizace Android SQLite nefunguje

  2. Příklad MICROSECOND() – MySQL

  3. Shrňte data do nové tabulky

  4. django.db.utils.operationalError:(2059,Authentication Plugin 'caching_sha2_password')