PHP форма либо одно из двух обязательных текстовых полей - PullRequest
0 голосов
/ 19 февраля 2012

Я понимаю, что существуют аналогичные темы, касающиеся страниц .asp, однако я использую HTML-форму с php, связанным с действием отправки, ведущим к опросу.

Клиент, для которого я разрабатываю, хотел бы заполнить одно из текстовых полей, в то время как ни одно из них не является обязательным для заполнения, одно из двух должно быть заполнено. Это может быть любой из двух, однако оба не могут быть оставлены пустыми.

Я бы предпочел не использовать jquery, однако, если это необходимо, я научусь. Я новичок во всем этом, и просто создание формы и подключение ее к базе данных заняло много времени.

Спасибо за любую помощь, ниже я разместил форму HTML и скрипт php, с которым она связана.

<form action="insert.php" method="post">
Name: <input type="varchar" name="name" />
<span style="color: #F00">or</span> Email:
<input type="varchar" name="email" />
<input type="submit" />
</form>

PHP 'insert.php

<?php
$con = mysql_connect("localhost","gobagtoo_1","1");
if (!$con)
{
die('Could not connect: ' . mysql_error());
}

mysql_select_db("gobagtoo_1", $con);

$sql="INSERT INTO name_email (name, email)
VALUES
('$_POST[name]','$_POST[email]')";

if (!mysql_query($sql,$con))
{
die('Error: ' . mysql_error());
}
else 
$url = 'tool.html';
echo '<META HTTP-EQUIV=Refresh CONTENT="0; URL='.$url.'">';  

mysql_close($con)
?>

M

1 Ответ

2 голосов
/ 19 февраля 2012

Вы должны выполнить это как на стороне клиента (где вы видите форму) с помощью javascript, так и на стороне сервера (PHP после отправки формы).

На стороне клиента: 1. Добавьте функцию на страницу validateForm. 2. Добавьте атрибуты id к вашему имени и элементам электронной почты. 3. Добавьте элемент onsubmit к тегу формы.

    <html>
    <head>
    <script language="javascript">
    function validateForm(){
        var value1 = document.getElementById('nameId').value;
        var value2 = document.getElementById('emailId').value;
        if( value1 != "" || value2 != "" ) 
        {
            return true;    
        }
        alert("You must enter a value");
        return false;
    }
    </script>
    </head>

    <body>
    <form action="insert.php" method="post" onsubmit="return validateForm();">
    Name: <input type="text" name="name" id="nameId" /> 
    <span style="color: #F00">or</span> Email: <input type="text" name="email" id="emailId" />
    <input type="submit" /> 
    </form> 
    </body>
    </html>

На стороне PHP:

    <?PHP

    function makeSafeish( $value ){
        return mysql_escape_real_string( $value );
        // If you put this in a function, you can do more w/ it. I don't use this as is but don't want to be judged by the community here for my bad use :P
    }

    if( strlen( $_POST['name'] ) > 0 && strlen( $_POST['email'] ) > 0 ){
        $con = mysql_connect("localhost","******","******"); 
        if (!$con) { 
            die('Could not connect: ' . mysql_error()); 
        }  
        mysql_select_db("*****", $con); 
        $sql="INSERT INTO name_email (name, email) VALUES ('".makeSafeish( $_POST["name"] )."','".makeSafeish( $_POST["email"] )."')"; 
        if ( ! mysql_query( $sql, $con ) ) { 
            die('Error: ' . mysql_error()); 
        } else  {
            $url = 'tool.html'; 
        }

        echo '<META HTTP-EQUIV=Refresh CONTENT="0; URL='.$url.'">';    
        mysql_close($con); // you're not gonna get here because of the above line.
    }else{
        echo 'You must enter either an email or name.";
    }
    ?> 
...