问题
在用户机器上,我们的升级程序弹出一个UAC请求框,用户同意后,又弹出一个,用户再次同意后,
又弹出一个……一直这样弹了十几个。
程序的逻辑
我们的主程序启动之后,会启动一个异步回调,周期是8小时。异步回调函数里面会启动一个更新进程。
更新进程用来检查服务端有没有新版本。
更新进程是以runas方式调用ShellExecuteEx来启动的,会弹出UAC框,来请求管理员权限。
更新进程安装新版本时,需要释放文件到Program Files (x86)目录下,是需要管理员权限的。
问题原因
发生问题的用户的场景是,该用户电脑保持开机状态,然后离开电脑很多天,所以经过了很多个8小时。
因为回调函数是被异步调用的,所以ShellExecuteEx会被调用很多次来向系统请求管理员权限。
因为第一次调用而弹出的UAC框,一直没有得到用户的处理,导致后面的调用全部阻塞,形成一个队列。
一旦用户回到电脑前,开始处理第一个,后面的请求会被依次处理,会导致处理完一个UAC框,
又弹出一个,直到队列中的全部被处理完。
解决方案
解决方案是一开始不要创建一个周期性的异步回调,而是创建一个一次性的异步回调,
然后在这个异步回调函数退出前,再创建一个一次性的异步回调……一直这样递归下去。