我正在嘗試使用 selenium 和 node.js 獲取 url,但是當站點有警報時,我無法在 Internet Explorer 上接受它。
index.js
require('iedriver');
const express = require('express');
const webdriver = require('selenium-webdriver');
let ie = require('selenium-webdriver/ie');
function start(params) {
start_server();
let options = new ie.Options();
options.ignoreZoomSetting(true);
let driver = new webdriver.Builder()
.forBrowser('internet explorer')
.withCapabilities(options)
.build();
let site="http://127.0.0.1:3000/";
driver.get(site)
.then(()=>{
return driver.wait(webdriver.until.alertIsPresent(),10000)
.then(()=>{
let alert = driver.switchTo().alert();
return alert.accept()
console.log("go on");
})
})
;
}
const start_server=()=>{
const app = express();
const PORT = 3000;
app.use(express.static('static'));
app.get('/', function(req, res){
let options = {
root: path.join(__dirname "/../static/")
};
let fileName = 'index.html';
res.sendFile(fileName, options, function (err) {
if (err) {
log(err);
} else {
console.log('Sent:', fileName);
}
});
});
app.listen(PORT, function(err){
if (err) console.log(err);
console.log("Server listening on PORT", PORT);
});
};
start();
頁面加載時,要打開的站點會發出警報,如下所示:
索引.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<script src="loading.js"></script>
<title>Document</title>
</head>
<body>
</body>
</html>
加載.js
alert("accept before start");
這必須在 Internet Explorer 上作業。
運行時,5分鐘后顯示這個
UnhandledPromiseRejectionWarning: TimeoutError: Timed out waiting for page to load.
at Object.throwDecodedError (C:\d\adhoc\node\copyimgwz\node_modules\selenium-webdriver\lib\error.js:517:15)
at parseHttpResponse (C:\d\adhoc\node\copyimgwz\node_modules\selenium-webdriver\lib\http.js:642:13)
像這樣停下來
用硒阻止警報
拜托,知道如何用硒接受警報嗎?
編輯
我找到了一個解決方案,添加這一行它已經可以正常作業了
options.introduceFlakinessByIgnoringProtectedModeSettings(true);
uj5u.com熱心網友回復:
我能夠使它作業,添加這一行
options.introduceFlakinessByIgnoringProtectedModeSettings(true);
在這個部分
let options = new ie.Options();
options.ignoreZoomSetting(true);
options.introduceFlakinessByIgnoringProtectedModeSettings(true);
顯然,在 Internet Explorer 上,您需要激活此功能才能讓您作業。
轉載請註明出處,本文鏈接:https://www.uj5u.com/qiye/415850.html
標籤:
