- 认证技术问题
- 键鼠模拟点击测试工具--xdotool
- Q:命令行修改屏幕分辨率
- KVM虚拟机-复制克隆(命令行)
- 统信UOS安装cherrytree
- 未进开发者根证书导入uos浏览器生效方案
- 将A卡驱动从从radeon切换为amdgpu
- uos系统ulimit工具使用
- kvm虚拟机运行时显示“启动域时出错”
- UOS文件命名最多支持字符数
- 在uos系统中如何下载不同架构的包
- 登录时输入正确密码后无法登陆 显示密码错误
- 通过终端判断窗口特效是否开启及开启关闭窗口特效
- 应用软件驻留任务栏问题
- FTP底层存储文件乱码
- 初识apache flink
- UOS专业版1032软件商店下载安装包缓存在哪里
- 如何用命令行查看当前cpu温度
- kvm远程连接报错ssh key
- 外设/认证类userid接口获取方式
- 命令行安装字体
- UOS访问windows文件共享
- uos系统中dbus调用api实现一些基本功能
- 用命令行设置关闭显示器、进入待机、自动锁屏
- 命令切换python版本
- uos系统中dbus调用实现系统锁屏
- UOS-lsmhookmanager程序的Demo
- KVM支持UEFI引导
- 身份鉴别系统如何接入UOS的PAM框架
- UOS收集桌面日志
- UOS远程windows桌面
- 获取有效打印机日志方法
- UOS浏览器导入证书
- 开发者问题反馈指南
- 因节信息为空,导致的签名失败的问题
- 搜狗输入法导入字体库
- LightDM桌面显示器相关技术内容(系统默认)
- 源码打包为deb
- 开源大数据部署手册
- UOS查看摄像头是否链接成功
- 安装双系统后无法进入UOS系统
- 进入桌面系统弹黑屏PoolCreationFaile解决办法
- udev详解
- dpkg: 处理软件包 uos-browser-stable
- 统信云打印
- uos-route路由相关操作
- 统信UOS操作系统-共享文件夹
- 统信UOS操作系统-定时关机
- 解决 tail 命令提示“inotify 资源耗尽,无法使用
- 使用字体管理器导入字体
- 清除浏览器dns缓存
- 在 Linux 中永久修改 USB 设备权限
- kvm 显示spice协议错误
- uos系统切换java版本
- rpm包在uos系统无法直接安装
- 更改密码后如何绕过登陆密钥环验证
- deb安装后,启动菜单没有启动图标
- 应用上架报错“获取不到包信息请检查”
- qt creator不能输入中文
- uname -v 第一个字段意义
- zabbix安装文档
- 统信服安装完系统后,切换root用户没有root用户密码
- uos系统中dbus调用实现特效模式开关
- UOS非开发者模式调用dmidecode
- 非适配完成打印机官方驱动安装方法
- apache spark 部署
- 使用MegaCli做raid
- 任务栏出现两个图标
- 通过 gdebi 工具解决安装本地包缺失依赖问题
- UOS通过Nginx托管Net Core服务
- 回收站删除时提示权限问题无法删除
- Linux 命令行查看图片详细信息(分辨率、色深、格式等)
- 切换JDK默认版本
- uos Postgresql 12.1 安装过程笔记
- PostgreSQL关系数据库
- kvm虚拟机运行时显示“启动域时出错”
- 统信UOS安装steam
- 如何查看uos浏览器是否支持flash
- uos系统中dbus调用api实现个性化透明度
- 如何确定deb包是否已经过统信方面的签名
- appimage打包基础步骤
- 命令行制作U盘启动盘方法
- vim配置优化
- 强制关机后磁盘数据损坏,initramfs无法挂载进不去系统
- 如何安装Debian&uos双系统
- 激活过程中提示服务器连接失败
- UOS浏览器内部协议(部分)
- uos设备管理器取值对照表
- 系统最小化安装,字符界面实现EAP认证
- dbus使用方法
- uos系统中dbus调用实现注销系统
- KVM虚拟机--删除(命令行)
- ppd文件打包deb
- uos和uos之间如何共享奔图打印机
- 驱动安装时提示"hplip-plugin"无法安装
- 离线环境先如何激活系统
- 基于UOS 部署微软.NET环境
- 外设驱动重新打包
- 关于打包过程dpkg-source -b . 命令构建出deb包时报错简单分析
- UOS更换英伟达官方显卡驱动
- 如何查看系统安装时间
- uos1030MIPS服务器安装kms激活
- uos远程连接工具--FinalShell的安装和使用
- 公网deb包转uos的deb包
- 开机引导后无法进入系统,显示busybox v1.30.
- 统信UOS命令行更改时间
- 在商店上架的应用显示程序大小异常
- 点击桌面上关机按钮,提示阻挡关机
- UOS浏览器下查看浏览器插件情况
- 打包规范之control文件字段说明
- UOS中输入法框架的开发技术是什么?
- uos右键刷新
- 开源堡垒机JumpServer解决方案
- UOS浏览器导入根证书
- 行业版环境如何实现远程适配?
- 修改系统默认语言编码
- 统信桌面操作系统查看当前版本
- 开源ZooKeeper集群解决方案
- lspci命令的应用
- 获取xxx软件包及依赖
- 开源ffmpeg的使用
- 用uos创建共享打印机
- deb安装,右键卸载失败的问题
- 系统历史启停时间查询脚本
- 串口使用及配置
- UOS切换至root用户命令无法补全问题
- .desktop文件Exec字段参数解释
- 自签名后因为系统时间变更导致程序无法运行
- 怎么使用iBMC工具安装uos操作系统
- activemq服务无法启动
- 二进制软件包打包为deb
- apt命令提示lock异常解决方案
- 应用软件打包辅助工具v1.0版本
- "提示:E: dpkg 被中断,您必须手工运行 ‘sudo
- 最小化环境命令行激活系统
- 如何拉取软件依赖包
- dpkg: 警告: 无法找到软件包 xxx 的文件名列表文件
- uos浏览器如何清除dns缓存
- 浏览器闪退解决方案
- 检查deb包打包规范脚本
- UOS自定义右键新建文档
- apache samza部署
- UOS 实现 rc.local 开机执行命令
- smb自动挂载
- UOS 搭建Firekyin个人网站
- 统信服务器操作系统设置登录时自动填充用户名
- 修改tomcat的最大连接数
- 单用户模式下创建一个可登录的用户
UOS非开发者模式调用dmidecode
UOS非开发者模式下调用dmidecode命令
linux中很多命令需要root权限才能执行,而配置/etc/sudoers给普通用户命令权限有时不能解决问题,例如dmidecode命令会调用/sys/firmware/dmi/tables/下DMI文件和smbios_entry_point文件,而这两个文件对于普通用户没有r(读)权限,简单点,使用chmod给文件赋权即可,但如果是没进入开发者模式的UOS系统就不能这么操作了。
本文将围绕该实际案例讲解如何绕过权限问题,其他类似问题可参考解决。
解决思路:通过deb包安装时调用钩子脚本,让钩子脚本生成一个系统下的自启动脚本,再通过自启动脚本实现永久的权限修改
1、制作deb包
deb打包参考DEBIAN打包规范,这里做一个空包就行了。
lyl@lyl-PC:~$ mkdir -p ~/workspace/DEBIAN
lyl@lyl-PC:~$ cd ~/workspace/DEBIAN/
lyl@lyl-PC:~/workspace/DEBIAN$ touch control postinst postrm preinst prerm
编辑control文件,内容如下(这里为演示,字段内容都是随意定义的)
Package: test
Version: 1
Section: free
Priority: optional
Depends:
Architecture: amd64
Installed-Size: 1024
Maintainer: [email protected]
Provides: bxp
Description: test
2、钩子脚本
DEBIAN/目录下postinst,postrm,preinst,prerm为钩子脚本,会在deb包安装和卸载时执行。
执行顺序如下:
图像化安装 / dpkg -i安装:
preinst -> postinst
图形化卸载 / dpkg -r卸载:
prerm -> postrm
dpkg --purge 完全卸载:
prerm -> postrm -> postrm
升级安装:
prerm -> preinst -> postrm -> postinst
这里对postinst和postrm脚本编辑即可
postinst内容如下:
#!/bin/bash
fileDir="/etc/init.d/"
fileName="testtest"
if [ ! -e "$fileDir$fileName" ];then
touch "$fileDir$fileName"
echo "#! /bin/sh" >> "$fileDir$fileName"
echo "### BEGIN INIT INFO" >> "$fileDir$fileName"
echo "# Provides: test" >> "$fileDir$fileName"
echo "# Required-Start: $local_fs $syslog" >> "$fileDir$fileName"
echo "# Required-Stop: $local_fs $syslog" >> "$fileDir$fileName"
echo "# Default-Start: 5" >> "$fileDir$fileName"
echo "# Default-Stop: " >> "$fileDir$fileName"
echo "# Description: test" >> "$fileDir$fileName"
echo "### END INIT INFO" >> "$fileDir$fileName"
echo "chmod a+r /sys/firmware/dmi/tables/smbios_entry_point" >> "$fileDir$fileName"
echo "chmod a+r /sys/firmware/dmi/tables/DMI" >> "$fileDir$fileName"
fi
chmod 755 $fileDir$fileName
cd $fileDir
update-rc.d $fileName defaults
chmod a+r /sys/firmware/dmi/tables/smbios_entry_point
chmod a+r /sys/firmware/dmi/tables/DMI
postrm内容如下:
#!/bin/bash
fileDir="/etc/init.d/"
fileName="testtest"
update-rc.d $fileName remove
rm -fr $fileDir$fileName
3、自启脚本
自启脚本安装由上文postinst的if代码块完成,会在/etc/init.d/下生成配置文件。
/etc/init.d/用于放服务脚本,当Linux启动时,会寻找这些目录中的服务脚本,并根据脚本的run level确定不同的启动级别。编写init.d/下的脚本需要符合LSB脚本规范。
LSB脚本规范:
脚本描述信息应该用### BEGIN INIT INFO 和 ### INIT INFO来分隔。分隔行可以包行尾部空白,脚本会忽略它。在分隔行之间包围区域其描述信息需要遵循这样的格式: # {keyword}: [arg1] [arg2] ...。,在#和keyword之间只能而且必须有一个空格。
#! /bin/sh
### BEGIN INIT INFO
# Provides: test
# Required-Start: $local_fs $syslog
# Required-Stop: $local_fs $syslog
# Default-Start: 5
# Default-Stop:
# Description: test
### END INIT INFO
chmod a+r /sys/firmware/dmi/tables/smbios_entry_point
chmod a+r /sys/firmware/dmi/tables/DMI
4、打包并自签名验证
lyl@lyl-PC:~$ dpkg-deb --root-owner-group -b ~/workspace ~/test_amd64.deb
自签名参考UOS生态官网(www.chinauos.com)的文档“开发者调试签名”。
安装签名包后即可调用dmidecode命令。
lyl@lyl-PC:~$ dmidecode -t 1
# dmidecode 3.2
Getting SMBIOS data from sysfs.
SMBIOS 3.1.1 present.
Handle 0x0001, DMI type 1, 27 bytes
System Information
Manufacturer: IPASON
Product Name:
Version: Not Specified
Serial Number: None
UUID: 03000200-0400-0500-0006-000700080009
Wake-up Type: Power Switch
SKU Number: None
Family: None