惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

T
The Blog of Author Tim Ferriss
Know Your Adversary
Know Your Adversary
P
Palo Alto Networks Blog
D
Darknet – Hacking Tools, Hacker News & Cyber Security
K
Kaspersky official blog
L
LINUX DO - 热门话题
P
Proofpoint News Feed
P
Privacy & Cybersecurity Law Blog
Google DeepMind News
Google DeepMind News
Attack and Defense Labs
Attack and Defense Labs
Cisco Talos Blog
Cisco Talos Blog
AI
AI
L
LINUX DO - 最新话题
H
Heimdal Security Blog
Hacker News: Ask HN
Hacker News: Ask HN
Webroot Blog
Webroot Blog
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
The GitHub Blog
The GitHub Blog
I
Intezer
Blog — PlanetScale
Blog — PlanetScale
有赞技术团队
有赞技术团队
S
Securelist
博客园_首页
IT之家
IT之家
Schneier on Security
Schneier on Security
博客园 - 叶小钗
罗磊的独立博客
WordPress大学
WordPress大学
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
MongoDB | Blog
MongoDB | Blog
P
Proofpoint News Feed
阮一峰的网络日志
阮一峰的网络日志
A
Arctic Wolf
Cyber Security Advisories - MS-ISAC
Cyber Security Advisories - MS-ISAC
Exploit-DB.com RSS Feed
Exploit-DB.com RSS Feed
W
WeLiveSecurity
The Register - Security
The Register - Security
D
DataBreaches.Net
S
Security @ Cisco Blogs
Security Archives - TechRepublic
Security Archives - TechRepublic
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
腾讯CDC
Recorded Future
Recorded Future
NISL@THU
NISL@THU
N
News and Events Feed by Topic
T
Tailwind CSS Blog
N
News and Events Feed by Topic
Cyberwarzone
Cyberwarzone
T
Tor Project blog
www.infosecurity-magazine.com
www.infosecurity-magazine.com

夏叶随风 – 魔帆博客

QDBus之路----------Hello DBus | 魔帆博客 校园网客户端 for linux解决方案 | 魔帆博客 为Linux应用说句公道话 | 魔帆博客 JetBrains全家桶翻译插件 | 魔帆博客 漫画趣解 Linux 内核构造 | 魔帆博客 chrome-dev v58以上版本开启自带flash插件 | 魔帆博客 用c实现动态数组(int)精简版 | 魔帆博客
QDBus之路----------Polkit-Qt5 | 魔帆博客
夏叶随风 · 2017-05-26 · via 夏叶随风 – 魔帆博客

没看上一篇的需要看上一篇 QDBus之路———-Hello DBus

我们都知道linux下有些惭怍需要root运行,然后通常直接sudo,但是,对于linux小白用户而言,总不能一运行软件就弹出要求用户sudo xxx重新运行软件吧,估计别人连sudo是啥都不知道

所以,软件要进行root操作,就需要利用polkit

其实polkit也没那么神圣,不过是读取对应的配置文件来验证用户下罢了。

实现root操作的大致原理就是写一个daemon,所以的root操作都写到这里,然后用dbus吧接口暴露出去,不过daemon暴露出去的接口都需要自行调用polkit(这里使用的是qt风格的polkit-qt5)进行验证,验证通过再继续操作

然后这个daemon还要在systemBus注册dbus服务,并且要手动sudo运行或者让他开机自启(dbus运行时自启动死活启动不了,sessionBus上注册能自启,但是明明指定了root用户结果还是普通用户运行,没权限)

polkit验证请求

Authority::Result result;
// 第一个参数是需要验证的action,和规则文件写的保持一致
result = Authority::instance()->checkAuthorizationSync(actionId, UnixProcessSubject(applicationPid),
                                                       Authority::AllowUserInteraction);
if (result == Authority::Yes) {
    //验证通过,进行root操作
}else {
    //验证不通过,不进行任何操作并return
}

源码:

https://github.com/1377195627/polkit-qt-example.git