updater执行的第一个步骤之一是检查它是否具有对应用程序文件夹的写入权限
IPermission perm = new FileIOPermission(FileIOPermissionAccess.AllAccess,_localApplicationCodebase);
if (!SecurityManager.IsGranted(perm)) { OnProgressChanged("Security Permission Not Granted \n The updater does not have read/write access to the application's files (" + _localApplicationCodebase + ")",MessageTypes.Error); return false; } OnProgressChanged("Updater have read/write access to local application files at " + _localApplicationCodebase); return true;
在Win7 / Vista下执行时,此代码传递(意味着根据CAS,代码确实具有写访问权限),但是当我尝试编写文件时,我得到了拒绝访问(并且我确认文件未被使用)
据我所知,Vista / Win7 UAC阻止用户在程序文件文件夹中写入文件.但是,我不明白的是,如果实际上不允许,则授予许可
问候,
埃里克吉拉德
解决方法
有两种方法可以解决这个问题.您可以让用户使用“以管理员身份运行”菜单项启动应用程序.但这依赖于用户记住一些东西.更好的是将embed a manifest转换为请求管理员权限的可执行文件.在清单中,将requestedExecutionLevel设置为requireAdministrator.这将导致UAC在应用启动后立即提示用户输入管理员凭据.
正如Daniel所说,最好的解决方案是将更新功能放在一个单独的应用程序中.您的主应用程序将有一个清单,将requestedExecutionLevel设置为“asInvoker”,并将updater应用程序设置为“requireAdministrator”.您的主应用程序可以使用标准权限运行.但是当需要更新时,请使用Process.Start启动需要用户输入管理员凭据的更新程序应用程序.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。