我过去三天一直在尝试完成这项工作,所以请不要回复 chrome API 的链接或类似的东西。
我正在开发一个与 mySql 数据库通信的 Chrome 扩展程序,以获取用户最喜欢的网站,以及每个网站的登录名/密码(比如说 facebook fbuser fbpass、google gguser ggpass ...)
所以扩展的目标是为每个网站打开一个新标签,并进行登录。
我已经建立了与数据库的通信,并且可以成功打开网站的新标签,但我一直在忙于在每个网站上插入用户名和密码。我的问题是我不能使用 document.getElementsById('input')... 因为它返回我弹出窗口上的元素,而不是网页上的元素。
因此,我已经阅读了有关 chrome.tabs.executeScript() 的内容,并且正在尝试使用它(看来这是我需要用来访问网页的 DOM 的内容)。
所以我正在使用类似的东西:
chrome.tabs.create({"url": web[i],"selected":false},function(tab) {
chrome.tabs.executeScript(tab.id, {file:"write.js"}, function(){
});
});
并且“write.js”必须进行自动填充。
所以这里开始我的问题:
我有一个“警报(“我在”);“ write.js 中的消息,并且它永远不会显示(因此永远不会调用函数的其余部分)。(我在互联网上找到了这个函数“write.js”)。
在这里,我将发布我的弹出 html、清单和 js 的部分内容,也许我必须在那里更改一些内容,因为我已经尝试了我在大多数示例中看到的内容并且不适合我。
清单.json:
{
"name": "MyExtension",
"version": "1.0",
"description": "My chrome extension",
"icons":{
"128":"icon_128.png"
},
"browser_action": {
"default_icon": "icon.png",
"popup": "consulta_empleados.html"
},
"permissions": [
"http://*/*",
"https://*/*"
]
}
Consulta_empleados.html(弹出窗口):
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
<title>Consulta Registro con AJAX</title>
<script src="ajax.js"></script>
</head>
<body>
<form name="form1" method="post" >
<label>
<div align="center">Email<br>
<input type="text" name="email" id="email">
</div>
</label>
<p align="center">
<label>
<input type="submit" name="open" id="open" value="Log In" onClick="runScript()">
</label>
</p>
</form>
<div id="resultado"></div>
<div id="prova"></div>
</body>
</html>
文件 ajax.js:
function runScript(){
...
//here I fill a vector with the usernames, the websites and the passwords from the data coming from my database. var num is the number of websites
...
var i=0;
while(i<num){
chrome.tabs.create({"url": web[i],"selected":false},function(tab) {
chrome.tabs.executeScript(tab.id, {file: "write.js"}, function(){
});
});
i++;
}
}
write.js:
function write() {
...
alert("I'm in");
...
}
write();
提前致谢。