- 浏览器插件的介绍
- Chrome浏览器插件开发的准备工做
- manifest.json配置介绍
- 页面如何注入scripts文件
1、 浏览器插件的介绍
浏览器插件是一种遵循必定规范的应用程序接口编写出来的,是对其进行起一个补充做用的程序,如播放Flash文件,浏览器自己是没有这个功能的,因此要经过插件来达到播放的功能。javascript
经常使用的浏览器插件有:php
Flash插件、RealPlayer插件、ActiveX插件、雅虎插件,百度,QQ, 搜狗,新浪,360网购,抢票工具等。css
2、Chrome浏览器插件开发的准备工做
本文主要以google chrome浏览器做为教程,其余浏览器能够经过本次案例进行触类旁通。html
Google chrome浏览器开发教程为英语,又加上中国大陆没法访问google chrome浏览器开发网站,让开发者带来必定的阻碍。java
其实开发插件很是简单,只要你具有javascript、html和css的知识,编写插件事半功倍。jquery
开发工具:正则表达式
浏览器:google chrome浏览器chrome
IDE:sublime text、notepad++、记事本、phpstorm等任一编辑器便可json
文件结构:后端
simple01
|-- manifest.json 工程配置文件,主要文件。
|--xxx.js 执行脚本
| --xxx.css 样式文件
| -- xxx.png 图片文件
测试环境:
打包发布插件:
发布升级版本:
3、manifest.json配置介绍
Manifest工程配置文件:manifest.json,最基础的文件,也是最重要的文件。
从后缀能够看出它是JSON格式的文件,JSON格式的介绍:
JSON (JavaScript Object Notation) 是一种轻量级的数据交换格式。它基于ECMAScript的一个子集。
JSON采用彻底独立于语言的文本格式,可是也使用了相似于C语言家族的习惯(包括C、C++、C#、Java、JavaScript、Perl、Python等)。
这些特性使JSON成为理想的数据交换语言。 易于人阅读和编写,同时也易于机器解析和生成(通常用于提高网络传输速率)。
[来自百度百科]
案例以下:
manifest_version
manifest文件内容格式的版本,目前版本为2,本次介绍的格式都是基于该版本的.
version
该浏览器插件的版本。
name
该浏览器插件的名称。
description
该浏览器插件的描述信息。
browser_action
浏览器插件的工具栏图标。
permissions
浏览器插件须要的权限,支持正则匹配。google对于安全性是至关重视,该配置也是重要的环节!
background
浏览器插件后端程序,大部分浏览器插件api,以及https网站都须要后端程序来完成。如:获取浏览器插件的版本号。
content_scripts
页面注入配置。例如:向域名为xx的注入一串输出hello world的脚本,就须要该配置,同时也须要配置拥有该域名xx的权限。
4、页面如何注入scripts文件
了解如何注入scripts文件,咱们先经过一个实例来了解。
本次案例是如何在淘宝登陆页面上自动输入用户名和密码。
1.manifest.json permissions配置
"permissions":[ "https://login.taobao.com/*" ]
*正则匹配符
2.manifest.json content_scripts配置
"content_scripts":[ { "matches":["https://login.taobao.com/*"], "js":["taobao_login.js"], "run_at":"document_end", "all_frames":true } ]
matches: 须要注入的脚本页面的URL,支持正则表达式。
js: 注入的脚本文件,相对路径。
run_at: 注入的位置,document_start文档的开始,document_idel文档的中间 , document_end文档的末尾。
all_frames: 是否全frame注入,好比页面使用了iframe或者frame。
3.编写taobao_login.js
语法为javascript,固然你也能够引入jquery。引入的配置为:
本次案例为纯javascript,先查看淘宝的登陆页面。
经过页面DOM树的查看,咱们得知用户名和密码输入的Dom标识。
相应的taobao_login.js代码为:
setTimeout(function(){ var username = document.getElementById('TPL_username_1'); username.focus(); username.value = "oShine"; var password = document.getElementById('TPL_password_1'); password.focus(); password.value = "oShine"; var submitStatic = document.getElementById("J_SubmitStatic"); submitStatic.focus(); setTimeout(function(){ //检测是否须要安全验证 var noCaptcha = document.getElementById("nocaptcha"); if(noCaptcha && noCaptcha.className == "nc-container tb-login" && noCaptcha.style.display !="block") { var submitStatic = document.getElementById("J_SubmitStatic"); if(submitStatic) submitStatic.click(); } },2000); },3000);
manifest.json:
{ "manifest_version": 2, "version": "1.0.1", "name": "淘宝自动登陆助手", "description": "淘宝自动登陆助手", "browser_action": { }, "permissions": [ "https://login.taobao.com/*" ], "background": { }, "content_scripts": [ { "matches": ["https://login.taobao.com/*"], "js": ["taobao_login.js"], "run_at": "document_end", "all_frames": true } ] }
案例结束!!
Chrome Extension Developer QQ群: 15785475
下一章节、Chrome浏览器插件开发-关于