当前位置: 首页>>代码示例>>C#>>正文


C# FileSecurity.GetSecurityDescriptorBinaryForm方法代码示例

本文整理汇总了C#中System.Security.AccessControl.FileSecurity.GetSecurityDescriptorBinaryForm方法的典型用法代码示例。如果您正苦于以下问题:C# FileSecurity.GetSecurityDescriptorBinaryForm方法的具体用法?C# FileSecurity.GetSecurityDescriptorBinaryForm怎么用?C# FileSecurity.GetSecurityDescriptorBinaryForm使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在System.Security.AccessControl.FileSecurity的用法示例。


在下文中一共展示了FileSecurity.GetSecurityDescriptorBinaryForm方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: GetSecAttrs

 private static unsafe Win32Native.SECURITY_ATTRIBUTES GetSecAttrs(FileShare share, FileSecurity fileSecurity, out object pinningHandle)
 {
     pinningHandle = null;
     Win32Native.SECURITY_ATTRIBUTES structure = null;
     if (((share & FileShare.Inheritable) != FileShare.None) || (fileSecurity != null))
     {
         structure = new Win32Native.SECURITY_ATTRIBUTES {
             nLength = Marshal.SizeOf(structure)
         };
         if ((share & FileShare.Inheritable) != FileShare.None)
         {
             structure.bInheritHandle = 1;
         }
         if (fileSecurity == null)
         {
             return structure;
         }
         byte[] securityDescriptorBinaryForm = fileSecurity.GetSecurityDescriptorBinaryForm();
         pinningHandle = GCHandle.Alloc(securityDescriptorBinaryForm, GCHandleType.Pinned);
         fixed (byte* numRef = securityDescriptorBinaryForm)
         {
             structure.pSecurityDescriptor = numRef;
         }
     }
     return structure;
 }
开发者ID:pritesh-mandowara-sp,项目名称:DecompliedDotNetLibraries,代码行数:26,代码来源:FileStream.cs

示例2: GetSecAttrs

        // If pinningHandle is not null, caller must free it AFTER the call to
        // CreateFile has returned.
        //
        // [....]: Copied this from System.IO.FileStream
        //
        private static unsafe SECURITY_ATTRIBUTES GetSecAttrs(
            FileShare share,
            FileSecurity fileSecurity,
            out object pinningHandle)
        {
            pinningHandle = null;
            SECURITY_ATTRIBUTES secAttrs = null;
            if ((share & FileShare.Inheritable) != 0 || fileSecurity != null)
            {
                secAttrs = new SECURITY_ATTRIBUTES();
                secAttrs.nLength = (int)Marshal.SizeOf(secAttrs);

                if ((share & FileShare.Inheritable) != 0)
                {
                    secAttrs.bInheritHandle = 1;
                }

                // For ACLs, get the security descriptor from the FileSecurity.
                if (fileSecurity != null)
                {
                    byte[] sd = fileSecurity.GetSecurityDescriptorBinaryForm();
                    pinningHandle = GCHandle.Alloc(sd, GCHandleType.Pinned);
                    fixed (byte* pSecDescriptor = sd)
                        secAttrs.pSecurityDescriptor = pSecDescriptor;
                }
            }
            return secAttrs;
        }
开发者ID:JianwenSun,项目名称:cc,代码行数:33,代码来源:LogStore.cs


注:本文中的System.Security.AccessControl.FileSecurity.GetSecurityDescriptorBinaryForm方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。