BHO,C#实现了超级拖拽的效果

BHO,C#实现了超级拖拽的效果。 

分类: C# 2013-12-10 22:49 167人阅读 评论(0) 收藏 举报 

BHO

我一般习惯用IE,以前一直是搭配着IEPRO用的,主要用里面的鼠标手势等一些辅助功能。后来换了x64win7后,它在x64下的IE不工作了,虽然找到了一款可以在x64IE下使用鼠标手势软件,但它功能较单一,缺少我常用的超级拖拽和双击TAB关闭的功能,由于它是开源的,我曾经尝试过在它的代码里加上这两个功能,令我十分诧异的是,虽然景德镇里BHO相关的软件漫山遍野,一个不留神就踩上了几个,但网上BHO开发相关的文章资料却少得可怜,加上我对com完全没有接触过,被那套框架绕得晕头转向,摸索了一天后也没有啥进展,就干脆放弃了。

昨天看到园子里有人在介绍的新版Microsoft All-In-One Code Framework,看了一下,发现里面有两个用C#写的BHO的例子,基本上是一看就懂,就在它的例子上,改吧改吧,基于CSBrowserHelperObject这个工程,实现了超级拖拽的功能。关于BHO的架构可以参看MSDN,网上也有中文译本的,这里就不多介绍了,只是谈一下超级拖拽的实现。

超级拖拽主要是对文本和链接实现了鼠标拖拽的附加功能,从而能快速打开链接,减少右键菜单那繁琐的操作,以下是代码:

 

    public HTMLDocumentEventHelper(HTMLDocument document)
    {
        this.document = document;

        this.ondragstart += e => e.returnValue = true;

        var rootElementEvents = document.documentElement as HTMLElementEvents_Event;
        rootElementEvents.ondragover += () => false;
        rootElementEvents.ondrop += () => { SuperDragDrop(); return false; };
    }

        

    void SuperDragDrop()
    {
        var eventObj = document.parentWindow.@event as IHTMLEventObj2;

        //拖拽的是链接,在新窗口中打开链接
        var url = (object)eventObj.dataTransfer.getData("URL"as string;
        if (!string.IsNullOrEmpty(url))
        {
            InternetExplorer.Navigate2(url, BrowserNavConstants.navOpenInBackgroundTab);
            return ;
        }

        //拖拽的是选择的文本,则用google搜索改文本
        var text = (object)eventObj.dataTransfer.getData("TEXT"as string;
        if (!string.IsNullOrEmpty(text))
        {
            if (text.StartsWith("http://", System.StringComparison.OrdinalIgnoreCase))    //未被识别的超链接
            {
                InternetExplorer.Navigate2(text, BrowserNavConstants.navOpenInBackgroundTab);
            }
            else    //待搜索的文本
            {
                InternetExplorer.Navigate2(string.Format("http://www.google.com.hk/search?hl=zh-CN&q={0}", text)
                    , BrowserNavConstants.navOpenInBackgroundTab);
            }
            return ;
        }

        return ;
    }

 

从代码里可以看出,和在winform下实现拖拽支持基本上一样,只要实现startdrag,ondragondrop这三个事件的回调即可,非常简单。超级拖拽的具体功能用C#实现起来自然也是轻而易举。

看了一下它的mshtml的那个库,主要还是用dynamic来简化和com之间的交互的,通过它简化后,用C#实现起来比用C++简单太多了,在搞清楚了BHO的架构和摸索出那些函数的用法之后,实现的过程是非常轻松的,本想一鼓作气把双击TAB关闭的功能也实现了的,查了半天也没有找打合适的方案,大致的意思都是这个功能只能通过winapi去实现,在bho中并没有相关接口,由于winapi也是我不熟悉的地方,就暂时搁置下了,等下次有空再摸索一下。

这里顺便把开发的过程中遇到的几个问题也记录一下: 

 164IE的插件开发方法:
开发64BHO32位的没有什么区别,只需要在Visual Studio x64 Win64 命令提示下执行安装的命令Regasm即可,当然,前提是你要安x64c++编译器。

2BHO无法调试的解决方法:
遇到调试BHO无法打断点时,将注册表HKCU/Software/Microsoft/Internet Explorer/Main/TabProcGrowth的值设置为0即可(没有就加上),但需要注意的是,加上了后会导致每个窗口一个独立的进程的功能实现,如果你喜欢这个功能,在用的时候吧这个值给删掉即可。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
BHO(Browser Helper Object,浏览器辅助对象,简称BHO)   BHO是微软推出的作为浏览器对第三方程序员开放交互接口的业界标准,通过简单的代码就可以进入浏览器领域的“交互接口”(INTERACTIVED Interface)。通过这个接口,程序员可以编写代码获取浏览器的行为,比如“后退”、“前进”、“当前页面”等,利用BHO的交互特性,程序员还可以用代码控制浏览器行为,比如修改替换浏览器工具栏,添加自己的程序按钮等。这些在系统看来都是没有问题的。BHO原来的目的是为了更好的帮助程序员打造个性化浏览器,以及为程序提供更简洁的交互功能,现在很多IE个性化工具就是利用BHO的来实现。 编辑本段 技术优势   “浏览器劫持”是一种不同于普通病毒木马感染途径的网络攻击手段,而是使用各种技术(如DLL插件等)插件对用户的浏览器进行篡改。安装后,它们会成为浏览器的一部分,可以直接控制浏览器进行指定的操作,根据需要,可以让你打开指定的网站,甚至是收集你系统中的各种私密信息。最可怕的是只有当浏览器已经被劫持了,你才会发现,反应过来,原来电脑已经出现了问题。比如IE主页被改,开机就会弹出广告等等。目前,浏览器劫持已经成为Internet用户最大的威胁之一。其实“浏览器劫持”就是通过BHO的技术手段进入你的系统的,而这种技术是合法的。   从某种观点看,Internet Explorer同普通的Win32程序没有什么两样。借助于BHO,你可以写一个进程内COM对象,这个对象在每次启动时都要加载。这样的对象会在与浏览器相同的上下文中运行,并能对可用的窗口和模块执行任何行动。例如,一个BHO能够探测到典型的事件,如GoBack、GoForward、DocumentComplete等;另外BHO能够存取浏览器的菜单与工具栏并能做出修改,还能够产生新窗口来显示当前网页的一些额外信息,还能够安装钩子以监控一些消息和动作。 编辑本段 注册表位置   BHO在注册表中的位置是:HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion\Explorer\Browser Helper Objects,有兴趣的朋友可以在这里做做实验。不过一定要记住你更改的每一步,否则会出错的哦!   BHO对象依托于浏览器主窗口。实际上,这意味着一旦一个浏览器窗口产生,一个新的BHO对象实例就要生成。任何 BHO对象与浏览器实例的生命周期是一致的。其次, BHO仅存在于Internet Explorer 4.0及以后版本中。   如果你在使用Microsoft Windows? 98, Windows 2000, Windows 95, or Windows NT版本4.0 操作系统的话,也就一块运行了活动桌面外壳4.71,BHO也被 Windows资源管理器所支持。 BHO是一个COM进程内服务,注册于注册表中某一键下。在启动时,Internet Explorer查询那个键并把该键下的所有对象预以加载。   迅雷中TDAtOnce_Now.dll和xunleiBHO_Now.dll为安全   如何发现BHO里面的危险模块.   首先有一个能够查看进程的软件 冰刃就不错 下面以它为例:   先打开冰刃—会看到一个BHO在这里就可以看到危险BHO进程了

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值