UOS 下wine的记录

本文详细介绍了Ubuntu 1050版本中wine的安装和使用,包括wine的版本选择、Deepin社区的wine包、wine启动方式、winetrick的使用以及wine在启动应用程序、安装msi程序、处理字体问题等方面的实践。同时提到了ActiveX控件的概念和wine环境下IE的安装与问题排查。此外,文章还探讨了wine的源码学习和错误排查,以及winehq的安装步骤。
摘要由CSDN通过智能技术生成

以下情况均在1050版本获取

软件包

默认情况下,系统安装完毕不会安装任何wine包。apt search wine可以筛选出,系统源带了3个版本的wine分别是:

  • wine 4.0-2 由debian社区维护的包,应该是debian 10版本的时候默认的版本
  • deepin-wine5-stable   国内深度社区维护
  • deepin-wine6-stable   国内深度社区维护

对deepin维护的2个包,不知道在wine官网的基础上做了什么改动加强之类,目前还没看到源码开放出来。

不过从商店下的wine软件包,一般都是通过脚本带起来的,而不是直接wine命令行起来的,查了一下,启动脚本来自于deepin-wine-helper:i386这个包,查看了下这个包的内容

 推测基本上是用于辅助启动应用程序的,主要初始化wine环境目录,解压应用程序到wine环境等等,主要那几个run的脚本吧。

对于UOS应用商店的wine移植软件,干净系统情况下,任意安装一个,都会顺带把依赖的deepin-wine6-stable 或者deepin-wine5-stable给安装上(当然这两个包也会把他依赖的32位或者64位包也给装上)。

wine周边软件包

首推winetrick , 这个包可以帮助用户自动安装下载一些非wine实现的dll之类的库(其实手工安装也可以,但谁不喜欢一键XXX功能呢),也包括IE,office等一些软件,比如.net dx vc++等,毕竟wine的实现只有这些库的部分功能,原生的库才是完全体,理论上用起来效果更好,但是如果出现bug问题,wine是没办法修复的。

这个包系统里面带的还是2018年的,建议有条件上官网给升级到最新的,两三年怎么也能搞定更多功能了。

其次是Playonlinux,wine的图形前端,也是图形的,图形化协助用户安装各种软件

最后是crossover,wine的主要后台商业公司出的版本,据说早些年deepin交过学费发现没啥用,后面kylin也去交了学费,不知道醒悟过来了没

国内的版本,kylin之前自己出过一个wine的包,不知道努力了多久,有没有成果。中科方德自己也有一套wine的东西,虽然挂的软件所的title做的,但具体怎么样也不太清楚。不过市场上是不是能碰到方德的人在努力的推wine的方案。

wine使用备忘

wine 启动程序的几种方式:

#一共就3种方式,切换到程序目录直接运行,写linux全路径以及写wine盘符全路径(路径用2个反斜线表示)

cd '.wine/drive_c/xxx/'

wine xxx.exe
# 这种适合程序需要cd 到工作目录执行的方式


# 也可以指定绝对路径,这种就可以不用指定linux上的全路径,只需要指定WINEPREFIX下从盘符开始的路径,第二种方式官网手册说要加2个反斜线,不过我双引号一个反斜线,他还是启动了。
wine start 'c:\windows\notepad.exe'
wine start "c:\\windows\\notepad.exe"


#下面这种其实在Linux里面方便。
wine start /unix "$HOME/.wine/drive_c/windows/notepad.exe"

安装msi程序,不能直接通过wine带起来,需要

wine msiexec /i xxx.msi   (这个格式验证过)
或者
wine start xxx.msi

wine gecko  

这个是wine自己实现的ie,在某些程序上(有些老游戏),如果要显示html页面,wine就会调用gecko来显示,从wine5.0-rc1开始,gecko可以在系统上进行共存了,不需要每个wine的prefix环境里面都单独安装。默认安装在/usr/share/wine/gecko(实际目录就是这样的目录/usr/share/wine/gecko/wine-gecko-2.47.2-x86),如果没安装,wine第一次会提示你安装,默认会去查找本地缓存~/.cache/wine里面找包。

如何修改wine环境里面的默认浏览器 ?(后面搞完再来记录)

wine mono

可以用来运行.net程序,安装同上。

其实更多的我感觉通过winetricks安装微软的.net框架环境应该会更好用一点(上周用winetrick安装还不好使,直接从网上下.net formwork 离线包来安装还顺利一些)

gecko mono这两个看winehq的wiki就可以了。

安装IE8,这个必须借助winetricks(要搞一些dll和注册表,没细看), 7.8版本的wine用2018年的winetricks不行,可以直接去debian下最新的源码包来编译(有个什么compat版本是13的依赖,直接改为12就能过了,以前很傻不去改编译依赖)

编译完后安装IE8就可以,但他默认非要安装英文版本的,可以搞个中文的再wine 安装一遍。还没试能不能用呢。

自带的Notepad.exe输入中文字体不显示,把win下的msyh* 之类的中文sim*拷贝过来就能显示了。

winecfg的显示面板,屏幕分辨率处中文显示为方块,只需要simsun字体就行,如果觉得窗口大小不合适,直接调整dpi,重新启动程序就行了。

wine7 默认创建的环境还是64位的,需要指定WINEARCH=win32来创建32位版本的。

ActiveX 控件:查询了下,据说这个还和动态链接库相关了,据说COM COM+ 这些属于高级代码复用的范畴了,能做到跨语言以及垮机器调用了。下面是baidu到的一些基础知识。

