[ 更换 ]
热门城市
北京上海广州深圳成都杭州南京武汉天津西安重庆青岛沈阳长沙大连厦门无锡福州济南宁波昆明苏州郑州长春合肥南昌哈尔滨常州烟台南宁温州石家庄太原珠海南通扬州贵阳东莞徐州大庆佛山威海洛阳淮安呼和浩特镇江潍坊桂林中山临沂咸阳包头嘉兴惠州泉州三亚赣州九江金华泰安榆林许昌新乡舟山慈溪南阳聊城海口东营淄博漳州保定沧州丹东宜兴绍兴唐山湖州揭阳江阴营口衡阳郴州鄂尔多斯泰州义乌汕头宜昌大同鞍山湘潭盐城马鞍山襄樊长治日照常熟安庆吉林乌鲁木齐兰州秦皇岛肇庆西宁介休滨州台州廊坊邢台株洲德阳绵阳双流平顶山龙岩银川芜湖晋江连云港张家港锦州岳阳长沙县济宁邯郸江门齐齐哈尔昆山柳州绍兴县运城齐河衢州太仓张家口湛江眉山常德盘锦枣庄资阳宜宾赤峰余姚清远蚌埠宁德德州宝鸡牡丹江阜阳莆田诸暨黄石吉安延安拉萨海宁通辽黄山长乐安阳增城桐乡上虞辽阳遵义韶关泸州南平滁州温岭南充景德镇抚顺乌海荆门阳江曲靖邵阳宿迁荆州焦作丹阳丽水延吉茂名梅州渭南葫芦岛娄底滕州上饶富阳内江三明淮南孝感溧阳乐山临汾攀枝花阳泉长葛汉中四平六盘水安顺新余晋城自贡三门峡本溪防城港铁岭随州广安广元天水遂宁萍乡西双版纳绥化鹤壁湘西松原阜新酒泉张家界黔西南保山昭通河池来宾玉溪梧州鹰潭钦州云浮佳木斯克拉玛依呼伦贝尔贺州通化朝阳百色毕节贵港丽江安康德宏朔州伊犁文山楚雄嘉峪关凉山雅安西藏四川广东河北山西辽宁黑龙江江苏浙江安徽福建江西山东河南湖北湖南海南贵州云南陕西甘肃青海台湾内蒙古广西宁夏香港澳门
培训资讯网 - 为兴趣爱好者提供专业的职业培训资讯知识

探秘,64位Office VBA能否与VB6再续良缘?64位VB6能否继续躺赢?

躺赢

长文告警,建议收藏后再阅读,谢谢。

前言

1、VBA已升64位,VBE环境还可编译DLL

探秘,64位Office VBA能否与VB6再续良缘?64位VB6能否继续躺赢?

64位VBA编译,大概就是这么个过程

很多接触过、听说过VBA的朋友,经常说VBA是解释执行的,没法编译,是离不开Office环境的VBA虽然简单强大,但也只不过是Office的深阁闺秀而已,是羞于见人的仿佛世界是公平的,让VBA满世界跑,那还得了。遇到VBA编译的话,多半会惊愕地问一句:VBA能编译?

其实,Office的VBE环境编译VBA代码为DLL,早已不是什么新鲜事。早在XP时代初期,微软就专门推出过Office的开发版,里面就包含了这些功能。但那时(本世纪初那会)售价近1000美刀,所以国内知道的人很少。

探秘,64位Office VBA能否与VB6再续良缘?64位VB6能否继续躺赢?

原理,大概是这样

笔者在前面的分享(《VBA可以编译吗?》)里也已介绍了一部分,但笔者当时是使用的32位Office,在WOW64的庇佑(遮掩)下,没感觉VB有什么障碍,对这个64位Office下的急迫性体会不是很深。所以,觉得VBE编译VBA没啥优势,更何况还是PCODE,不如使用VB6编译来得专业,毕竟VB工具链的分工就是这样的。

