0

我正在尝试输入gameName,它对前导空格非常敏感,因为它需要与其他功能一起使用。

当我将其输入输入字段时,没有空格。我在DB里查的时候,直接处理完,前面有个空格。当我从数据库中拉出它时,没有空间,将其重新插入数据库(在被拉出后)会删除空间。

该页面的违规代码是:

if (isset($_GET) && $_GET['page'] == 'addGame') {
    if (isset($_GET) && $_GET['page'] == 'addGame' && $_GET['action'] == 'success') {
?>
      <h2>Game added to database.</h2>
      <h4><a href='index.php?page=addGame'>Add another</a> or choose something new to do.</h4>
<?
    } else {
      include('./inc/addGameProc.php');
?>
      <fieldset>
      <legend><h2>Add game</h2></legend>

      <form name='addGame' id='addGame' method='POST'>
        <input type='text' name='gameName' placeholder='Game name' required /><br />
        <textarea name="gameDesc" class="span12" rows="10" placeholder='Game description' required></textarea><br />
        <input type='submit' name='submitNewGame' class='btn btn-primary' /><br />
      </form>
      </fieldset>
<?

    }
}

您看到的添加游戏过程是:

    <?
    if (isset($_POST['submitNewGame']) && $_SERVER['REQUEST_METHOD'] == 'POST') {
        $database = new database('localhost','wwwander_sradmin','editedout','wwwander_srmain','mysqli');
        $database->openConnection();

            //save and escape entered material
            $gameName = ltrim($_POST['gameName']);
            $gameDesc = $database->escapeString($_POST['gameDesc']);

            //check that material not already in db
            $checkDB = $database->queryDB("SELECT * FROM mainSite_games WHERE gameName='$gameName' AND gameDesc='$gameDesc'");
            if ($database->dbNumRows($checkDB) == 1) {
                echo "Game already in database";
            } else {
                //add entered material into db
                $addToDB = $database->queryDB("INSERT INTO mainSite_games(gameName, gameDesc) VALUES(\" $gameName \", \" $gameDesc \")");
                if (!$addToDB) {
                    echo "An error occured.";
                } else {
                    header('Location: index.php?page=addGame&action=success');
                }
            }

        $database->closeConnection();
    }
?>

你可以在那里看到我尝试过和失败的 ltrim。

当然,这是我在这里的最后一次尝试。我已经做了我所知道的一切。有任何想法吗?我可以提供更多我遗漏的资源吗?

编辑 -

被拉后,有一个空格。我说没有的原因是因为我通常在哪里拉它,它进入一个选择,我认为空格无关紧要,因为它们没有被考虑在内?我不知道。

4

1 回答 1

0

改变 :

VALUES(\" $gameName \" 

至 :

VALUES(\"$gameName\"

我认为您看到的空间是引号之后的空间

于 2013-04-28T06:47:44.220 回答