ActiveX,OLE是基于COM的一种应用,其文件后缀一般以dll和ocx结尾;ocx作为一种特殊的dll文件,具有一定的用户界面和事件响应,而dll文件只是方法和属性的集合。

以.ocx为后缀名的ActiveX控件是一种比较特殊的DLL,它的基础是OLE和COM,是有交互界面的可视化控件,定义了控件的属性和方法,定义控件可引发的事件的响应。我们通常说的.DLL为后缀名的文件是一个包含函数和数据的模块集合,可以被其它应用程序共享的程序模块。

在web中调用ActiveX,需要在页面加入类似下面的部分(仅IE,这就是微软垄断的表现啊)

<object id="CardAccessor" 
    classid="clsid:03AD53E8-D7E7-485D-A39A-D07B37DEFBC9"     
    width="0" 
    height="0">
</object>

其中最重要的就是classid ,插件在安装的时候通过regsvr32 注册到系统的注册表中,浏览器也会通过这个id来确定加载机器上的哪一个DLL或者OCX。

注册到注册表的位置在 HKEY_CLASSES_ROOT\CLSID\{554445A9-E948-4d95-A46D-A9E84AF143B8} 这样的位置,最后一部分就是classid。

然后就可以在js中访问ActiveX插件了。

WINE学习  

对于不是做开发或者不做wine开发的人来说,对wine的学习也就仅限于,安装,使用,winetricks,playonlinux这些方法折腾了。补windows原生的dll,各种组件等。

再深入一点,补完各种库后winecfg或者注册表里面设置一下这些dll是用原生的还是wine内置的。(kernel32.dll, gdi32.dll, user32.dll, and ntdll.dll 这几个官网说只能用内置的,原生的还要调用更底层的库wine环境里没有)

然后就是利用各种渠道学来的知识折腾一下注册表,毕竟太多windows的程序爱写注册表了,注册表用来管理配置确实是好东西,但是对管理员或者用户来说,非常的不友好。毕竟ini文件这种还可以注视一下说这配置啥意思,到了注册表就自求多福能各种渠道查到啥意思吧。这也许就是开发者和用户的视角不一样吧。

再深入就得学习各种windows相关的知识了,以及看wine代码和对windows开发要有很多了解了,毕竟这都是黑盒反推回去的东西,命令行报错如果是报缺DLL或者DLL功能不对还好办,报其他的fixme或者error其实不做开发或者对wine开发不了解也是看不懂的(什么MFC VC++各种版本,OLE,COM,各种底层,谁知道问题出在哪儿,眼花缭乱)。

所以其实要排错,没点功力不行的,不单要懂wine的开发,还要懂windows开发,才能很好的诊断问题,我自己安装好ie8,但是不管打开啥网页都好久才出来,看报错啥都看不懂的,这就是懂点皮毛的表现。

快速安装官网wine

sudo dpkg --add-architecture i386
#添加32位架构
wget -nc https://dl.winehq.org/wine-builds/winehq.key
sudo mv winehq.key /usr/share/keyrings/winehq-archive.key
#添加winehq的key,否则apt install的时候会报密钥问题

wget -nc https://dl.winehq.org/wine-builds/debian/dists/buster/winehq-buster.sources
sudo mv winehq-buster.sources /etc/apt/sources.list.d/

#添加winehq的源


sudo apt install --install-recommends winehq-stable
#安装稳定分支
sudo apt install --install-recommends winehq-devel
#或者安装开发分支

不过国内网速奇慢,国内镜像还没法把wine-build给镜像下来,只能镜像源码。

我自己下载了,放百度网盘了  ,有需要的可以下

链接: https://pan.baidu.com/s/19uPtjhNZrWGACPiQXb2x4g 提取码: 6enm 
--来自百度网盘超级会员v3的分享

sudo apt install --install-recommends winehq-stable 这个命令最终要安装4个deb包,解包看了一下依赖关系 

winehq-stable 依赖 wine-stable  ,提供/usr/bin/面的wine系列的可执行程序的链接,实际会链接到wine-stable提供的/opt目录下的文件。

,wine-stable 依赖wine-stable-i386 wine-stable-amd64,提供/opt/wine-stable/bin/下面一系列可执行文件。

wine-stable-i386  提供32位的wine以及32位windows环境的一些动态静态库/opt/wine-stable/lib,

wine-stable-amd64 提供64位的wine(即wine64),以及/opt/wine-stable/lib64/下的64位windows环境的动态静态库。

这两天看了下很早之前的有个项目pipelight,这个项目可以在浏览器中安装一个npapi的插件,通过这个插件调用wine来运行需要在windows里面运行的activeX插件。

基本原理是:浏览器内pipelight插件--》调用npactiveX.dll ---> 实际插件。

不过实际使用发现,很多浏览器不只是插件,还有js等强绑定了IE浏览器,如果不修改js代码,在pipelight的wine环境里面手工安装了插件照样也显示不出来。这兼容性还真是难啊。

pipelight插件本身还有个chrome插件配合使用,可以做简单的浏览器UA修改以及添加辅助脚本。实际上发现很多网站不仅仅只靠ua来判断浏览器,还会通过js来判断实际运行的平台,这时候就应该还是需要ie模拟之类的东西。

国内中科方德的浏览器在这方面做了一些工作。有类似windows下面的IE模式。可以直接切到IE模式对这些绑定IE的js ,css兼容。它也自带了Pipelight软件包以及activeX for chrome扩展。启动的时候机会初始化一个Pipelight单独的wine环境。

  • 0
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值