2、VB6IDE停更,64位编译无望,能否继续牵手Office,啃老Windows?

直到网友(VB领域的资深研究者)说没必要再研究VB,微软官方都已放弃。其他人这么说,权当是笑话,因为VB转向VBA又不是近5年或10年的事,而是26年前就定了的。所以这一次隐约感觉到里面有问题了,于是装了64位Office,来一探究竟,便有了《Office的VBE环境若能编译64位的DLL,VB6岂不是坐拥第二春?》。

尽管32位应用通过WOW64环境,得以在64位Windows上生存,甚至继续开发。但VB6编译的32位PE,不得不面临与其他64位PE之间的沟通交流的问题。微软官方那句"64位应用不能载入32位DLL,32位应用也不同载入64位DLL",让32位的VB6很是尴尬。

64位Office将VBA升级到了7.0,有了名符其实的64位真身,与其相关的一众对象(Dictionary、FileSystemObject、Encoder、Regexp等)所依赖的PE也有了64位版本。唯独VB6,微软官方信誓旦旦地说,别想了,不会再有了。

探秘,64位Office VBA能否与VB6再续良缘?64位VB6能否继续躺赢?

对,就是这段,太伤人了

早前便说了,VB6的真实身份是VBA,与Office喜结连理,也算一代功臣的功名所在。曾经VB6在指针(包括函数指针)、内联汇编、多线程、驱动等专业领域,不断被爱好者发掘扩展,不仅可以写正儿八经的企业应用(如用友),还能玩一手黑客炫技(如注入Hook)。现在,不带她玩了,看见64位就像老鼠见了猫,颜面何在?说好的VB代表着Windows的特色呢?

笔者曾经说VB/VBA里,CopyMemory不是VB里内存操作(常被广大VB/VBA人士用于指针操作)的最佳实现,更不是VB/VBA指针该有的样子。结果,连64的门槛儿都跨不过去,还吹个毛线?如果OfficeVBA能编译出64位DLL,尽管是PCODE,那意义也是非同凡响啊!

VBA编译的64位DLL,按照微软的说法,依然不能为VB6所用。但是,可以使用64位资源,以64位方式扩展64位Office,并且还能将扩展后的Office对象导出。这样,VB6就可以不费一枪一弹,继续啃老Windows,继续以躺赢的姿态供各位业余编程爱好者玩耍!不说这技术性能怎么样,光不需要继续加码学习,把精力用到更有价值的地方,想想都是很美好滴。

3、分享初衷促深入,一探究竟真学习

探秘,64位Office VBA能否与VB6再续良缘?64位VB6能否继续躺赢?

啥也不说了...

也有网友说大把优秀便捷的工具遍地都是,不必死抱VB不放。其实,这并非死抱(抱残守缺),作为BASIC衣钵传承的VB6,是一项伟大的历史遗产。其意义不仅在于天然适合编程的启蒙教育(由教育者设计用于计算机教学,解决计算机使用的高门槛问题,参考《VB前传,从教学到游戏,再到系统,似乎每步都是精心设计》),更在于为广大非IT人士提供了现代编程的『浅水区』。

所以国内计算机普及教育从早期的QBASIC到现在的VB6,都是这一系列的,那不是没有道理。更何况VB6与VBA如此之近,Office在民间办公领域又占据着统治地位。学习VB为日后踏入社会,步入工作岗位,提高效率还是蛮有帮助的。

对于业余编程人员,能够在极短时间,极少投入的情况下,尝鲜编程方式使用计算机,开启效率的全新模式,未尝不是件好事!对于编程爱好者而言,VB也是不可多得的好材料,通过学习借鉴VB内部的东西(往深里去,VB会像C一样,直奔系统底层而去),也会让自己的知识结构大为受益。

所以,探究VB6在64位下的正确打开方式,不仅能惠及广大VB/VBA人士,也能给那些研究32/64位兼容编程的人员提供些参考信息。作为非IT适用的编程技术框架分享者,笔者有必要在前几篇的基础上,图文并茂地再给大家伙分析分析。

