在POST复选框值的数组上使用preg_match

时间:2015-07-01 10:21:13

标签: php arrays checkbox preg-match

我遇到的问题是让preg_match正确处理从我的表单返回的数组。

<input type="checkbox" name="receiver-check[]" class="checkbox-id" value="Username 1 (123)">
<input type="checkbox" name="receiver-check[]" class="checkbox-id" value="Username 2 (456)">
<input type="checkbox" name="receiver-check[]" class="checkbox-id" value="Username 3 (789)">

所以我希望对通过表单收到的值使用preg_match。 这就是我使用它的方式。

$msg_receivers = !empty($_POST['receiver-check']) && is_array($_POST['receiver-check']) ? $_POST['receiver-check'] : array();
    $receiverIds = array();
    foreach($msg_receivers as $receiver) {
        $receiverIds[] = preg_replace('/\((\d+)\)$/', "$1", $receiver);
    }
    $number_of_receivers = count($receiverIds);
    $while_count = 0;
    while($number_of_receivers >= ($while_count + 1)){
        $sql = <<< EOF
        INSERT INTO private_messages (
        message_subject,
        message_content,
        message_deliver,
        message_receive,
        message_status,
        message_datetime,
        message_to_stab
        )VALUES
        (?,?,?,?,'2',?,?);
EOF;
        $stmt = $mysqli->prepare($sql) or die ("Feil i database<br>" . $sql . "<br><b>Feilmelding:</b> " . $mysqli->error);
        $stmt->bind_param("ssiiii",$message_subject,$message_content, $_SESSION['user_id'],$receiverIds[$while_count],$message_datetime,$message_to_stab);
        $stmt->execute() or die("noe gikk galt");
        $msg_num_rows = $stmt->num_rows;
        if($msg_num_rows = 0){
            $msg = "Feilmelding: Klarte ikke å sende meldingen.";
        }
        else{
            $msg = "Meldingen har blitt sendt.";
        }
        $stmt->free_result();
        $stmt->close();
        $while_count ++;
    }

然后我使用$msg_receiver_query在while循环中的查询中设置一个值。 我目前在我的数据库中收到的是0和1.没有别的。正确preg_match对我来说输出JUST里面的数字会是什么?我的这个问题是否有更有效的解决方案?

2 个答案:

答案 0 :(得分:1)

看起来你想要匹配,你只想提取每个$_POST['receiver-check']值的一部分 - 所以preg_replace()将是正确使用的功能

$msg_receivers = !empty($_POST['receiver-check']) && is_array($_POST['receiver-check']) 
             ? $_POST['receiver-check'] : array();

$receiverIds = array();

foreach($msg_receivers as $receiver) {
  $receiverIds[] = preg_replace('/^.*\((\d+)\)$/', "$1", $reciever);
}

这应该会给你一系列接收者ID($ receiverIds),如:

array(
  [0] => 123, 
  [1] => 456, 
  [2] => 789
  );

答案 1 :(得分:0)

你可以这样做。

这样您就可以将其插入到数据库中。但你会查询你的Db 3次以插入3条记录。

<?php

//use your connection Data
$user = "root";
$pass = "***";
$host = "localhost";
$dbdb = "TestDataBase";

$connect = mysqli_connect($host, $user, $pass, $dbdb);
if(!$connect)
{
    trigger_error('Error connection to database: '.mysqli_connect_error());
}

//check if receiver-check is set or not
if(isset($_POST['receiver-check'])){
      $msg_receivers = $_POST['receiver-check'];


      // iterate through $msg_receivers
      foreach($msg_receivers AS $value){
          preg_match_all("/([0-9]{3})/", $value, $msg_receiver_query);

            //Query, just change the table name and columns to what ever you need.
            $sql = "INSERT INTO `table` (`column1`) VALUES ('" .$msg_receiver_query[0][0] . "')";

            if (mysqli_query($connect, $sql)) {
                  echo 'Record(s) created successfully<br>';
            } else {
                  echo $sql . '"<br>"' . mysqli_error($connect);
            }
      }

}else{
      echo "nothing is set";
}
?>

提升可能还有一点点但你可以在一个查询中执行此操作。

<?php

//use your connection Data
$user = "root";
$pass = "***";
$host = "localhost";
$dbdb = "TestDataBase";

$connect = mysqli_connect($host, $user, $pass, $dbdb);
if(!$connect)
{
    trigger_error('Error connection to database: '.mysqli_connect_error());
}

//check if receiver-check is set or not
if(isset($_POST['receiver-check'])){
      $msg_receivers = $_POST['receiver-check'];

      $inputArray = '';

      // iterate through $msg_receivers
      foreach($msg_receivers AS $value){
          preg_match_all("/([0-9]{3})/", $value, $msg_receiver_query);

          //insert all output in to an array
          $inputArray [] =  "('" . $msg_receiver_query[0][0] . "')";
      }

      //Insert all outputs in 1 query
      $sql = "INSERT INTO `testtable` (`column1`) VALUES " . implode(",",$inputArray) . "";

      if (mysqli_query($connect, $sql)) {
            echo 'Record(s) created successfully<br>';
      } else {
            echo $sql . '"<br>"' . mysqli_error($connect);
      }

}else{
      echo "nothing is set";
}
?>