0

ここでjQueryファイルのアップロードに取り組んでいます。ページに投稿する必要があるデータを保存したら、画像を保存しています

ここでは、2 つのアプリケーション (2 つの別個のアプリケーション) html.page を使用して、画像を mvc アップロード コントローラーに投稿し、画像を完全に保存しました。

レスポーズデータを取得するには、URLを介してリダイレクトする必要があるため、このようにリダイレクトしています

 public void ReturnResult(string jsonObj)
       {

           var hostName = " http://localhost:8988/cors/postmessage.html?MyURL=";
           var s = jsonObj;
           var filterUrl = hostName + s;
           HttpContext.Current.Response.Redirect(filterUrl);

       }

このページにリダイレクトしたら、どうすればそれらのデータを取得できますか?

そして、これがデータをリダイレクトしているのか、データがリダイレクトされていることをどのように知ることができるのか、データを取得するのを手伝ってくれるのかわかりません

これは私の

このページにリダイレクトされました

       <!DOCTYPE HTML>

<html lang="en">
<head>
<meta charset="utf-8">
<title>jQuery File Upload Plugin postMessage API</title>
<script src="//ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
</head>
<body>
<script>

    'use strict';

    var origin = /^http:\/\/example.org/,
//var origin = 'http://localhost:4071/Upload/UploadHandler.ashx',
    target = new RegExp('^(http(s)?:)?\\/\\/' + location.host + '\\/');
    alert(1);
    alert(origin);
$(window).on('message', function (e) {
    e = e.originalEvent;
    var s = e.data,
        xhr = $.ajaxSettings.xhr(),
        f;
    if (!origin.test(e.origin)) {
        throw new Error('Origin "' + e.origin + '" does not match ' + origin);
    }
    if (!target.test(e.data.url)) {
        throw new Error('Target "' + e.data.url + '" does not match ' + target);
    }
    $(xhr.upload).on('progress', function (ev) {
        ev = ev.originalEvent;
        e.source.postMessage({
            id: s.id,
            type: ev.type,
            timeStamp: ev.timeStamp,
            lengthComputable: ev.lengthComputable,
            loaded: ev.loaded,
            total: ev.total
        }, e.origin);
    });
    s.xhr = function () {
        return xhr;
    };
    if (!(s.data instanceof Blob)) {
        f = new FormData();
        $.each(s.data, function (i, v) {
            f.append(v.name, v.value);
        });
        s.data = f;
    }
    $.ajax(s).always(function (result, statusText, jqXHR) {
        if (!jqXHR.done) {
            jqXHR = result;
            result = null;
        }
        e.source.postMessage({
            id: s.id,
            status: jqXHR.status,
            statusText: statusText,
            result: result,
            headers: jqXHR.getAllResponseHeaders()
        }, e.origin);
    });
});
</script>
</body>
</html>

どんな助けでも大歓迎です事前に感謝します

4

1 に答える 1

0

HTML ページでコントローラから返されたクエリ文字列からデータを取得する必要がある場合は、この関数を使用できます。

function getUrlVars() {
                var vars = [], hash;
                var hashes = window.location.href.slice(window.location.href.indexOf('?') + 1).split('&');
                for (var i = 0; i < hashes.length; i++) {
                    hash = hashes[i].split('=');
                    vars.push(hash[0]);
                    vars[hash[0]] = hash[1];
                }
                return vars;
            }

次のようなページの読み込み時に値を取得できます。

var MyURL= getUrlVars()['MyURL'];
于 2013-03-25T06:47:39.647 に答える