一、64位VBA编译的DLL,堪用否?

在上篇中,按照图1编译出的DLL,笔者分析了其初步结构,不是很乐观。那本篇,继续分析其在64位Office上是否可以使用呢?毕竟WOW64兼容层能让32位匹配到64位,毕竟64位上的32位也只是忽悠人的另一方秘境之地。

探秘,64位Office VBA能否与VB6再续良缘?64位VB6能否继续躺赢?

是骡子是马,拉出去遛下不就知道了

赶紧打开心爱的Excel,Alt+F11进入VBE,引用待测试DLL,没报错,好迹象。写测试过程,智能提示和补全没问题,VBE能识别该DLL的接口,正如上图5、6所示,说明该DLL为COM组件。然后,在源码上下断点,准备F8逐行执行源码。

VB/VBA的这点好(源码级调试),就足以让人爱不释手。利用COM,其他开发工具都能实现VB/VBA这样的智能提示和代码补全,但要让源码逐句执行,随意在指定源码语句上下断点,直接在IDE中跟踪源码里变量的值,没有一个强大的解释器,肯定是不行的。

通观已有编码工具中,二进制编译型的就排除了,其他基于COM的,目前也唯有.NET有这个潜力,但是连VB.NET都前途未卜,所以目前来看VBA的解释器,微软不会轻言放弃,更不会轻易开源。微软为了迎合开源,于去年将GW-BASIC开源了。要知道,这货还是微软抱IBM大腿时期的产品,处理器还是808X。尽管开源社区呼呼开源其他型号CPU的BASIC解释器,但微软却明确表示Sorry,不能提供。

哎,没忍住,强吹了一波VB,不过笔者希望读者可以在自己的项目中,思考如何借鉴VB/VBA的这些特性。好了,来看看运行结果,与预期的差不多,不能创建自动化对象。

二、64位VBA编译出了32位DLL,为何不能用?

1、难道依赖MSVBVM60.DLL,成了祸首?

探秘,64位Office VBA能否与VB6再续良缘?64位VB6能否继续躺赢?

COM无疑,但VB6的运行库是个什么鬼?

在前篇《Office的VBE环境若能编译64位的DLL,VB6岂不是坐拥第二春?》中,分析了该DLL文件结构信息,如上图所示。和VB6编译的程序一样,导入模块只有MSVBVM60.DLL。这里也提一句安全方面的,如果没有那些针对VB的现成工具,VB程序对于逆向人员而言的确是一个不小的挑战。

但是为何VBA里为何会冒出VB6的运行库?在笔者以往虚拟机相关分享中,提到了VBA虽然与VB6同属一个体系,但二者的功能实现却是相互独立的。VBE编译并不需要VB6的编译器,这就更加确定VBE编译的DLL是PCODE。要实现编译还需要链接器,由于笔者没有Office的开发版,也不太清楚现在微软还有没有开发版(哪位有,可以提供给笔者进一步分析),所以借用了VB6的链接器,难道是链接器Link.exe在作祟?

要知道MSVBVM60.DLL虽然仍处于系统级支持,但在64位Windows上,只有32位版本。再加上微软官方的那句狠话,估计不会有64位的MSVBVM60.DLL了。这就又回到了老问题上,既然VBE编译的DLL为32位,那也不能用64位的MSVBVM60.DLL吧。所以,目前问题还不在MSVBVM60.DLL的版本上,而在于何时引入了MSVBVM60.DLL?

2、难道Link.exe除了组装外,还干了供应商的活儿?

链接器的原材料就是一堆OBJ文件,一种COFF结构的文件,源码早就编译好了。一般链接器按照PE结构,将这堆OBJ文件的内容,进行合并组装就完事了。按理Link.exe不会对代码进行动刀,自然也不会影响导入模块。为了一探究竟,有必要查看下OBJ文件的内容。

探秘,64位Office VBA能否与VB6再续良缘?64位VB6能否继续躺赢?

