Chrome扩展程序开发实例:QQ邮箱密码自动填写

发布时间: 编辑:RILL 0人评论 20616次浏览 chrome插件开发
摘要 : 本文以一个简单的例子来讲解Chrome扩展程序的基本开发过程,从代码编写到加载运行、整个扩展程序的运行原理以及调试。

chrome扩展程序开发背景

经常有人说程序员与产品经理之间的关系是“死对头”,网上还有程序员跟产品经理打起来的案例,而基本上都是由需求引发的。说到需求一天某懒产品经理提出了一个懒需求,大概是这样的:想从我们公司的cms后台点击进入另一个第三方后台的同时,将cms后台的一些数据自动填充到那个第三方后台的一些表单中。也就是说,以前他们需要把数据、文字一个一个拷贝粘贴到第三方后台,现在他们不干了,想让我帮他们实现这个自动“搬迁”数据的过程。这该怎么办呢?那个第三方后台也不是我能控制的了的啊,这时就要使用chrome扩展程序这个神器了,它可以实现浏览器上多个页面之间的数据传递呢!

chrome扩展程序开发背景

chrome扩展程序开发简介

关于chrome扩展程序的开发,本站也推出Chrome浏览器扩展开发系列一至十并持续更新中。chrome扩展程序能做的事情还是挺多挺好玩的,本文只是以一个很简单的例子来讲解一下它的基本开发过程,从代码编写到加载运行,最后再说明一下整个扩展程序的运行原理以及调试。这个简单例子是这样的:将一些QQ邮箱的账号密码写在文件中,然后进入QQ邮箱登陆界面的时候带入一个id参数,chrome插件根据这个id去读取QQ账号密码自动填充到登录表单中,无需我们手动输入,然后这个扩展程序还要能记录邮箱的登录情况。

chrome扩展程序开发过程

一、编写代码

首先创建一个空文件夹qqmail用于存放这个扩展程序所有的代码文件,然后写一个配置文件manifest.json,配置文件各个参数配置和意义如下:

manifest.json

说明(browser_action和page_action只能选其中一个):
browser_action:扩展程序图标在chrome地址栏之外,chrome主工具栏右侧。定义处理事件适用于所有页面。
page_action:扩展程序图标在chrome地址栏之内右侧。定义需要处理的页面的事件,并不是适用于所有页面的。
扩展程序背景页脚本:在以上配置中为background.js,是一个独立于所有页面的脚本,常用于管理一些任务或状态,可作为不同页面之间传递数据的桥梁。它会在扩展程序的整个生命周期都存在,同时,在同一时间只有一个实例处于活动状态。

接下来,编写扩展程序弹窗页面popup.html:
popup.html

popup.html中引入了两个js文件,一个是jQuery文件,另一个则是用于刷新弹窗内容的popup.js,不过,这里要先介绍一下扩展程序背景页脚本background.js:background.js

这个文件主要记录了一些QQ邮箱的账号、密码和独立密码,并维护当前登录邮箱的登录状态,使用chrome.runtime.onMessage.addListener()监听来自content script脚本的请求。
好了,现在回过头来看看popup.js:

popup.js

这个js文件主要是通过chrome.extension.getBackgroundPage()与扩展程序背景页脚本background.js取得联系,并调用其中的qqmail.getInfo()取得当前登录邮箱的信息,刷新弹窗页面popup.html的内容。
最后就是content script文件content_scripts.js:

content_scripts.js

这个脚本是运行在chrome每一个页面的,主要工作就是判断当前页面是哪个页面并作出相应动作,使用chrome.runtime.sendMessage()从背景页脚本请求数据、发送邮箱登陆状态给背景页。

好了,到这里这个简单的chrome扩展程序便开发完成了,目录的所有文件如下: 

chrome扩展程序目录文件 

二、加载运行

代码编写完毕之后便可以开始加载这个扩展程序来运行了,在chrome上的操作示意图如下:
 chrome扩展程序运行
点击“加载已解压的扩展文件”选中刚刚的目录qqmail,加载之后信息如下:
chrome扩展程序加载后信息
至此,这个简单的chrome扩展程序已经开始运行。

三、扩展程序的运行原理

