1

我有一个网站,管理员可以选择添加一定数量的 bbcode 标签和相应的 html 标签。首先,他从 for Each 循环中的下拉选择表单中选择要添加的标签数量。根据他单击提交按钮时选择的标签数量,相应数量的输入标签会出现在第二个表单中,也是在 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;

   }

这是网站的样子

非常感谢,如果我的代码是业余的,我很抱歉,我只是从 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 ";

这工作得更好一些,但现在它转到上面的 else 并显示“2 个标签为空”,所以它仍然不能正常工作。

4

2 回答 2

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 标签。

于 2013-04-22T19:17:20.217 回答
-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);
?>
于 2013-04-20T12:53:22.443 回答