混合内容错误(Http / Https)

时间:2016-01-11 15:58:25

标签: javascript jquery ajax http https

我有混合内容错误,在网站上使用了http和https协议。

以下是Chrome控制台的错误:

  

混合内容:' https://www.amazon.com/'是通过HTTPS加载的,但是请求了一个不安全的XMLHttpRequest端点' http://www.amazon.com/../?redirect=true'。此请求已被阻止;内容必须通过HTTPS提供。

此处的屏幕截图显示错误:http://prntscr.com/9os5li

找到了一些解决方案:

更改" http://"的链接到" https://"在 Blocked loading mixed active content

没有任何帮助,因为当我将代码或手册中的链接从 http 更改为 https 时,亚马逊服务器会一直放弃它并将其设为 http

例如,这个Link 2我无法在此使用 https ,因为我有混合内容错误。

这是我打电话的AJAX:

$.ajax({
            url: "//" + MWS_URL + rest_path,
            data: request,
            dataType: 'text',
            type: 'POST',
            contentType: 'application/x-www-form-urlencoded; charset=utf-8',
            beforeSend: function(req) {
                //req.setRequestHeader("User-Agent", "chrome extension");
                req.setRequestHeader("x-amazon-user-agent", "chrome extension");
            },
            success: function(data){
                if (onSuccess) {
                    onSuccess(data);
                }
            },
            error: function(jqXHR, textStatus, errorThrown) {
                if (onError) {
                    onError(jqXHR, textStatus);
                }
            }
        });
        setTimeout(callService, 1000);
    }

请求:

requests.push(
                    $.get(link.URL, function (data) {
                        if (IsCancel()) {
                            return;
                        }
                        var jdata = $($.parseHTML(data));
                        var parser = new ProductPageParser(jdata, link.URL);
                        if (!parser.isValidProduct()) {
                            console.log(link.URL + " is not a valid product, skipped.");
                            link.processed = true;
                            return;
                        }

                        // Process associated (linked) product on this page according to user preferences.
                        crawlLinkedProducts(jdata, link.URL, config);

                        // Store product into a collection.
                        var product = getProductForParser(parser, link);
                        //product.dbRawProductURL = urlRaw;
                        if (product) {
                            products.push(product);
                        }
                        link.processed = true;
                    })
                );

正如我在解析器中解析的那样,这是第二级解析器。我在主页上解析了产品:

$(productUrls).each(function (index, link) {
                        if (!link.processed) {
                            console.log("Download second level -> " + link.URL);
                            requests_2level.push(
                                $.post(link.URL, "", function (data) {
                                    if (IsCancel()) {
                                        return;
                                    }

                                    console.log("End download second level -> " + link.URL);
                                    var jdata = $($.parseHTML(data));
                                    var parser = new ProductPageParser(jdata, link.URL);

                                    if (!parser.isValidProduct()) {
                                        console.log(link.URL + " is not a valid product, skipped.");
                                        link.processed = true;
                                        return;
                                    }

                                    var hackUrl = "//amazon.com/o/ASIN/" + parser.getAsin();
                                    link.URL = hackUrl;
                                    var product = getProductForParser(parser, link);
                                    if (product) {
                                        products.push(product);
                                    }
                                    link.processed = true;
                                })
                            );

                        }
                    });

任何人都知道如何解决这个问题?

2 个答案:

答案 0 :(得分:0)

如果亚马逊继续将您从HTTPS重定向到HTTP,那么您就无法做到这一点:

  • 在亚马逊上努力克服他们修复
  • 使用差异化服务

答案 1 :(得分:-1)

决定是使用http还是https,并为每次通话使用相同的。