还记得2010年的时候,那时候开始喜欢上了js,经常逛MDN

一开始写些简单的油猴脚本,慢慢的接触了扩展开发,发现用自己的js知识 加上firefox的插件API,可以完成好多功能。

看了很多插件的源代码,集成很多插件功能,代码也是重构了好几个版本(基于FF功能,Components.utils.import封装了require模块加载,sqlite数据库操作,http拦截, 定时任务,Prefs操作等)

也发现FF插件其实很不安全(可以拦截http请求进行修改,进行中间人攻击)

不知不觉就写了2年。

后来FF也有了一套api工具包,我也主要通过aauto写相关的桌面程序了,就再没有更新过

特写这篇博文,记录下曾经写过的插件api功能

  github项目地址: https://github.com/legu2009/UserJS

  该插件为基础api包,通过overlay.xul,在chrome级别插入script结点引用

  简单介绍下文件夹和功能,时间太早了,有的一时也翔不起来了

|-content //插件内容文件夹

  |-datebase

    DateBase.js//sqlite数据库操作

  |-img

    Canvas.js//获取图像的base64数据或保存网页为图片

  |-io(这个用的比较少,有的可能api,只是其他插件的重写下)

    _FILE_BASE.js//系统文件描述符

    DIR_UTILS.js//文件夹公用函数

    File.js//文件操作

    File_base.js//文件操作

  |-network

    Ajax.js//ajax功能封装1.0

    Ajax2.js//ajax功能封装2.0

    CACHE.js//浏览器内存控制

    COOKIES.js//浏览器cookie控制

    HTTP_OBSERVER.js//http请求监听

    PROXY_OBSERVER.js//浏览器代理设置

    POP.js//基于pop,socket与服务器通信

    SMTP.js//基于SMTP,socket与服务器通信

    ServerSocket.js//服务器端socket代码

    Socket.js//客户端socket

  |-other

    保存的插件代码

  |-server

    httpd.js//httpserver//来源于别的项目

  |-UserJS//自己用的脚本,功能更加强,涉及安全问题,可以用于黑客技术

    network

      Ajax3.js//ajax功能封装3.0

      COOKIE_MANAGE//浏览器cookie管理,结合数据库(可以做多马甲浏览器)

      COOKIE_MANAGE_AND.js//浏览器cookie管理,无数据库

      HTTP_OBSERVER.js//HTTP请求响应的拦截,监控,可以修改返回,或制定返回文件

      HTTP_OBSERVER-53.js//以前一个版本的保存

      INFO_MANAGE.js//帐号信息管理

      OPTS_MANAGE.js//数据库初始化

  |-utils

    _TIMER.js//浏览器级别定时器api封装

    CLEAR.js//清空浏览器缓存功能(cookie,历史,flash 等)

    CONFIG.js//开启java,js功能

    dateFormat.js//时间格式化

    Group.js//组管理(用于定时任务,定时)

    jsBeautify.js

    PATH_MANAGE.js//路径管理,资源文件和实际文件路径,等相关功能

    Post.js//定时任务系统,主要是开发了个多帐号抢楼层逻辑

    Prefs.js//配置Prefs管理

    RSA.js//RSA加密

    Timer.js//定时器

    Worker.js//多任务管理,定时任务管理

    UTIL.js//公用库(md5,迭代器,加载脚本,编码转换,浏览器提示,通过调进程切换IP)

  init.js//插入chrome的初始化文件

  options.json//配置短路径配置文件,主要用于require

  overlay.xul//插件载入,修改chrome元素的信息xul文件

|-defaults //插件多语言等信息的文件夹

chrome.manifest //FF注册资源文件

install.rd f//FF插件信息文件

