windows权限管理越来越严格,桌面应用和服务之间的交互就很成问题。服务通常以独立的服务身份运行,而且在用户登录之前就开始运行,显然不能去访问用户私人的数据,况且既然是服务,同时为多个不同的登录用户服务也是很常见的。
用socket通讯当然是个办法,但是socket本身需要额外的权限,既然是本机操作,需要网络权限也不是很合理。
比较合理的一种方式是通过公共文件。windows的用户目录下面有一个叫做“公用”的文件夹,里面的内容是所有用户都可以访问的,也包括服务用户。
如何获取公共文件路径:
- TCHAR szPath[MAX_PATH];
- int dir=CSIDL_COMMON_DOCUMENTS;
- if(S_OK!=SHGetFolderPath(NULL,
- dir|CSIDL_FLAG_CREATE,
- NULL,
- SHGFP_TYPE_CURRENT,
- szPath))
- {
- return L"";//出错
- }
CSIDL_COMMON_DOCUMENTS宏表示公共目录,还有一些别的值,如CSIDL_APPDATA代表程序目录。很多时候我们瞎猜这些目录的位置,其实正确的做法是通过API函数SHGetFolderPath获取。
通过文件交互唯一的问题是需要定时轮询。
(这里是结束)