将 PHP 中包含的 HTML 表单信息写入 CSV 文件中



我正在为我自己的目的开发一个小的Wordpress插件。

第一步很简单,但是对于使用PHP将表单的数据写入CSV文件中,我有些不明白。 我正在使用readfile((在PHP文件中导入html代码。

我遵循了本教程,但我不明白为什么它不起作用。CSV 文件中不写入任何数据。 可能是因为readfile((吗?

编辑:可能是因为我没有用Wordpress Hook调用我的函数吗?在发送表单时可以使用哪一个?

网页代码:

<form method="post">
<label for="prenom">Prénom</label>
<input class="main-content__form--input" pattern="[a-zA-Z0-9 ]+" id="prenom" type="text" name="prenom" required>
<label for="nom">Nom</label>
<input class="main-content__form--input" pattern="[a-zA-Z0-9 ]+" id="nom" type="text" name="nom" required>
<label for="email">Email</label>
<input class="main-content__form--input" id="email" type="email" name="email" required>
<fieldset class="main-content__form--checkbox">
<legend class="main-content__form--legend">Sélection des films</legend>
<input type="checkbox" id="laHaine" name="films" value="La Haine">
<label for="laHaine">La Haine</label>
<input type="checkbox" id="odyssee" name="films" value="l'Odyssée de l'espace">
<label for="odyssee">l'Odyssée de l'espace</label>
<input type="checkbox" id="requiem" name="films" value="Requiem for a dream">
<label for="requiem">Requiem for a dream</label>
<input type="checkbox" id="mulholland" name="films" value="Mulholland Drive">
<label for="mulholland">Mulholland Drive</label>
<input type="checkbox" id="Carnage" name="films" value="Carnage">
<label for="Carnage">Carnage</label>
<input type="checkbox" id="under" name="films" value="Under the skin">
<label for="under">Under the skin</label>
<input type="checkbox" id="edward" name="films" value="Edward aux mains d'argent">
<label for="edward">Edward aux mains d'argent</label>
<input type="checkbox" id="lost" name="films" value="Lost in translation">
<label for="lost">Lost in translation</label>
</fieldset>
<input class="main-content__form--input" name="submit" type="submit" value="S'inscrire">
</form>

PHP代码:

$error = '';
$fname = sanitize_text_field($_POST['prenom']);
$lname = sanitize_text_field($_POST['nom']);
$email = sanitize_email($_POST['email']);
$checkbox = $_POST['films'];
$error = '';

function clean_text($clean) {
$clean = trim($clean);
$clean = stripslashes($clean);
$clean = htmlspecialchars($clean);
return $clean;
}

if(isset($_POST['submit'])) {
if(empty($_POST['prenom']) OR empty($_POST['nom']) OR empty($_POST['email'])) {
$error = '<p>Veuillez réessayer</p>';
} else {
$fname = clean_text($_POST['prenom']);
$lname = clean_text($_POST['nom']);
$email = clean_text($_POST['email']);
}
if($error = '') {
$file_open = fopen('../form-to-csv.csv', 'a');
$no_rows = count(file('form-to-csv.csv')); 
if ($no_rows > 1) {
$no_rows = ($no_rows - 1) +1;
} 
$form_data = array(
'id' => $no_rows,
'prenom' => $fname,
'nom' => $lname,
'email' => $email,
'films' => $checkbox
);
fputcsv($file_open, $form_data);
$error = '<p>Votre inscription a bien été prise en compte</p>';
$fname = '';
$lname = '';
$email = '';
$checkbox = '';
}             
}

比较运算符中的拼写错误:if($error = '') {应该是if($error == '') {

编辑可能是您的文件权限,尤其是编辑。 更改权限或尝试将 csv 文件放在桌面上:$file_open = fopen('C:UsersDanielDesktopform-to-csv.csv', 'a');

编辑2:是的,这是文件权限。我在修复比较运算符的情况下执行了您的代码,并成功附加到文件中。

最新更新