我使用jQuery創建了一個AJAX提交表單,並使用PHP處理了表單郵件(這就是您在下面看到的內容。)基於下面的代碼,從AJAX/AJAX接收的內容中跳出超全局$ _POST變量的最佳方法是什麼? jQuery形式?將trim()函數包裝在htmlspecialchars()函數中可以嗎?由於電子郵件的內容未被插入到數據庫中,因此在發送php郵件程序時,我必須關注哪種類型的安全性。
<?php
$content_link = trim($_POST['content_link']);
$email = trim($_POST['email']);
$viewport_size = trim($_POST['viewportsize']);
$browser = trim($_POST['browser']);
$os = trim($_POST['os']);
$current_page = trim($_POST['current_page']);
$to = '<[email protected]>';
$from = '<' . $email . '>';
$subject = 'Form Submission';
$message = '
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head></head>
<body>
<table>
<tr><td>Content Link:</td><td>' . nl2br($content_link) . '</td></tr>
<tr><td>Email:</td><td>' . $email . '</td></tr>
<tr><td>Viewport Size:</td><td>' . $viewport_size . '</td></tr>
<tr><td>Browser/OS:</td><td>' . $browser . '/' . $os . '</td></tr>
<tr><td>Current Page:</td><td>' . $current_page . '</td></tr>
</table>
</body>
</html>';
$headers = "MIME-Version: 1.0" . "\r\n";
$headers .= "Content-type:text/html;charset=iso-8859-1" . "\r\n";
$headers .= 'From: ' . $from . "\r\n";
mail($to,$subject,$message,$headers);
htmlentites($ value)用於回顯任何數據以防止人們提交javascript等。 – Waygood 2013-03-11 17:01:24
您需要做一些防止[電子郵件注入]的工作(http://www.securephpwiki.com/index.php/Email_Injection) 。 – datasage 2013-03-11 17:04:09