喏,一眼就看出来了

简单地用记事本打开编译过程中的OBJ,MSVBVM60.DLL已经赫然在列了,说明VBE在调用链接器前的编译阶段,就自有主张了,与链接器Link.exe并无关系。为了进一步说明上图中的问题,笔者将VBE中的代码用VB6编译为PCODE,来看下图:

探秘,64位Office VBA能否与VB6再续良缘?64位VB6能否继续躺赢?

有没有发现点什么?

没错,一旦编译,资源之间就有正儿八经的依赖关系,并且静态资源会在导入表中体现出来,而不是VBA依附于Office环境那样寄人篱下。同时也说明,VB6使用的Declare语句(API),只是向VB运行库进行声明,实际调用却是动态的,所以导入表中看不见其他库资源。所以,VB/VBA中使用Declare语句是一个运行时概念,效率自然没有静态编译的高了。这就是很多人鄙视VB6原因之一,实际上VB6默认不支持编译标准DLL的槽点,也该记到VB/VBA的Declare机制上。

从上图对比中还可以发现,从32位的VB6,到64位的VBA,指针从4字节变为8字节了。说明64位的VBA,期待的是64位MSVBVM60.DLL。看到这里,大家心里是不在犯嘀咕:散了吧,敢情半天,又是截图又是左顾右盼的,就讲了『VBA甩了VB6,单飞了?』讲爱情故事呢?

三、Windows终于给VB6断奶了?

没有64位的MSVBVM60.DLL,不能用熟悉的方式构建64位DLL了,就差临门一脚了,的确挺可惜的。不过别光顾着悲伤,请看《VB/VBA(代表32位)如何继续在64位Win上抖机灵(二)? 》。

64位Windows上的32位进程,是个伪货,人家可是正儿八经的64位进程。只不过系统会利用WOW64兼容层,隔离32与64位资源,才有32与64之分。这是一种简单粗暴,却行之有效的方法,也不是64位系统时的临时起意,而是当年16位向32位过渡时就想好了。

当64位Windows不能直接运行当年16位程序时,大家再次开始对Windows的兼容,担忧不已,认为不做切割舍弃,兼容的屎山就会压垮Windows。笔者以为,其实完全不是这样滴,兼容的真正压力在Intel那里,Windows这个前端表演者就是捡便宜的。事实上,64位Windows不能直接运行当年的16应用程序,除了依赖的库资源已发生变化外,更主要的是因为线程环境结构中,用于兼容的标志位被挪用给32位了。

而当大家去查微软官方文档时,会发现官网对WOW64轻描淡写道:这货是64位用户态实现。所以,作为用户态兼容层,WOW64也不可能跑到所谓32位核心态,不然逻辑就太扯了,屎山的推论更会塞满大街小巷。

既然同属用户态,又要作为兼容层,WOW64那一堆dll想要脱离进程机制(不到用户空间),以一种超然的方式存在,也不太可能。唯一正确的推论(无需专业知识),WOW64的64位dll与32位进程里的那堆dll,打得正火热呢!为毛系统能用,VB6就不能用呢?用户态还有什么见不得人的特权层?

显然不符合微软的宣传,也不符合众多安全工作者的反馈。所以VB6是可以使用WOW64机制,直接与64位DLL耍滴。既然如此,VB6没有64位版本,又会损失什么呢?当然可以继续躺着啃老Windows呀!

为什么,32位进程看不到WOW64那一堆dll呢?很多隐藏模块的方法可以看一看,链嘛,就是方便摘掉某个节点。既然32位看不见,也摸不着WOW64,64位进程又不用,要如何才能洞见玄机呢?

欢迎关注BtOfficer,更多精彩仍在继续,有严肃的技术,也有轻松的唠嗑,期待你的加入!

相关内容

怎么学?如何干?西藏7市(地)委书记在西藏日报发表文章

