我有混合内容错误,在网站上使用了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;
})
);
}
});
任何人都知道如何解决这个问题?
答案 0 :(得分:0)
如果亚马逊继续将您从HTTPS重定向到HTTP,那么您就无法做到这一点:
答案 1 :(得分:-1)
决定是使用http还是https,并为每次通话使用相同的。