PHP - 从forEach选择表单返回发布

时间:2013-04-20 12:18:51

标签: php forms foreach

我有一个网站,管理员可以选择添加一定数量的bbcode标签和相应的html标签。 首先,他从for循环中的下拉选择表单中选择要添加的标签数量。 根据他在单击提交按钮时选择的标签数量,相应数量的输入标签以第二种形式出现,也出现在for Each循环中。他填写bbcode和html输入并单击提交按钮。通常情况下,标签应该添加到我的数据库中,但在这种情况下,当他点击提交时,表单会消失并且不会添加任何内容。

以下是代码:

//FIRST FORM WHERE HE DECIDES HOW MANY TAGS TO ADD
<form id='nbbalises' action='config.ini.php' method='post' accept-charset='UTF-8'>
  <fieldset>
    <legend>How many tags ?</legend>
    <input type='hidden' name='submitted' id='submitted' value='1' /> 
    <?php

    echo '<select name="number">';
    $range = range(1,50,1);
    foreach ($range as $nb) {
      echo "<option value='$nb'>$nb</option>";
    }
    echo "</select>";

    ?>  

    <input type='submit' name='Submit' value='Submit' />
  </fieldset>
</form><br /> <br />




<?php 

if (!(empty($_POST['number']))) {
if ($_POST['number'] >= 1 && $_POST['number']<= 50){
    $number = $_POST['number'];
    $range2 = range(1,$number,1);
?>


//SECOND FORM WHERE I GENERATE THE INPUT DEPENDING ON THE NUMBER CHOSEN FROM FIRST FORM     
<form id='balises' action='config.ini.php' method='post' accept-charset='UTF-8'>
  <fieldset>
    <legend>Balises bbc : </legend>
    <input type='hidden' name='submitted' id='submitted' value='1' />

    <?php 

    foreach ($range2 as $nb2) {
      echo "<label>bbcode tag $nb2 :</label> 
        <input type='text' size='40' name='bbc$nb2' id='bbc$nb2' maxlength='40'  />
        <label>html tag $nb2 :</label> 
     <input type='text' size='40' name='html$nb2' id='html$nb2' maxlength='40'   />
         <br />";

     }

   }
   ?>
   <input type='submit' name='Submit2' value='Submit2' />
  </fieldset>
</form>

<?php 

//PROBLEM STARTS HERE, NOTHING WORKS UNDER HERE  
if (isset($_POST['Submit2'])){

  //CONNECT TO MY DATABASE      
  connectDB();
  for ($i=0; $i<$number ; $i++){

     if (!(empty($_POST["bbc$i"])) && (empty($_POST["html$i"]))) 

     //FUNCTION ADDS TAGS TO DATABASE       
     addBbc($_POST["bbc$i"], $_POST["html$i"]);


 }   
 mysql_close();
}

}


//MY FUNCTIONS TO ADD THE BBCODE AND HTML TO DATABASE


function connectDB(){
//connexion DB

$link = mysql_connect('127.0.0.1', 'USERNAME', 'PASSWORD');
if (!$link) {
    die('Erreur de connexion: ' . mysql_error());
}

$db = mysql_select_db('1213he200967',$link) or die("N'a pu selectionner
    1213he200967");    

mysql_query("SET NAMES 'utf8'");
    }


function addBbc($bbc, $html){

 $b = mysql_real_escape_string($bbc);
 $h = mysql_real_escape_string($html);


$query="INSERT INTO bbcode (BBC,HTML) VALUES ('$b','$h')";

$result = mysql_query($query) or  die("error");

if (!$result) {
    $message  = 'Invalid query: ' . mysql_error() . "\n";
    die($message);
    return false;
}
else return true;

   }

Heres is what the site looks like

非常感谢,如果我的代码是业余爱好者,我很抱歉,我只是从php开始。

修改 发现问题的一部分

$number = $_POST['number'];
$range2 = range(1,$number,1);

这从1变为用户在第一种形式中选择的数字。

for ($i=0; $i<$number ; $i++){

    if (!(empty($_POST["bbc$i"])) && (empty($_POST["html$i"]))) 

    //FUNCTION ADDS TAGS TO DATABASE       
    addBbc($_POST["bbc$i"], $_POST["html$i"]);

这从0变为$ number - 1

所以我把我的代码改为了。

for ($i=0; $i<$number ; $i++){
  $nb = $i + 1;
  if (!(empty($_POST["bbc$nb"])) && (empty($_POST["html$nb"]))) {
    addBbc($_POST["bbc$nb"], $_POST["html$nb"]);
  }
  else echo "$nb tags empty ";

这样做效果好一些,但现在它转到上面的其他地方并显示“2个标签为空”,所以它仍然不能正常工作。

2 个答案:

答案 0 :(得分:0)

好的解决方法我最终决定将数据从第二个表单发布到另一个页面,然后我修改了我的代码。

for ($i=0; $i<$number ; $i++){
    $nb = $i + 1;

    $varBbc = 'bbc'.$nb;
    $varHtml = 'html'.$nb;

    if ((isset($_POST[$varBbc])) && (isset($_POST[$varHtml]))) {

        addBbc($varBbc, $varHtml);

    }

    else echo "$nb tags empty ";
}

显然使用!empty而不是isset在这种情况下不起作用,可能是因为html标签。

答案 1 :(得分:-1)

$ nb应该是双引号。

所以echo "<option value='$nb'>$nb</option>"

更改为echo "<option value='".$nb."'>$nb</option>";

以及

if (!(empty($_POST['number']))) {
if ($_POST['number'] >= 1 && $_POST['number']<= 50){
    $number = $_POST['number'];
    $range2 = range(1,$number,1);
?>

更改为:

if (isset($_POST['submit'])) {
if ($_POST['number'] >= 1 && $_POST['number']<= 50){
    $number = $_POST['number'];
    $range2 = range(1,$number,1);
?>