启航新征程 开创新局面为全面建设社会主义现代化新拉萨努力奋斗自治区党委常委、拉萨市委书记 普布顿珠党的二十大大笔擘画坚持以中国式现代化全面推进中华民族伟大复兴的宏伟蓝图,区党委十届三次全会全面铺开建设美丽幸福西藏、共圆伟大复兴梦想的壮阔实践···

2023年全区智慧旅游专业人才培训班圆满结业

6月2日,自治区旅游发展厅主办的全区智慧旅游专业人才培训班在拉萨圆满结业。培训共历时三天,累计完成全区旅游行政管理部门工作人员及涉旅企业专业技术人员培训100人。本次培训是区旅发厅深入推进学习贯彻习近平新时代中国特色社会主义思想主题教育重要···

徐汇萨迦共同举办大美西藏首届口腔学习班

随着现代医学的发展,口腔健康越来越受到人们的关注,为提高西藏地区口腔技术水平和服务质量,近日,徐汇区牙病防治所和萨迦县中心医院远程连线共同举办首届口腔学习班开班仪式。徐汇区卫生健康委副主任胡强,上海援藏干部、萨迦县委常务副书记、常务副县长沈···

自觉抵制“一对一”“一对多”等学科类培训!哈尔滨中小学生暑期预警来了

17日,记者从哈尔滨市各区教育局获悉,2023年暑假将至,南岗区、道里区、香坊区教育局向家长发出预警,自觉抵制违规培训,各区义务教育阶段学科类培训机构已经全部注销,暑假期间以任何形式开展的学科类培训均属于违规培训。家长要自觉抵制任何机构或个···

哈尔滨市道里区企投局举办“招商大讲堂”专题培训

黑龙江网讯(记者 王惠婷)10月24日,哈尔滨市道里区企投局组织开展“招商大讲堂”专题培训班,全区各招商专班负责同志及业务骨干参加培训。本次培训从实际需求出发,紧紧围绕当前招商工作中的热点、难点,对“什么是招商引资”“道里区的产业结构和主导···

团黑龙江省委举办全省青年文明号青年岗位能手学习宣传贯彻党的二十大精神培训交流会

中国青年报客户端讯(李海涛)为深入学习贯彻党的二十大精神,充分发挥青年文明号、青年岗位能手示范引领作用,在全省职业青年中掀起学习党的二十大精神热潮,11月22日,团黑龙江省委举办全省青年文明号青年岗位能手学习宣传贯彻党的二十大精神培训交流会···

辽宁葫芦岛举办外贸政策培训会推动外贸保稳增量

辽宁省葫芦岛市外贸政策培训会4月3日举办。 辽宁省贸促会供图中新网葫芦岛4月3日电 (李晛)辽宁省葫芦岛市外贸政策培训会4月3日举办。本次活动由辽宁省贸促会支持、葫芦岛市商务局主办,葫芦岛市贸促会、葫芦岛海关、中国出口信用保险辽宁分公司和辽···

山西运城:严查无证校外培训机构 查封9家警告2家

新华社太原8月5日电(记者王飞航)记者从山西省运城市政府了解到,运城市教育局近日联合市公安局等多家单位,对中心城区无证校外培训机构进行了一次突击检查,共检查了13家校外培训机构,查封9家,警告2家,发放整改通知书4份。今年7月,运城市教育局···

山西开展培训筑牢森林“防火墙”

山西新闻网3月30日讯(记者 卢奕如)今日,记者从山西省应急管理厅获悉,全省举办森林草原防灭火业务培训,邀请专家以视频会议形式,围绕森林扑火指挥实操、森林草原火灾防控经验做法、火灾现场各级各类指挥员具体操作中遇到的问题等内容进行授课。培训内···

校外培训机构治理工作取得进展 山西停办近1300所

资料图:小学生排队等待进入校园。中新社记者 刘文华 摄中新网5月11日电 据教育部网站消息,按照校外培训机构专项治理工作整体安排,教育部、民政部、国家市场监管总局启动了校外培训机构治理专项督查工作。5月9日至10日,督查组率先在北京市开展华···

