我有这个代码:
[PermissionSet(SecurityAction.Assert, Name = "FullTrust")]
public List<WinInfo> GetWindows()
{
try
{
var isFullTrust = Assembly.GetExecutingAssembly().IsFullyTrusted;
if (isFullTrust)
{
return Process.GetProcesses().Where(z => !string.IsNullOrEmpty(z.MainWindowTitle))
.Select(z => new WinInfo
{
ProcessID = z.Id,
ProcessName = z.ProcessName,
WinID = z.MainWindowHandle,
WindowTitle = z.MainWindowTitle
}).ToList();
}
else
return null;
}
catch (Exception ex)
{
Trace.Write(ex.Message);
return null;
}
}
当我在当前用户(具有管理员权限)下在本地计算机上进行测试时,它可以正常工作,显示所有具有窗口的进程。但是当我从 Windows 服务调用此代码时,在“本地服务”帐户下运行时,列表为空。我附加到该进程,并通过调试发现“Process.GetProcesses()”返回所有进程,但所有进程的 MainWindowHandle 为 0,MainWindowTitle 为空,即使它们确实有窗口。那么我的代码有什么问题?
编辑我编辑了代码,以便它检查程序集是否完全信任并具有 PemmissionSet 应该授予代码必要的权限。结果还是一样。当我调试时,我可以看到,“isFullTrust”是“True”并且代码执行时没有异常。列表仍然是空的,因为没有进程包含非空 MainWindowTitle