firefox 自写底层扩展,源码简介的更多相关文章

  1. (原创)通用查询实现方案(可用于DDD)[附源码] -- 简介

    [声明] 写作不易,转载请注明出处(http://www.cnblogs.com/wiseant/p/3985353.html).   [系列文章] 通用查询实现方案(可用于DDD)[附源码] -- ...

  2. 通用查询实现方案(可用于DDD)[附源码] -- 简介

    原文:通用查询实现方案(可用于DDD)[附源码] -- 简介 [声明] 写作不易,转载请注明出处(http://www.cnblogs.com/wiseant/p/3985353.html).   [ ...

  3. Redis核心设计原理(深入底层C源码)

    Redis 基本特性 1. 非关系型的键值对数据库,可以根据键以O(1) 的时间复杂度取出或插入关联值 2. Redis 的数据是存在内存中的 3. 键值对中键的类型可以是字符串,整型,浮点型等,且键 ...

  4. 手写Koa.js源码

    用Node.js写一个web服务器,我前面已经写过两篇文章了: 第一篇是不使用任何框架也能搭建一个web服务器,主要是熟悉Node.js原生API的使用:使用Node.js原生API写一个web服务器 ...

  5. 图解Janusgraph系列-图数据底层序列化源码分析(Data Serialize)

    图解Janusgraph系列-图数据底层序列化源码分析(Data Serialize) 大家好,我是洋仔,JanusGraph图解系列文章,实时更新~ 图数据库文章总目录: 整理所有图相关文章,请移步 ...

  6. C写的扫描器源码

    Title:C写的扫描器源码 --2010-10-27 20:02 无意间看见的一个源代码,弄回来读下. ----------------------------------------------- ...

  7. Linux内核分析(一)---linux体系简介|内核源码简介|内核配置编译安装

    原文:Linux内核分析(一)---linux体系简介|内核源码简介|内核配置编译安装 Linux内核分析(一) 从本篇博文开始我将对linux内核进行学习和分析,整个过程必将十分艰辛,但我会坚持到底 ...

  8. 手写@koa/router源码

    上一篇文章我们讲了Koa的基本架构,可以看到Koa的基本架构只有中间件内核,并没有其他功能,路由功能也没有.要实现路由功能我们必须引入第三方中间件,本文要讲的路由中间件是@koa/router,这个中 ...

  9. OpenSSL源码简介

    1.X.509标准 x509是由国际电信联盟(ITU-T)制定的数字证书标准:包含公钥和用户标志符.CA等: x509是数字证书的规范,P7和P12是两种封装形式:X.509是常见通用的证书格式.所有 ...

随机推荐

  1. javascript设计模式——Observer

    定义一种一对多的从属关系,当一个目标状态改变,所有他的从属对对象都将收到通知. 1.简单的Observer模式 实现 var Observer = function(){ this.list = [] ...

  2. 利用java生成带有干扰线的网页验证码图片

    package imageCreate; import java.awt.Color; import java.awt.Font; import java.awt.Graphics; import j ...

  3. iOS设计模式解析(四)组合模式

    组合模式:将对象组合成树形结构以表示"部分-整体"的层次结构.组合是的用户对单个对象和组合对象的使用具有一致 Cocoa Touch中组合模式使用:Cocoa Touch框架中,U ...

  4. filestream 读取视频文件

    class Program { static void Main(string[] args) { string source = @"F:\361\android studio\4.0\亲 ...

  5. 使用cvReleaseImage()释放图像出错

    前几天用opencv写程序的时候,在用cvReleaseImage()函数释放cvLoadImage()加载的图像的时候出错,如下所示: IplImage *src = cvLoadImage(fil ...

  6. 前端开发面试题收集 JS

    前端开发面试题收集-JS篇 收集经典的前端开发面试题 setTimeout的时间定义为0有什么用? javascript引擎是单线程处理任务的,它把任务放在队列中,不会同步执行,必须在完成一个任务后才 ...

  7. python-凯撒密码

    凯撒密码 简介:凯撒密码(Caesar)是最早的代换密码,对称密码的一种 算法:将每个字母用字母表中它之后的第k(称作位移值)个字母替代 代码: #-*-coding:utf-8-*- __autho ...

  8. 关于const限定符

    1.  指向非常量数据的非常量指针 具有最高的数据访问极限 .不包含const关键字. 2. 指向常量数据的非常量指针 指针可以被改写,使其指向相应类型的任何数据项, 但是它所指向的数据项的值是不能被 ...

  9. Asp.net Mvc 中的模型绑定

    asp.net mvc中的模型绑定可以在提交http请求的时候,进行数据的映射. 1.没有模型绑定的时候 public ActionResult Example0() { ) { string id ...

  10. jQuery事件对象的属性

    注:摘自<锋利的jQuery(第二版)> JQuery在遵循W3C规范的情况下,对事件对象的常用属性进行了封装,使得事件处理在各大浏览器下都可以正常运行而不需要进行浏览器类型判断. 1. ...