Como posso passar informações para um iframe via Publicar em ASP.NET?
-
05-07-2019 - |
Pergunta
Gostaria de passar informações para um iframe via correio. (Poderia ser jquery ou javascript que executa o post, ele realmente não importa).
As informações não podem ser enviados via querystring como eu não tenho acesso para alterar a forma como a página trazido pelo iframe é.
Estes dados irão determinar o layout do conteúdo na iframe assim como eu posso fazer isso para que depois da mensagem é enviada do iframe é atualizado? (Possivelmente atualizar?)
Solução
Eu escrevi um blog sobre como fazer isso com jQuery para carregar um arquivo usando um iframe escondido. Aqui está o código:
Aqui está o HTML para o formulário:
<div id="uploadform">
<form id="theuploadform">
<input type="hidden" id="max" name="MAX_FILE_SIZE" value="5000000" >
<input id="userfile" name="userfile" size="50" type="file">
<input id="formsubmit" type="submit" value="Send File" >
</form>
O DIV em que para permitir jQuery para criar o iframe pode ocultá-lo com um pouco de CSS:
<div id="iframe" style="width:0px height:0px visibility:none">
</div>
O DIV em que para mostrar os resultados do callback:
<div id="textarea">
</div>
O código jQuery:
<script type="text/javascript" src="js/jquery-1.3.2.min.js"></script>
<script type="text/javascript">
$(document).ready(function(){
$("#formsubmit").click(function() {
var userFile = $('form#userfile').val();
var max = $('form#max').val();
var iframe = $( '<iframe name="postframe" id="postframe" class="hidden" src="about:none" />' );
$('div#iframe').append( iframe );
$('#theuploadform').attr( "action", "uploader.php" )
$('#theuploadform').attr( "method", "post" )
$('#theuploadform').attr( "userfile", userFile )
$('#theuploadform').attr( "MAX_FILE_SIZE", max )
$('#theuploadform').attr( "enctype", "multipart/form-data" )
$('#theuploadform').attr( "encoding", "multipart/form-data" )
$('#theuploadform').attr( "target", "postframe" )
$('#theuploadform').submit();
//need to get contents of the iframe
$("#postframe").load(
function(){
iframeContents = $("iframe")[0].contentDocument.body.innerHTML;
$("div#textarea").html(iframeContents);
}
);
return false;
});
});
</script>
Eu usei um aplicativo php como este uploader.php fazer alguma coisa com o arquivo:
<?php
$uploaddir = 'uploads/';
$uploadfile = $uploaddir . basename($_FILES['userfile']['name']);
$maxfilesize = $_POST[MAX_FILE_SIZE];
if ($maxfilesize > 5000000) {
//Halt!
echo "Upload error: File may be to large.<br/>";
exit();
}else{
// Let it go
}
if (move_uploaded_file($_FILES['userfile']['tmp_name'], $uploadfile)) {
print('File is valid, and was successfully uploaded. ');
} else {
echo "Upload error: File may be to large.<br/>";
}
chmod($uploadfile, 0744);
?>
Há mais lá do que você precisa, mas ilustra o conceito em jQuery.
Outras dicas
Eu não tenho o código útil, mas a minha equipa realizou esta puramente em Javascript. Pelo que me lembro que foi algo como isto:
function postToPage() {
var iframe = document.getElementById('myIFrame');
if (iframe) {
var newForm = '<html><head></head><body><form...> <input type="hidden" name="..." value="..." /> </form><script type=\"text/javascript\">document.forms[0].submit();</scrip' + 't></body></html>';
iframe.document.write(newForm); //maybe wrong, find the iframe's document and write to it
}
}