PHP根据表单名称发布到不同的用户

PHP根据表单名称发布到不同的用户,php,html,Php,Html,试图找出让下面的PHP发布到不同用户电子邮件地址的最佳方法,具体取决于它来自的表单名称 这个表格是name=“engineering australia”,我还有其他不同名字的表格。我想把这个给你user1@domain.com还有一个要去的地方user2@domain.com等等 我的问题是,做这件事的最佳方式是什么,我不想使用javascript——我在想某种if语句?但是表单名称是否需要以某种方式拉进来 另外值得一提的是,除了表单名称之外,表单是相同的,我不想为每个表单创建不同的PHP脚本

试图找出让下面的
PHP
发布到不同用户电子邮件地址的最佳方法,具体取决于它来自的表单名称

这个表格是
name=“engineering australia”
,我还有其他不同名字的表格。我想把这个给你user1@domain.com还有一个要去的地方user2@domain.com等等

我的问题是,做这件事的最佳方式是什么,我不想使用javascript——我在想某种
if
语句?但是表单名称是否需要以某种方式拉进来

另外值得一提的是,除了表单名称之外,表单是相同的,我不想为每个表单创建不同的
PHP
脚本

HTML

<form class="form-contact" name="engineering-australia">
    <fieldset>
        <input id="form-name" name="name" type="text" placeholder="Your Name" />
        <input id="form-email" name="email" type="text" placeholder="Your Email" />
    </fieldset>
    <textarea id="form-msg" name="message" rows="10" placeholder="Your Message" ></textarea>
    <input type="submit" name="submit" class="button button-small" value="Send Message" />
</form>

PHP

<?php

define('kOptional', true);
define('kMandatory', false);

error_reporting(E_ERROR | E_WARNING | E_PARSE);
ini_set('track_errors', true);

function DoStripSlashes($fieldValue)  { 
// temporary fix for PHP6 compatibility - magic quotes deprecated in PHP6
 if ( function_exists( 'get_magic_quotes_gpc' ) && get_magic_quotes_gpc() ) { 
  if (is_array($fieldValue) ) { 
   return array_map('DoStripSlashes', $fieldValue); 
  } else { 
   return trim(stripslashes($fieldValue)); 
  } 
 } else { 
  return $fieldValue; 
 } 
}

function FilterCChars($theString) {
 return preg_replace('/[\x00-\x1F]/', '', $theString);
}

function CheckEmail($email, $optional) {
 if ( (strlen($email) == 0) && ($optional === kOptional) ) {
  return true;
  } elseif ( preg_match("/^([\w\!\#$\%\&\'\*\+\-\/\=\?\^\`{\|\}\~]+\.)*[\w\!\#$\%\&\'\*\+\-\/\=\?\^\`{\|\}\~]+@((((([a-z0-9]{1}[a-z0-9\-]{0,62}[a-z0-9]{1})|[a-z])\.)+[a-z]{2,6})|(\d{1,3}\.){3}\d{1,3}(\:\d{1,5})?)$/i", $email) == 1 ) {
  return true;
 } else {
  return false;
 }
}

if (isset($_SERVER['HTTP_X_FORWARDED_FOR'])) {
 $clientIP = $_SERVER['HTTP_X_FORWARDED_FOR'];
} else {
 $clientIP = $_SERVER['REMOTE_ADDR'];
}

$FTGname = DoStripSlashes( $_POST['name'] );
$FTGemail = DoStripSlashes( $_POST['email'] );
$FTGmessage = DoStripSlashes( $_POST['message'] );
$FTGsubmit = DoStripSlashes( $_POST['submit'] );

$validationFailed = false;

# Fields Validations

if (!CheckEmail($FTGemail, kMandatory)) {
 $FTGErrorMessage['email'] = 'ERROR MESSAGE';
 $validationFailed = true;
}

# Redirect user to error message

if ($validationFailed === true) {

 header("Location: index.php?success=2");

}

if ( $validationFailed === false ) {

 # Email to Form Owner

 $emailSubject = FilterCChars("Website Enquiry");

 $emailBody = chunk_split( base64_encode( "<html>\n"
  . "<head>\n"
  . "<title></title>\n"
  . "</head>\n"
  . "<body>\n"
  . "Name : $FTGname<br />\n"
  . "Email : $FTGemail<br />\n"
  . "Message : " . nl2br( $FTGmessage ) . "\n"
  . "</body>\n"
  . "</html>" ) )
  . "\n";
  $emailTo = 'User <user1@domain.com>';

  $emailFrom = FilterCChars("$FTGemail");

  $emailHeader = "From: $emailFrom\n"
   . "MIME-Version: 1.0\n"
   . "Content-Type: text/html; charset=\"UTF-8\"\n"
   . "Content-Transfer-Encoding: base64\n"
   . "\n";

  mail($emailTo, $emailSubject, $emailBody, $emailHeader);

# Redirect user to success message

header("Location: index.php?success=1");

}

?>

在PHP中无法获取表单名称。尝试在每个表单中使用隐藏输入:

<input name="form" type="hidden" value="engineering-australia" />
更改:

<form class="form-contact" name="engineering-australia">
    <fieldset>

致:



现在,您只需在“提交操作”页面上请求
$\u POST['POST-to']
,即可检查您要向谁发送电子邮件。

问题是什么,有问题吗?错误?你是动态创建表单的吗?@user3980820不,我对这个很陌生。他们给了你你想要的答案,但我认为你应该动态创建表单,这会节省你的时间。@user3980820谢谢!我会调查的,因为我对它了解不多。干杯,我明白了!非常感谢!我真的很感谢你的帮助。谢谢你的帮助。我考虑了一个隐藏的领域,但不认为这是最干净的方式,我想是吧!:)干杯
<form class="form-contact" name="engineering-australia">
    <fieldset>
<form class="form-contact">
    <input type="hidden" name="post-to" value="engineering-australia" />
    <fieldset>