objective-c – 在沙盒OSX应用程序中询问用户管理员密码

前端之家收集整理的这篇文章主要介绍了objective-c – 在沙盒OSX应用程序中询问用户管理员密码前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在编写一个应用程序,我希望自定义首选项窗口在允许任何更改之前要求输入管理员密码(但从不存储它). up unitl现在我一直在使用这段代码
  1. OSStatus status;
  2. AuthorizationRef authorizationRef;
  3.  
  4. // AuthorizationCreate and pass NULL as the initial
  5. // AuthorizationRights set so that the AuthorizationRef gets created
  6. // successfully,and then later call AuthorizationCopyRights to
  7. // determine or extend the allowable rights.
  8. // http://developer.apple.com/qa/qa2001/qa1172.html
  9. status = AuthorizationCreate(NULL,kAuthorizationEmptyEnvironment,kAuthorizationFlagDefaults,&authorizationRef);
  10. if (status != errAuthorizationSuccess)
  11. {
  12. NSLog(@"Error Creating Initial Authorization: %d",status);
  13. return status;
  14. }
  15.  
  16. // kAuthorizationRightExecute == "system.privilege.admin"
  17. AuthorizationItem right = {kAuthorizationRightExecute,NULL,0};
  18. AuthorizationRights rights = {1,&right};
  19. AuthorizationFlags flags = kAuthorizationFlagDefaults | kAuthorizationFlagInteractionAllowed | kAuthorizationFlagPreAuthorize | kAuthorizationFlagExtendRights;
  20.  
  21. // Call AuthorizationCopyRights to determine or extend the allowable rights.
  22. status = AuthorizationCopyRights(authorizationRef,&rights,flags,NULL);
  23. if (status != errAuthorizationSuccess)
  24. {
  25. NSLog(@"Copy Rights Unsuccessful: %d",status);
  26. }
  27. return status;

哪个工作正常,提出一个标准的os密码对话框,要求输入管理员密码.根据返回的状态启用/禁用首选项的nib中的各种控件.但是,现在我正在尝试使用SandBox应用程序,此代码始终返回errAuthorizationDenied.我已经查看了AuthorizationCopyRights和AuthorizationCreate的doc,但我看不到在SandBoxed环境中使用它们的参考.

我尝试过各种各样的AuthorizationFlags标志,但它总是一样的结果.有没有办法修改上面的代码在沙盒中工作,或者这些天是否要求管理员密码?

解决方法

我查看了沙盒文档,Determine Whether Your App is Suitable for Sandboxing部分立即回答了您的问题.

来自文档

The following app behaviors are incompatible with App SandBox:

  • Use of Authorization Services

游戏结束.

事实上,我不确定你希望实现什么.为什么不让用户为应用程序确定自己的自定义首选项?

猜你在找的C&C++相关文章