接下来操作一下邮箱登录过程,并逐步说明这个扩展程序的运行过程与原理。
加载之后点击扩展程序图标,弹窗页面脚本popup.js便会请求背景页脚本background.js,获取邮箱信息,刷新弹窗页面内容,由于此时还没有进入QQ邮箱登录页面并传id参数,所以background.js中还没有当前登录邮箱的任何信息,所以弹窗页面是这样的:  

弹窗页面
接下来打开QQ邮箱登录页面并传id,比如这样:https://mail.qq.com/?id=1,进入这个页面之后content script脚本content_scripts.js通过url匹配找到要执行的动作,即:取得参数id的值,并调用背景页脚本background.js的qqmail.setInfo()函数,取得当前要登录邮箱的信息并保存在info对象中。这时,由于QQ邮箱登录表单位于登录页面中的iframe中,扩展程序的content script脚本content_scripts.js也运行其中,通过脚本中第二个url匹配,发送消息给背景页脚本background.js,调用其中的qqmail.getInfo()函数取得info对象中的账号和密码,自动填充到登录表单中,这样就无需我们手动输入了。此时再去点击扩展程序图标,弹窗脚本popup.js再次请求背景页脚本background.js中的qqmail.getInfo()函数获取当前登录QQ邮箱信息,刷新弹窗页面,效果是这样的:

弹窗页面
接下来,点击登录,进入独立密码填写页面,content script脚本content_scripts.js通过与背景页脚本background.js通信,做两个动作:首先调用qqmail.setStatus()函数设置邮箱登录状态,然后调用qqmail.getInfo()函数取得独立密码并自动填充表单。此时再点击扩展程序图标,popup.js重新请求背景页脚本刷新弹窗页面如下:
 弹窗页面

同样的,登录成功、退出登录时,content script脚本content_scripts.js也都会发消息给背景页脚本background.js去修改当前登录邮箱的登录状态,即更新info对象的值,点击扩展图标时弹窗页面脚本popup.js也会请求背景页脚本background.js获取当前登录邮箱状态,刷新弹窗页面。
好了,现在大概了解chrome扩展程序大概的运作原理了吧。整个扩展程序主要涉及三个js脚本文件:
1. 弹窗页面脚本:每点击一次扩展程序图标则运行一次,主要负责通过与背景页脚本通信,请求数据,刷新弹窗内容。
2. content script脚本:运行于chrome中每个打开的页面,可与背景页脚本通信,可操作当前页面。
3. 背景页脚本:独立于chrome任何页面,存在于扩展程序整个生命周期,一般用于保存一些数据状态,充当不同页面之间数据交流的桥梁。

四、调试方法
最后,简单说一下chrome扩展程序开发过程中的调试方法。弹窗页面脚本的调试方法:右键扩展图标,点击“审查弹出内容”即可弹出调试窗口,对弹窗页面进行抓包。content script脚本的调试方法则与一般调试相同,直接按“F12”按钮即可。而背景页脚本,由于没有具体页面,故无法直接调试,可通过弹窗页面脚本和 content script脚本使用一定方法间接调试,因为这两个脚本都可获取到背景页脚本中的数据啊。修改了扩展程序代码之后,保存,然后直接在chrome扩展程序管理页面点击“重新加载”即可生效!

其实chrome扩展程序能做的事情还真挺多的,本文只是提供了一个很简单的例子来说明它的开发过程与运行过程而已。一般来说,我们可以通过在某个第三方网页的url末尾加上我们自定义的参数,由我们的chrome扩展程序的content script脚本根据这个参数去请求我们自己的接口,获取数据来填充这个网页的表单,或是做一些其他的操作来达到我们的目的,也可以在content script脚本中定义某个页面的某个按钮的点击事件,在事件响应函数中就可以做我们想做的事情就是了,当然了,操作页面上的内容之前,首先要先研究一下这个页面的html代码,不然你怎么知道去操作哪些控件呢是吧。

文章转自:https://www.cnblogs.com/wujuntian/p/7890091.html

查看更多

转载必须注明来自:https://huajiakeji.com/dev/2019-01/1784.html

30 Seconds of Knowledge

30 Seconds of Knowledge

0 人评论 10738 次人浏览 4.0分 4.0 分
30 Seconds of Knowledge Chrome学习插件,每次打开新标签页时,Google Chrome扩展程序都可以让你获得新的开发人员技能。
评论:(0)

已有 0 位网友发表了一针见血的评论,你还等什么?