山西综改区举办省技术创新中心申报培训

  8月18日,山西综改区科技金融部举办2023年度省技术创新中心申报培训会,来自区内企业、科研院所及有关单位代表160余人参加了培训。  山西省技术创新中心是以产业前沿引领技术和关键共性技术研发为核心的产业技术创新平台,承担着为区域和产业···

山西汾阳医院开展健康教育与控烟知识培训

来源:【吕梁日报-吕梁新闻网】本报讯 (记者 刘少伟) 5月18日,在“世界无烟日”到来之际,山西汾阳医院组织开展健康教育与控烟知识培训。近年来,山西汾阳医院全面落实健康中国战略,根据国家卫健委《关于2011年起全国医疗卫生系统全面禁烟的决···

山西省文物局年度田野考古技术培训班开班

10月10日,山西省文物局在运城闻喜上郭城址、邱家庄墓群举办2023年度田野考古技术培训班开班仪式。该次培训为期三个月,通过理论和实践两部分教学,旨在推进山西考古工作高质量发展,提升考古业务人员专业技术水平。本次培训由山西省考古研究院和山西···

最低每课时9元!全省学科类校外培训课时长和收费标准出台

近日,山西省发改委、省教育厅下发《关于中小学学科类校外培训收费标准及有关事项的通知》,明确全省中小学学科类校外培训收费标准,从12月17日起执行。《通知》对全省线上线下学科类校外培训基准收费标准和浮动幅度制定了科学标准。其中,义务教育阶段线···

山西天镇 阳光职业培训学校培养乡村“新农人”乡村振兴添动能

(记者 贺文生) 山西天镇县阳光职业培训学校紧紧围绕乡村振兴战略,按照“政府引导、农民自愿、立足产业、突出重点”的原则,创新高素质农民技能培训方式方法,采取以“授人以渔”的方式,让人才振兴成为助推农业农村现代化的内生动力,以高素质农民引领现···

山西:建立全过程 全链条 无缝隙安全培训制度

黄河新闻网讯(记者杨江涛)日前,山西省应急管理厅下发了《山西省安全培训管理暂行办法》(以下简称《办法》)。我省将进一步抓好安全生产这个基本盘、基本面,推动全省安全培训工作制度化、规范化、科学化,促进安全培训工作高质量发展。山西省应急管理厅厅···

山西:艺考培训机构纳入全国监管平台管理

央广网太原10月6日消息(记者郎麒) 日前,山西省教育厅、省发改委、省公安厅等部门联合制定《加强面向高中阶段学生艺考培训规范管理工作方案》,针对艺考培训的突出特点和实际情况,全面规范艺考培训行为,将艺考培训机构统一纳入全国校外教育培训监管与···

太平财险阳泉中支开展消防安全教育和有限空间作业培训

为强化员工安全意识,进一步提升员工消防和有限空间突发事件应急处理能力,9月14日,太平财险阳泉中支邀请北京市卫民安消防教育咨询中心山西分中心讲师向全体员工开展了一次消防安全教育和有限空间作业课程培训。按照防消结合、预防为主的原则,本次讲座通···

山西省数字化转型贯标试点工作宣贯培训会在太原举行

  10月20日消息,山西省数字化转型贯标试点工作宣贯培训会在太原举行。省工信厅介绍,作为国家数字化转型贯标试点省份,试点启动后将引导企业加快数字化转型,助力制造业高端化、智能化、绿色化发展。  今年,工信部启动数字化转型贯标试点工作,我省···

山西马兰花创业培训讲师大赛收官 太原市获多个奖项

山西新闻网8月31日讯(记者 冯耿姝)8月29日,山西省第四届马兰花创业培训讲师大赛圆满收官,太原市代表队在比赛中分获多个二、三等奖和优秀奖。本届大赛以“启迪创新思维·激发创业梦想”为主题,全省共有56名教师晋级复赛,其中,太原市有7名选手···