ユーザーが情報を送信できるフォームを作成し、特定のユーザーに電子メールで送信するファイルを添付しています。
HTML フォームを作成しましたが、ページを更新したくないので、非表示の iframe 経由で送信しました。
フォームにキャプチャを追加するまで、すべてが機能していました。今、私は問題を抱えています。キャプチャ用に生成された文字列をメイン フォーム ページのセッションに保存します。しかし、フォームが iframe から送信されているため、PHP が空の新しいセッションを作成していると思います。
iframe とフォームページを同じセッションに接続する方法を誰かが提案できますか? ユーザーがクリックしてフォームを送信すると、iframe は JavaScript によって動的に作成されることに注意してください。
アドバイスをありがとう!
編集: 私のコード HTML フォーム ページ:
<input type="text" name="name"/><br />
<input type="text" name="email"/><br />
<textarea name="message"></textarea><br />
<input type="file" name="file"/><img id="captchaimg" src="http://xxx/mailsend.php?application=xxx&image=get"/><input type="text" name="captcha"/>
<input type="button" id="send" value="send"/>
私のJSファイル:
function sendFromIframe() {
if ($('#hiddeniframe').length == 0) {
var iframe = ('<iframe name="hiddeniframe" id="hiddeniframe" src="" border="0" height="0" width="0" style="display:none"></iframe>');
$("body").append(iframe);
}
setTimeout(function() {
var form = $('#feedback');
form.attr('target', 'hiddeniframe');
form.attr('method', 'POST');
form.attr('action', 'http://xxx/mailsend.php');
form.attr("enctype", "multipart/form-data");
form.attr("encoding", "multipart/form-data");
form.submit();
wait4refresh();
}, 550);
}
function wait4refresh(counter){
var counter = counter || 0;
var bolean = false;
var request = $.ajax({
async: false,
url: 'http://xxx/mailsend.php',
type: 'GET',
data: 'application=' + $('input[name="application"]').val() + '&issend'
});
request.done(function(msg){
if (msg == 'true'){
bolean = true;
}
});
if (bolean){
refreshCaptcha();
}
else if (counter > 10){
return false;
}
else{
setTimeout(function(){
counter++
wait4refresh(counter);
},500);
}
}
function refreshCaptcha() {
var application = $('input[name="application"]').val();
d = Math.round(Math.random() * 100);
$('#captchaimg').attr('src', 'http://xxx/mailsend.php?application=' + application + '&image=get' + '&' + d);
}
および PHP ファイル:
ここに PHP コードを追加しようとすると、「接続がピアによってリセットされました」というエラーが表示されます。私に何ができる?