Ubuntu 24.04 安装企业微信(deepin-wine 版)完整指南
环境信息
- 系统: Ubuntu 24.04 (Noble Numbat)
- 方案: deepin-wine10-stable + com.qq.weixin.work.deepin
- 核心问题: Ubuntu 24.04 与 deepin-wine 的兼容性(依赖缺失、p7zip 安全策略、XDG_RUNTIME_DIR 权限)
一、安装前的准备
1.1 修复软件源重复配置
Ubuntu 24.04 使用新的 DEB822 格式源(/etc/apt/sources.list.d/ubuntu.sources),旧的 /etc/apt/sources.list 会导致重复警告:
bash
# 清空旧的 sources.list(推荐)
sudo truncate -s 0 /etc/apt/sources.list
sudo apt update
1.2 添加 i386 架构支持
bash
sudo dpkg --add-architecture i386
sudo apt update
二、安装依赖(关键步骤)
2.1 安装 p7zip-full(16.02 版本)
核心问题 : Ubuntu 24.04 仓库中的 p7zip-full 虽然版本号是 16.02,但默认不创建 7z 命令,且新版 7zip (23.01+) 的安全策略会拒绝解压 deepin-wine 容器中的符号链接。
bash
# 安装 p7zip-full
sudo apt install p7zip-full
# 检查安装的二进制文件
dpkg -L p7zip-full | grep bin
# 输出应包含:
# /usr/bin
# /usr/bin/7z
# /usr/bin/7za
# 验证 7z 可用
7z | head -2
# 预期输出: 7-Zip [64] 16.02
常见问题 : 7z: command not found
bash
# 如果 7z 命令不存在,创建软链接
sudo ln -sf /usr/bin/7za /usr/bin/7z
2.2 安装缺失的系统依赖
Ubuntu 24.04 移除了 libsane 和 libodbc1,需要从 Ubuntu 22.04 (jammy) 源获取:
bash
# 添加 jammy 兼容源
echo "deb http://archive.ubuntu.com/ubuntu jammy main universe" | sudo tee /etc/apt/sources.list.d/jammy-compat.list
# 设置源优先级(避免整体系统降级)
cat <<EOF | sudo tee /etc/apt/preferences.d/jammy-compat
Package: *
Pin: release n=jammy
Pin-Priority: 100
EOF
sudo apt update
# 安装缺失的依赖
sudo apt install -t jammy libsane1 libodbc1 libosmesa6 libsdl2-2.0-0
# 清理临时源
sudo rm /etc/apt/sources.list.d/jammy-compat.list /etc/apt/preferences.d/jammy-compat
sudo apt update
2.3 安装 deepin-wine 和企业微信
bash
# 添加仓库 首次使用时,你需要运行如下一条命令将移植仓库添加到系统中。
wget -O- https://deepin-wine.i-m.dev/setup.sh | sh
# 安装企业微信
sudo apt install com.qq.weixin.work.deepin
wine支持软件列表: https://deepin-wine.i-m.dev/
三、解决启动问题
3.1 问题一:解压失败(p7zip 安全策略)
症状 : 启动时提示"解压失败",日志显示大量 ERROR: Dangerous symbolic link path was ignored
原因: 新版 p7zip 拒绝解压包含绝对路径符号链接的 7z 文件。
解决 : 确保使用 16.02 版本的 p7zip-full,并正确创建 7z 软链接(见 2.1 节)。
3.2 问题二:7z: command not found
症状 : /opt/deepinwine/tools/run_v4.sh: line 538: 7z: command not found
原因 : run_v4.sh 第 538 行调用 7z,但系统只有 7za。
解决:
bash
sudo ln -sf /usr/bin/7za /usr/bin/7z
3.3 问题三:XDG_RUNTIME_DIR 权限错误
症状:
QStandardPaths: runtime directory '/run/user/' is not owned by UID 1000,
but a directory permissions 0755 owned by UID 0 GID 0
原因 : /run/user/ 目录权限为 root:root 0755,而当前用户(UID 1000)需要拥有 /run/user/1000 目录。
解决:
bash
# 获取当前用户 UID
MYUID=$(id -u)
# 创建并修复 runtime 目录权限
sudo mkdir -p /run/user/$MYUID
sudo chown $USER:$USER /run/user/$MYUID
chmod 700 /run/user/$MYUID
# 设置环境变量
export XDG_RUNTIME_DIR=/run/user/$MYUID
3.4 问题四:deepin-wine-banner 重复运行
症状 : 检测到 deepin-wine-banner 运行, exit 1
原因: 之前启动的实例未正常退出,残留进程冲突。
解决:
bash
# 强制结束所有相关进程
killall -9 deepin-wine-banner WXWork.exe winedevice.exe wineserver 2>/dev/null
sleep 2
# 清理 wine 容器(强制重新初始化)
rm -rf ~/.deepinwine/Deepin-WeChatWork/
四、完整启动命令
bash
# 1. 修复 XDG_RUNTIME_DIR
MYUID=$(id -u)
sudo mkdir -p /run/user/$MYUID
sudo chown $USER:$USER /run/user/$MYUID
chmod 700 /run/user/$MYUID
export XDG_RUNTIME_DIR=/run/user/$MYUID
# 2. 结束残留进程
killall -9 deepin-wine-banner WXWork.exe wineserver 2>/dev/null
sleep 2
# 3. 清理容器(首次或出错时执行)
rm -rf ~/.deepinwine/Deepin-WeChatWork/
# 4. 启动企业微信
/opt/apps/com.qq.weixin.work.deepin/files/run.sh
五、创建桌面快捷方式
5.1 创建 .desktop 文件
bash
# 获取 UID
MYUID=$(id -u)
# 创建桌面文件
cat <<EOF > ~/.local/share/applications/wework.desktop
[Desktop Entry]
Name=企业微信
Name[zh_CN]=企业微信
Comment=企业微信 (WeCom / WeWork / WXWork)
Keywords=wework;qiye;wecom;wechatwork;wxwork;qiyeweixin;企业微信
Exec=env XDG_RUNTIME_DIR=/run/user/$MYUID /opt/apps/com.qq.weixin.work.deepin/files/run.sh
Icon=/opt/apps/com.qq.weixin.work.deepin/entries/icons/hicolor/48x48/apps/com.qq.weixin.work.deepin.svg
Type=Application
Categories=Office;Network;Chat;
Terminal=false
StartupNotify=true
EOF
# 赋予执行权限
chmod +x ~/.local/share/applications/wework.desktop
# 刷新应用菜单
update-desktop-database ~/.local/share/applications
5.2 搜索关键词
创建后可通过以下关键词搜索启动:
weworkqiyewecom企业微信wechatworkwxwork
5.3 添加到任务栏/收藏
- GNOME: 应用菜单 → 找到"企业微信" → 右键"添加到收藏"
- KDE: 右键任务栏 → 添加部件 → 启动器 → 选择企业微信
六、常见问题速查
| 问题 | 症状 | 解决 |
|---|---|---|
| 源重复警告 | W: Target Packages configured multiple times |
sudo truncate -s 0 /etc/apt/sources.list |
| 依赖缺失 | libsane / libodbc1 no installation candidate |
添加 jammy 源安装旧版依赖 |
| 解压失败 | Dangerous symbolic link path was ignored |
使用 p7zip-full 16.02 |
| 7z 找不到 | 7z: command not found |
sudo ln -sf /usr/bin/7za /usr/bin/7z |
| 权限错误 | XDG_RUNTIME_DIR not owned by UID 1000 |
修复 /run/user/$(id -u) 权限 |
| 进程冲突 | deepin-wine-banner 运行,exit 1 |
killall -9 deepin-wine-banner |
| 容器损坏 | 反复解压失败 | rm -rf ~/.deepinwine/Deepin-WeChatWork/ |
七、备选方案
如果 deepin-wine 方案持续出现问题,可考虑:
7.1 官方 Linux 版企业微信
bash
wget https://dldir1.qq.com/wework/work_weixin/linux/WeCom_4.1.20.6002_linux_x86_64.deb
sudo dpkg -i WeCom_4.1.20.6002_linux_x86_64.deb
sudo apt --fix-broken install
缺点: 功能较 Windows 版少,更新滞后。
7.2 Waydroid (Android 容器)
bash
sudo apt install waydroid
sudo waydroid init
sudo systemctl start waydroid-container
waydroid show-full-ui
# 在 Android 内安装企业微信 APK
要求: 需要 Wayland 会话,性能接近原生。
八、总结
Ubuntu 24.04 安装 deepin-wine 企业微信的核心难点在于:
- 依赖断层 :
libsane、libodbc1等包被移除,需从旧版本源获取 - 工具链变化: p7zip 安全策略收紧,需确保使用兼容版本
- 权限模型: XDG_RUNTIME_DIR 需正确设置为用户私有目录
通过本文的步骤,可以系统性地解决这些问题,最终实现稳定运行。