0

ユーザーが情報を送信できるフォームを作成し、特定のユーザーに電子メールで送信するファイルを添付しています。

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 コードを追加しようとすると、「接続がピアによってリセットされました」というエラーが表示されます。私に何ができる?

4

1 に答える 1

0

を作成して<div id='htmlform'> </div>、jqueryで表示/非表示にすることはできませんか?

于 2012-09-14T13:54:13.883 に答える