powered by simpleCommunicator - 2.0.55     © 2025 Programmizd 02
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Форумы / WinForms, .Net Framework [игнор отключен] [закрыт для гостей] / А как в .Net обстоят дела с правами на объекты (реестр, файл...), сменой владельца и т.п.?
25 сообщений из 60, страница 1 из 3
А как в .Net обстоят дела с правами на объекты (реестр, файл...), сменой владельца и т.п.?
    #38842344
Дмитрий77
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Например:
Есть ветка реестра
Надо понять, есть ли у пользователя (пусть будет администратор) определенные права скажем на удаление/модификацию ключей
Надо понять, является ли пользователь владельцем этой ветки
Надо уметь сменить владельца
Надо уметь сменить права
ну и т.д.

На API я все это делал месяца 3 назад - еще свежо.
Есть .Net классы?

Кой-чего начал копать, напр. могу узнать администратор ли пользователь:
Код: vbnet
1.
2.
3.
  Public Function IsAdministrator() As Boolean
    Return New WindowsPrincipal(WindowsIdentity.GetCurrent()).IsInRole(WindowsBuiltInRole.Administrator)
  End Function



Ну, если с этим тоже фигово, передеру API-вариант.
...
Рейтинг: 0 / 0
А как в .Net обстоят дела с правами на объекты (реестр, файл...), сменой владельца и т.п.?
    #38842348
Фотография Изопропил
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Мыши плакали, кололись, но продолжали грызть кактус
...
Рейтинг: 0 / 0
А как в .Net обстоят дела с правами на объекты (реестр, файл...), сменой владельца и т.п.?
    #38842369
Дмитрий77
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Изопропил,
хорош язвить.
Пример, чтоб было понятнее о чем речь:
15846991
Ты уже наверно понял, что если мне чего-то надо, то я всегда догрызаю до победного. А мне надо.
Так что там .Net об этом думает?
...
Рейтинг: 0 / 0
А как в .Net обстоят дела с правами на объекты (реестр, файл...), сменой владельца и т.п.?
    #38842373
Фотография hVostt
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Дмитрий77Ты уже наверно понял, что если мне чего-то надо, то я всегда догрызаю до победного. А мне надо.

Читай от корки до корки:

http://msdn.microsoft.com/ru-ru/library/ms229742(v=vs.110).aspx
...
Рейтинг: 0 / 0
А как в .Net обстоят дела с правами на объекты (реестр, файл...), сменой владельца и т.п.?
    #38842380
Фотография Изопропил
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Дмитрий77,

Дмитрий77Так что там .Net об этом думает?
net думает, что у него есть managed c++
...
Рейтинг: 0 / 0
А как в .Net обстоят дела с правами на объекты (реестр, файл...), сменой владельца и т.п.?
    #38842396
Дмитрий77
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
hVosttЧитай от корки до корки:

http://msdn.microsoft.com/ru-ru/library/ms229742(v=vs.110).aspx
OK,
System.Security.AccessControl

А про смену владельца есть где?

!!!VB6
Код: vbnet
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
29.
30.
31.
32.
33.
34.
35.
36.
37.
38.
39.
40.
41.
42.
43.
44.
45.
46.
47.
48.
49.
50.
51.
52.
53.
54.
55.
56.
57.
58.
59.
60.
61.
62.
63.
64.
65.
66.
67.
68.
69.
70.
71.
72.
73.
74.
75.
76.
77.
78.
79.
80.
81.
82.
83.
84.
85.
86.
87.
88.
89.
90.
91.
92.
93.
94.
95.
96.
97.
98.
99.
100.
101.
102.
103.
104.
105.
106.
107.
108.
109.
110.
111.
112.
113.
114.
115.
116.
117.
118.
119.
120.
121.
122.
123.
124.
125.
126.
127.
128.
129.
130.
131.
132.
133.
134.
135.
136.
137.
138.
139.
140.
141.
142.
143.
144.
145.
146.
147.
148.
149.
150.
151.
152.
153.
154.
155.
156.
157.
158.
159.
160.
161.
162.
163.
164.
165.
166.
167.
168.
169.
170.
171.
172.
173.
174.
175.
176.
177.
178.
179.
180.
181.
182.
183.
184.
185.
186.
187.
188.
189.
190.
191.
192.
193.
194.
195.
196.
197.
198.
199.
200.
201.
202.
203.
204.
205.
206.
207.
208.
209.
210.
211.
212.
213.
214.
215.
216.
217.
218.
219.
220.
221.
222.
223.
224.
225.
226.
227.
228.
229.
230.
231.
232.
233.
234.
235.
236.
237.
238.
239.
240.
241.
242.
243.
244.
245.
246.
247.
248.
249.
250.
251.
252.
253.
254.
255.
256.
257.
258.
259.
260.
261.
262.
263.
264.
265.
266.
267.
268.
269.
270.
271.
272.
273.
274.
275.
276.
277.
278.
279.
280.
281.
282.
283.
284.
285.
286.
287.
288.
289.
290.
291.
292.
293.
294.
295.
296.
297.
298.
299.
300.
301.
302.
303.
304.
305.
306.
307.
308.
309.
310.
311.
312.
313.
314.
315.
316.
317.
318.
319.
320.
'http://support.microsoft.com/kb/218965/ru
'http://msdn.microsoft.com/en-us/library/windows/desktop/aa446629(v=vs.85).aspx

Public Function GetSecurityOwner(ByVal pszObjName As String, _
 ByVal ObjectType As SE_OBJECT_TYPE, _
 ByRef AcctName As String, ByRef DomainName As String) As Long
  'ф-ция возвращает владельца объекта
  
  'AcctName - account name, DomainName - domain name
  Dim dwRes As Long
  Dim pSidOwner As Long 'security identifier
  Dim pSD As Long
  Dim bRtnBool As Long
  Dim dwAcctName As Long 'size of account name buffer
  Dim dwDomainName As Long 'size of domain name buffer
  Dim eUse As Integer 'SID type
 
  If (pszObjName = "") Then
    GetSecurityOwner = ERROR_INVALID_PARAMETER
    'Debug.Print "ERROR_INVALID_PARAMETER"
    Exit Function
  End If
  
  'Get a pointer to the owner SID of the file
  dwRes = GetNamedSecurityInfo(pszObjName, ObjectType, _
   OWNER_SECURITY_INFORMATION, _
   pSidOwner, 0&, 0&, 0&, pSD)
  If dwRes <> ERROR_SUCCESS Then
    'Debug.Print "GetNamedSecurityInfo Error " & CStr(dwRes)
    GoTo Cleanup
  End If
  
  'First call to LookupAccountSid to get the buffer sizes.
  bRtnBool = LookupAccountSid(vbNullString, pSidOwner, AcctName, dwAcctName, _
   DomainName, dwDomainName, eUse)
  If (bRtnBool = 0) And (Err.LastDllError <> ERROR_INSUFFICIENT_BUFFER) Then
    'Debug.Print "LookupAccountSid (1) Error " & Err.LastDllError
    dwRes = Err.LastDllError
    GoTo Cleanup
  End If
  
  'Allocate the required space in the AcctName and DomainName string
  'variables. Allocate 1 byte less to avoid the appended NULL character.
  AcctName = Space(dwAcctName - 1)
  DomainName = Space(dwDomainName - 1)
  
  'Second call to LookupAccountSid to get the account name.
  bRtnBool = LookupAccountSid(vbNullString, pSidOwner, AcctName, dwAcctName, _
   DomainName, dwDomainName, eUse)
  If bRtnBool = 0 Then
    'Debug.Print "LookupAccountSid (2) Error " & Err.LastDllError
    dwRes = Err.LastDllError
    GoTo Cleanup
  End If

Cleanup:
  If pSD <> 0 Then LocalFree pSD
  
  GetSecurityOwner = dwRes
  
End Function

'Enabling and Disabling Privileges in C++
'http://msdn.microsoft.com/en-us/library/windows/desktop/aa446619(v=vs.85).aspx
Public Function SetPrivilege( _
 ByVal hToken As Long, _
 ByVal lpszPrivilege As String, _
 ByVal bEnablePrivilege As Boolean) As Long
  ' hToken - access token handle
  ' lpszPrivilege - name of privilege to enable/disable
  ' bEnablePrivilege - to enable or disable privilege
  
  Dim bRtnBool As Long
  Dim tP As TOKEN_PRIVILEGES
  Dim New_tp As TOKEN_PRIVILEGES
  Dim mLUID As LUID
  bRtnBool = LookupPrivilegeValue("", lpszPrivilege, mLUID)
  If bRtnBool = 0 Then
    'Debug.Print "LookupPrivilegeValue Error " & Err.LastDllError
    SetPrivilege = Err.LastDllError
    Exit Function
  End If
  
  tP.PrivilegeCount = 1
  tP.Privileges(0).pLuid = mLUID
  If bEnablePrivilege Then
    tP.Privileges(0).Attributes = SE_PRIVILEGE_ENABLED
  Else
    tP.Privileges(0).Attributes = 0
  End If
  bRtnBool = AdjustTokenPrivileges(hToken, False, tP, 4 + (12 * tP.PrivilegeCount), _
   New_tp, 4 + (12 * New_tp.PrivilegeCount))
  If bRtnBool = 0 Then
    'Debug.Print "AdjustTokenPrivileges Error " & Err.LastDllError
    SetPrivilege = Err.LastDllError
    Exit Function
  End If
  
  If Err.LastDllError = ERROR_NOT_ALL_ASSIGNED Then
    'Debug.Print "AdjustTokenPrivileges Error " & Err.LastDllError
    SetPrivilege = Err.LastDllError
    Exit Function
  End If
  
  'при успехе эта ф-ция вернет 0
End Function

'Taking Object Ownership in C++
'http://msdn.microsoft.com/en-us/library/windows/desktop/aa379620(v=vs.85).aspx
Public Function SetSecurityOwnerAdmins(ByVal pszObjName As String, _
 ByVal ObjectType As SE_OBJECT_TYPE) As Long
  'назначает группу "Administrators" владельцем объекта
  
  'AcctName - account name, DomainName - domain name
  Dim dwRes As Long
  Dim hToken As Long
  Dim pSIDAdmin As Long
  Dim bRtnBool As Long
 
  If (pszObjName = "") Then
    SetSecurityOwnerAdmins = ERROR_INVALID_PARAMETER
    'Debug.Print "ERROR_INVALID_PARAMETER"
    Exit Function
  End If
  
  'Create a SID for the BUILTIN\Administrators group.
  Dim siaNtAuthority As SID_IDENTIFIER_AUTHORITY
  
  siaNtAuthority.Value(5) = SECURITY_NT_AUTHORITY
  bRtnBool = AllocateAndInitializeSid(siaNtAuthority, 2, _
   SECURITY_BUILTIN_DOMAIN_RID, DOMAIN_ALIAS_RID_ADMINS, _
   0, 0, 0, 0, 0, 0, pSIDAdmin)
  If bRtnBool = 0 Then
    'Debug.Print "AllocateAndInitializeSid Error " & Err.LastDllError
    dwRes = Err.LastDllError
    GoTo Cleanup
  End If
  
  'If the preceding call failed because access was denied,
  'enable the SE_TAKE_OWNERSHIP_NAME privilege, create a SID for
  'the Administrators group, take ownership of the object, and
  'disable the privilege. Then try again to set the object's DACL.

  ' Open a handle to the access token for the calling process.
  bRtnBool = OpenProcessToken(GetCurrentProcess(), _
                          TOKEN_ADJUST_PRIVILEGES Or TOKEN_QUERY, _
                          hToken)
  If bRtnBool = 0 Then
    'Debug.Print "OpenProcessToken Error " & Err.LastDllError
    dwRes = Err.LastDllError
    GoTo Cleanup
  End If

  'Enable the SE_TAKE_OWNERSHIP_NAME privilege.
  dwRes = SetPrivilege(hToken, SE_TAKE_OWNERSHIP_NAME, True)
  If dwRes <> 0 Then
    'Debug.Print "SetPrivilege (1) Error " & dwRes
    GoTo Cleanup
  End If
  
  'Set the owner in the object's security descriptor.
  dwRes = SetNamedSecurityInfo(pszObjName, ObjectType, _
   OWNER_SECURITY_INFORMATION, _
   pSIDAdmin, 0&, 0&, 0&)
  If dwRes <> ERROR_SUCCESS Then
    'Debug.Print "SetNamedSecurityInfo Error " & CStr(dwRes)
    GoTo Cleanup
  End If
        
  'Disable the SE_TAKE_OWNERSHIP_NAME privilege.
  dwRes = SetPrivilege(hToken, SE_TAKE_OWNERSHIP_NAME, False)
  If dwRes <> 0 Then
    'Debug.Print "SetPrivilege (2) Error " & dwRes
    GoTo Cleanup
  End If
  
Cleanup:
  If pSIDAdmin <> 0 Then FreeSid pSIDAdmin
  If hToken <> 0 Then CloseHandle hToken

  SetSecurityOwnerAdmins = dwRes
  
End Function

'Taking Object Ownership in C++
'http://msdn.microsoft.com/en-us/library/windows/desktop/aa379620(v=vs.85).aspx
Public Function SetSecurityOwner(ByVal pszObjName As String, _
 ByVal ObjectType As SE_OBJECT_TYPE, _
 ByVal AcctName As String, Optional ByVal DomnName As String = "") As Long
  'назначает группу/аккаунт [DomnName + '\' +] AcctName владельцем объекта (по читаемому имени)
 
  'AcctName - account name, DomnName - domain name
  Dim AccountName As String 'на вход DomnName + '\' + AcctName
  
  Dim dwRes As Long
  Dim hToken As Long
  Dim p_abytSIDTarget() As Byte 'вместо pSIDTarget
  Dim dwSIDTarget As Long 'size of the Sid buffer
  Dim DomainName As String 'domain name на выходе
  Dim dwDomainName As Long 'size of domain name buffer
  Dim eUse As Integer 'SID type
  Dim bRtnBool As Long
 
  If (pszObjName = "") Then
    SetSecurityOwner = ERROR_INVALID_PARAMETER
    'Debug.Print "ERROR_INVALID_PARAMETER"
    Exit Function
  End If
  
  'Create a SID for specified account
  If Len(DomnName) > 0 Then
    AccountName = DomnName & "\" & AcctName
  Else
    AccountName = AcctName
  End If
  'Preinitialize p_abytSIDAdmin array with one element. It will be redimmed lated
  ReDim p_abytSIDTarget(1) As Byte
  'First call to LookupAccountName to get the buffer sizes.
  bRtnBool = LookupAccountName(vbNullString, AccountName, p_abytSIDTarget(0), dwSIDTarget, _
   DomainName, dwDomainName, eUse)
  If (bRtnBool = 0) And (Err.LastDllError <> ERROR_INSUFFICIENT_BUFFER) Then
    'Debug.Print "LookupAccountName (1) Error " & Err.LastDllError
    dwRes = Err.LastDllError
    GoTo Cleanup
  End If
  
  'Debug.Print "dwSIDTarget=" & dwSIDTarget & vbCrLf & "dwDomainName=" & dwDomainName
  
  'Allocate the required space in the p_abytSIDAdmin and DomainName string
  'variables. Allocate 1 byte less to avoid the appended NULL character.
  ReDim p_abytSIDTarget(dwSIDTarget) As Byte
  DomainName = Space(dwDomainName - 1)

  'Second call to LookupAccountName to get p_abytSIDAdmin.
  bRtnBool = LookupAccountName(vbNullString, AccountName, p_abytSIDTarget(0), dwSIDTarget, _
   DomainName, dwDomainName, eUse)
  If bRtnBool = 0 Then
    'Debug.Print "LookupAccountName (2) Error " & Err.LastDllError
    dwRes = Err.LastDllError
    GoTo Cleanup
  End If
  
  'Debug.Print DomainName
  
  'If the preceding call failed because access was denied,
  'enable the SE_TAKE_OWNERSHIP_NAME privilege, create a SID for
  'Target group, take ownership of the object, and
  'disable the privilege. Then try again to set the object's DACL.

  ' Open a handle to the access token for the calling process.
  bRtnBool = OpenProcessToken(GetCurrentProcess(), _
                          TOKEN_ADJUST_PRIVILEGES Or TOKEN_QUERY, _
                          hToken)
  If bRtnBool = 0 Then
    'Debug.Print "OpenProcessToken Error " & Err.LastDllError
    dwRes = Err.LastDllError
    GoTo Cleanup
  End If

  'Enable the SE_TAKE_OWNERSHIP_NAME privilege.
  dwRes = SetPrivilege(hToken, SE_TAKE_OWNERSHIP_NAME, True)
  If dwRes <> 0 Then
    'Debug.Print "SetPrivilege (1) Error " & dwRes
    GoTo Cleanup
  End If

  'Enable the SE_RESTORE_NAME privilege.
  dwRes = SetPrivilege(hToken, SE_RESTORE_NAME, True)
  If dwRes <> 0 Then
    'Debug.Print "SetPrivilege (2) Error " & dwRes
    GoTo Cleanup
  End If
  
  'Set the owner in the object's security descriptor.
  dwRes = SetNamedSecurityInfo(pszObjName, ObjectType, _
   OWNER_SECURITY_INFORMATION, _
   VarPtr(p_abytSIDTarget(0)), 0&, 0&, 0&)
  If dwRes <> ERROR_SUCCESS Then
    'Debug.Print "SetNamedSecurityInfo Error " & CStr(dwRes)
    GoTo Cleanup
  End If
        
  'Disable the SE_TAKE_OWNERSHIP_NAME privilege.
  dwRes = SetPrivilege(hToken, SE_TAKE_OWNERSHIP_NAME, False)
  If dwRes <> 0 Then
    'Debug.Print "SetPrivilege (3) Error " & dwRes
    GoTo Cleanup
  End If

  'Disable the SE_RESTORE_NAME privilege.
  dwRes = SetPrivilege(hToken, SE_RESTORE_NAME, False)
  If dwRes <> 0 Then
    'Debug.Print "SetPrivilege (4) Error " & dwRes
    GoTo Cleanup
  End If
  
Cleanup:
  If hToken <> 0 Then CloseHandle hToken

  SetSecurityOwner = dwRes
  
End Function

Public Function GetFileFolderOwner(ByVal FileFolderPath As String, _
 ByRef AcctName As String, ByRef DomainName As String) As Long
  'возвращает владельца папки или файла
  GetFileFolderOwner = GetSecurityOwner(FileFolderPath, _
   SE_FILE_OBJECT, _
   AcctName, _
   DomainName)
End Function

Public Function GetRegistryEntryOwner(ByVal RegistryPath As String, _
 ByRef AcctName As String, ByRef DomainName As String) As Long
  'возвращает владельца ветки реестра
  GetRegistryEntryOwner = GetSecurityOwner(RegistryPath, _
   SE_REGISTRY_KEY, _
   AcctName, _
   DomainName)
End Function

...
Рейтинг: 0 / 0
А как в .Net обстоят дела с правами на объекты (реестр, файл...), сменой владельца и т.п.?
    #38842408
Дмитрий77
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Изопропилnet думает, что у него есть managed c++
А скажи мне, как я подключу C++ если у меня проект VB.Net и все GUI на VB.Net и осваивать managed c++ как таковое я не хочу. Хотя API лучше на C++ кто б спорил.
И я использую Express. Лицензия - дорого, а искать крякнутые студии - в этом вопросе я на это не пойду.
...
Рейтинг: 0 / 0
А как в .Net обстоят дела с правами на объекты (реестр, файл...), сменой владельца и т.п.?
    #38842427
carrotik
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Дмитрий77,

...уж не является ли ваш проект заменой Панели управления Windows, случайно? ... не язвлю, честно интересно ...
...
Рейтинг: 0 / 0
А как в .Net обстоят дела с правами на объекты (реестр, файл...), сменой владельца и т.п.?
    #38842432
Фотография Изопропил
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Дмитрий77И я использую Express.
Community Edition почему не используешь?
Дмитрий77А скажи мне, как я подключу C++ если у меня проект VB.Net и все GUI на VB.Net
легко - один из проектов в солюшне на C++

managed с++ - тож не сахар, на мой взгляд адаптеры для API лучше нв обычном c++ а с .net кодом взаимодействовать через свой внятный p/invoke или свой COM интерфейс с внятными параметрами
IDispatch в конце концов

Если и дальше собираешься воевать с p/invoke - обрати внимание на ICustomMarshaler, с ним любые проблемы интеропа решаемы, но адаптер на С++ пишется быстрее
...
Рейтинг: 0 / 0
А как в .Net обстоят дела с правами на объекты (реестр, файл...), сменой владельца и т.п.?
    #38842496
Дмитрий77
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
carrotikДмитрий77,

...уж не является ли ваш проект заменой Панели управления Windows, случайно? ... не язвлю, честно интересно ...
Нет, не является. Но техническая часть достаточно сложна. Т.е. мне необходимо конфигурировать виртуальные порты, модемы, есть виртуальный принтер, может запускаться как служба. И как понимаешь должен работать под обычным пользователем, а какие-то вещи конфигурируются только администратором, отсюда необходимось работать с правами и т.п. о чем я здесь спрашиваю.

Изопропил,
ну в принципе написать любой API-код на VB(6/Net) для меня не является проблемой.
Ну т.е. C++ мне для этого не нужен.

Опять же, если есть нормальный .Net класс, предпочту его а не API.
...
Рейтинг: 0 / 0
А как в .Net обстоят дела с правами на объекты (реестр, файл...), сменой владельца и т.п.?
    #38842501
Фотография Изопропил
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Дмитрий77Опять же, если есть нормальный .Net класс
ну так не покрывается WinApi .net классами

время, потраченное на битву с интероп, куда полезнее можно было использовать на освоение C++
...
Рейтинг: 0 / 0
А как в .Net обстоят дела с правами на объекты (реестр, файл...), сменой владельца и т.п.?
    #38842518
Дмитрий77
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
ИзопропилДмитрий77Опять же, если есть нормальный .Net класс
ну так не покрывается WinApi .net классами

время, потраченное на битву с интероп, куда полезнее можно было использовать на освоение C++
Я же написал "если есть".
А время уже и так потрачено когда писал на VB6. Переписать на VB.Net много времени не занимает. С IntPtr/Integer вроде разобрались.
Я умею писать это на C++ но у меня проект VB, и я к VB привык.
...
Рейтинг: 0 / 0
А как в .Net обстоят дела с правами на объекты (реестр, файл...), сменой владельца и т.п.?
    #38842550
Фотография Изопропил
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Дмитрий77но у меня проект VB
замени проект на solution и комбинируй хоть с питоном
...
Рейтинг: 0 / 0
А как в .Net обстоят дела с правами на объекты (реестр, файл...), сменой владельца и т.п.?
    #38842575
Сон Веры Павловны
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Дмитрий77А про смену владельца есть где?
Для файловой системы:
FileSystemSecurity Class (System.Security.AccessControl)
FileSystemAccessRule Class (System.Security.AccessControl)
для реестра по аналогии:
RegistrySecurity Class (System.Security.AccessControl)
RegistryAccessRule Class (System.Security.AccessControl)
смена прав:
ObjectSecurity.ModifyAccessRule Method (System.Security.AccessControl)
до кучи ко всему вышеперчисленному советую прочитать вот это: Manage Access to Windows Objects with ACLs and the .NET Framework
...
Рейтинг: 0 / 0
А как в .Net обстоят дела с правами на объекты (реестр, файл...), сменой владельца и т.п.?
    #38843719
Дмитрий77
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Помогайте,

Код: vbnet
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
  Private Sub ButtonCheckModify_Click(sender As Object, e As EventArgs) Handles ButtonCheckModify.Click
    Dim acc As NTAccount = New NTAccount("Администраторы")
    Dim secId As SecurityIdentifier = acc.Translate(GetType(SecurityIdentifier))
    Dim rk As RegistryKey = Registry.ClassesRoot.OpenSubKey("AppID\{AA0B85DA-FDDF-4272-8D1D-FF9B966D75B0}", _
     RegistryKeyPermissionCheck.ReadSubTree, Security.AccessControl.RegistryRights.ReadPermissions)
    Dim mSec As New RegistrySecurity
    mSec = rk.GetAccessControl()
    'MsgBox(mSec.GetOwner(GetType(NTAccount)).ToString)
    Dim rules As AuthorizationRuleCollection = mSec.GetAccessRules(True, True, GetType(NTAccount))
    For Each Rule As RegistryAccessRule In rules
      Debug.Print(Rule.IdentityReference.Value & " " & Rule.RegistryRights.ToString)
      Мне нужно правило соответствующее "Администраторы"!!!
      Мне нужно пока понять есть ли в этом правиле флаг SetValue (KEY_SET_VALUE) ДА/НЕТ
    Next
  End Sub


Судя по выводу дебага куда надо я попал:
Код: vbnet
1.
2.
3.
4.
5.
NT AUTHORITY\СИСТЕМА ReadKey
BUILTIN\Администраторы ReadKey
BUILTIN\Пользователи ReadKey
NT SERVICE\TrustedInstaller FullControl
ЦЕНТР ПАКЕТОВ ПРИЛОЖЕНИЙ\ВСЕ ПАКЕТЫ ПРИЛОЖЕНИЙ ReadKey
...
Рейтинг: 0 / 0
А как в .Net обстоят дела с правами на объекты (реестр, файл...), сменой владельца и т.п.?
    #38843751
Дмитрий77
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
>Мне нужно пока понять есть ли в этом правиле флаг SetValue (KEY_SET_VALUE) ДА/НЕТ

Ну видимо

Код: vbnet
1.
2.
3.
    For Each Rule As RegistryAccessRule In rules
      Debug.Print(Rule.IdentityReference.Value & " " & ((Rule.RegistryRights Or RegistryRights.SetValue) = Rule.RegistryRights))
    Next


А вот как уточняется что это правило именно для "Администраторы" (не визуальным сравнением Rule.IdentityReference.Value надо думать)
...
Рейтинг: 0 / 0
А как в .Net обстоят дела с правами на объекты (реестр, файл...), сменой владельца и т.п.?
    #38843950
Дмитрий77
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Ну как-то так:

Код: vbnet
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
  Public Function RegistryEntry_QuerySetValueAdmins(ByVal Key As RegistryKey, ByVal SubKey As String, _
   ByRef AllowSetValue As Boolean) As Boolean
    'ф-ция выясняет, имеют ли администраторы право SetValue (KEY_SET_VALUE) для ветки реестра
    'ф-ция возвращает true при успехе определения искомого
    'ф-ция возвращает результат в AllowSetValue (при успехе)
    Dim adminSid As SecurityIdentifier = New SecurityIdentifier(WellKnownSidType.BuiltinAdministratorsSid, Nothing)
    Dim rk As RegistryKey = Key.OpenSubKey _
     (SubKey, RegistryKeyPermissionCheck.ReadSubTree, Security.AccessControl.RegistryRights.ReadPermissions)
    For Each rule As RegistryAccessRule In _
     rk.GetAccessControl().GetAccessRules(True, True, GetType(SecurityIdentifier))
      If rule.IdentityReference.Equals(adminSid) Then
        AllowSetValue = ((rule.RegistryRights Or RegistryRights.SetValue) = rule.RegistryRights)
        Return True
      End If
    Next
    Return False
  End Function

  Private Sub ButtonCheckModify_Click(sender As Object, e As EventArgs) Handles ButtonCheckModify.Click
    Dim bSuccess As Boolean
    MsgBox(RegistryEntry_QuerySetValueAdmins _
     (Registry.ClassesRoot, "AppID\{AA0B85DA-FDDF-4272-8D1D-FF9B966D75B0}", bSuccess))
    MsgBox("Allow SetValue=" & bSuccess)
  End Sub



Ну вот не пойму.
Код вроде короче, и обертка вроде есть.
Но она чуть ли не запутанней чем API, или я не привык просто.
...
Рейтинг: 0 / 0
А как в .Net обстоят дела с правами на объекты (реестр, файл...), сменой владельца и т.п.?
    #38844061
Дмитрий77
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Владельца получить могу:
Код: vbnet
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
  Public Function GetRegistryEntryOwner(ByVal Key As RegistryKey, ByVal SubKey As String, _
   ByRef OwnerName As String) As Boolean
    'возвращает владельца ветки реестра
    Try
      Dim rk As RegistryKey = Key.OpenSubKey _
       (SubKey, RegistryKeyPermissionCheck.ReadSubTree, Security.AccessControl.RegistryRights.ReadPermissions)
      OwnerName = rk.GetAccessControl().GetOwner(GetType(NTAccount)).Value
      Return True
    Catch
      Debug.Print(Err.Description)
      Return False
    End Try
  End Function



А вот заменить не получается (запускаю под админим естественно):
Код: vbnet
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
  Public Function SetRegistryEntryOwner(ByVal Key As RegistryKey, ByVal SubKey As String, _
   ByVal OwnerName As String) As Boolean
    'назначает владельца ветки реестра
    Try
      Dim rk As RegistryKey = Key.OpenSubKey _
       (SubKey, RegistryKeyPermissionCheck.ReadSubTree, Security.AccessControl.RegistryRights.TakeOwnership)
      Dim ac As RegistrySecurity = rk.GetAccessControl()
      ac.SetOwner(New NTAccount(OwnerName))
      rk.SetAccessControl(ac)
      Return True
    Catch
      Debug.Print(Err.Description)
      Return False
    End Try
  End Function


Спотыкается на строчке

Код: vbnet
1.
2.
3.
      Dim rk As RegistryKey = Key.OpenSubKey _
       (SubKey, RegistryKeyPermissionCheck.ReadSubTree, Security.AccessControl.RegistryRights.TakeOwnership)
Запрошенный доступ к реестру запрещен.



Через API я это делал:
17049769

Вот как это в .Net сделать, про какие-то токены речь идет:
Код: vbnet
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
29.
30.
  'If the preceding call failed because access was denied,
  'enable the SE_TAKE_OWNERSHIP_NAME privilege, create a SID for
  'the Administrators group, take ownership of the object, and
  'disable the privilege. Then try again to set the object's DACL.

  ' Open a handle to the access token for the calling process.
  bRtnBool = OpenProcessToken(GetCurrentProcess(), _
                          TOKEN_ADJUST_PRIVILEGES Or TOKEN_QUERY, _
                          hToken)
  If bRtnBool = 0 Then
    'Debug.Print "OpenProcessToken Error " & Err.LastDllError
    dwRes = Err.LastDllError
    GoTo Cleanup
  End If

  'Enable the SE_TAKE_OWNERSHIP_NAME privilege.
  dwRes = SetPrivilege(hToken, SE_TAKE_OWNERSHIP_NAME, True)
  If dwRes <> 0 Then
    'Debug.Print "SetPrivilege (1) Error " & dwRes
    GoTo Cleanup
  End If
  
  'Set the owner in the object's security descriptor.
  dwRes = SetNamedSecurityInfo(pszObjName, ObjectType, _
   OWNER_SECURITY_INFORMATION, _
   pSIDAdmin, 0&, 0&, 0&)
  If dwRes <> ERROR_SUCCESS Then
    'Debug.Print "SetNamedSecurityInfo Error " & CStr(dwRes)
    GoTo Cleanup
  End If
...
Рейтинг: 0 / 0
А как в .Net обстоят дела с правами на объекты (реестр, файл...), сменой владельца и т.п.?
    #38844164
Дмитрий77
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Добавил SE_TAKE_OWNERSHIP_NAME privilege для текущего процесса (через API, по идее должно было сработать).
В реестр пустил,
а rk.SetAccessControl(ac) делать все одно не хочет:
Необработанное исключение типа "System.UnauthorizedAccessException" в mscorlib.dll
Дополнительные сведения: Не удалось выполнить запись в раздел реестра.

У администратора нет прав на запись согласен.
Но сменить владельца администратор может.
Но .Net код этого делать не хочет. Или я не тот .Net код пишу и не так.
Реестр открыт с Security.AccessControl.RegistryRights.TakeOwnership

Код: vbnet
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
29.
30.
31.
32.
33.
34.
35.
36.
37.
38.
39.
40.
41.
42.
43.
44.
45.
46.
47.
48.
49.
50.
51.
52.
53.
54.
55.
56.
57.
58.
59.
60.
61.
62.
63.
64.
65.
66.
67.
68.
69.
70.
71.
72.
73.
74.
75.
76.
77.
78.
79.
80.
81.
82.
83.
84.
85.
86.
87.
88.
89.
90.
91.
92.
93.
94.
95.
 Public Function SetRegistryEntryOwner(ByVal Key As RegistryKey, ByVal SubKey As String, _
   ByVal OwnerName As String) As Boolean
    'назначает владельца ветки реестра
    Dim hToken As IntPtr
    Dim dwRes As Integer

    'If the preceding call failed because access was denied,
    'enable the SE_TAKE_OWNERSHIP_NAME privilege, create a SID for
    'the Administrators group, take ownership of the object, and
    'disable the privilege. Then try again to set the object's DACL.

    ' Open a handle to the access token for the calling process.
    If OpenProcessToken(Process.GetCurrentProcess().Handle, _
                            TOKEN_ADJUST_PRIVILEGES Or TOKEN_QUERY, _
                            hToken) = False Then
      Debug.Print("OpenProcessToken Error " & Err.LastDllError)
      Return False
    End If

    'Enable the SE_TAKE_OWNERSHIP_NAME privilege.
    dwRes = SetPrivilege(hToken, SE_TAKE_OWNERSHIP_NAME, True)
    If dwRes <> 0 Then
      'Debug.Print "SetPrivilege (1) Error " & dwRes
      SetRegistryEntryOwner = False
      GoTo Cleanup
    End If

    'Try
    Dim rk As RegistryKey = Key.OpenSubKey _
     (SubKey, RegistryKeyPermissionCheck.Default, Security.AccessControl.RegistryRights.TakeOwnership)
    Dim ac As RegistrySecurity = rk.GetAccessControl()
    ac.SetOwner(New NTAccount(OwnerName))
    rk.SetAccessControl(ac) 'Не удалось выполнить запись в раздел реестра. 
    SetRegistryEntryOwner = True
    'Catch
    Debug.Print(Err.Description)
    SetRegistryEntryOwner = False
    'End Try

    'Disable the SE_TAKE_OWNERSHIP_NAME privilege.
    dwRes = SetPrivilege(hToken, SE_TAKE_OWNERSHIP_NAME, False)
    If dwRes <> 0 Then
      'Debug.Print "SetPrivilege (2) Error " & dwRes
      GoTo Cleanup
    End If

Cleanup:
    If hToken <> IntPtr.Zero Then CloseHandle(hToken)

  End Function

  'Enabling and Disabling Privileges in C++
  'http://msdn.microsoft.com/en-us/library/windows/desktop/aa446619(v=vs.85).aspx
  Public Function SetPrivilege( _
   ByVal hToken As IntPtr, _
   ByVal lpszPrivilege As String, _
   ByVal bEnablePrivilege As Boolean) As Integer
    ' hToken - access token handle
    ' lpszPrivilege - name of privilege to enable/disable
    ' bEnablePrivilege - to enable or disable privilege

    Dim tP As New TOKEN_PRIVILEGES
    Dim New_tp As New TOKEN_PRIVILEGES
    Dim mLUID As New LUID
    If LookupPrivilegeValue("", lpszPrivilege, mLUID) = False Then
      Debug.Print("LookupPrivilegeValue Error " & Err.LastDllError)
      SetPrivilege = Err.LastDllError
      Exit Function
    End If

    tP.PrivilegeCount = 1
    tP.pLuid = mLUID
    If bEnablePrivilege Then
      tP.Attributes = SE_PRIVILEGE_ENABLED
    Else
      tP.Attributes = 0
    End If
    If AdjustTokenPrivileges(hToken, False, tP, 4 + (12 * tP.PrivilegeCount), _
     New_tp, 4 + (12 * New_tp.PrivilegeCount)) = False Then
      Debug.Print("AdjustTokenPrivileges Error " & Err.LastDllError)
      SetPrivilege = Err.LastDllError
      Exit Function
    End If

    If Err.LastDllError = ERROR_NOT_ALL_ASSIGNED Then
      Debug.Print("AdjustTokenPrivileges Error " & Err.LastDllError)
      SetPrivilege = Err.LastDllError
      Exit Function
    End If

    'при успехе эта ф-ция вернет 0
    Return 0
  End Function

End Module
...
Рейтинг: 0 / 0
А как в .Net обстоят дела с правами на объекты (реестр, файл...), сменой владельца и т.п.?
    #38844206
Фотография hVostt
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Дмитрий77Помогайте,

Будь добр, заведи у себя на рабочем столе текстовый файлик, и общайся там сам с собой. Не иби мозг.
...
Рейтинг: 0 / 0
А как в .Net обстоят дела с правами на объекты (реестр, файл...), сменой владельца и т.п.?
    #38844251
Дмитрий77
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
hVostt,

Послушай, Уважаемый, или как тебя там.
Ты мне совет дал.
hVosttЧитай от корки до корки: http://msdn.microsoft.com/ru-ru/library/ms229742(v=vs.110).aspx
Я прочитал и попытался воспользоваться.
И в 2-х постах выше я подробно описал что конкретно у меня не получается.
При этом я в отличии от тебя не позволяю себе выражений типа "твоя технология - г*вно, а ты ...", а пытаюсь разобраться.
Знаешь - помоги разобраться. Не знаешь или не хочешь подсказать, не пиши ничего.
Меня если честно тоже за..бали общие рассуждения не относящиеся к темам топиков, при том что стоящих ответов по существу вопросов - 1%.

И будь добр , следи за своими высказываниями.
...
Рейтинг: 0 / 0
А как в .Net обстоят дела с правами на объекты (реестр, файл...), сменой владельца и т.п.?
    #38844259
Фотография hVostt
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Дмитрий77Меня если честно тоже за..бали общие рассуждения не относящиеся к темам топиков, при том что стоящих ответов по существу вопросов - 1%.

Ты перепутал личный блог с форумом. Задаёшь конкретный вопрос, получаешь конкретный ответ.
...
Рейтинг: 0 / 0
А как в .Net обстоят дела с правами на объекты (реестр, файл...), сменой владельца и т.п.?
    #38844268
Дмитрий77
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
hVostt,

Нет, не перепутал. Я всегда задаю конкретные вопросы.

==
Крайний вопрос был следующий, готов переформулировать.

Есть ветка реестра. У нее Owner=Trusted Installer. У администратора права только на чтение.
Мне надо поменять Owner на Administrators.
Вот мой код (запущен из под администратора):
Код: vbnet
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
  Public Function SetRegistryEntryOwner(ByVal Key As RegistryKey, ByVal SubKey As String, _
   ByVal OwnerName As String) As Boolean
    'назначает владельца ветки реестра
    Try
      Dim rk As RegistryKey = Key.OpenSubKey _
       (SubKey, RegistryKeyPermissionCheck.ReadSubTree, Security.AccessControl.RegistryRights.TakeOwnership)
      Dim ac As RegistrySecurity = rk.GetAccessControl()
      ac.SetOwner(New NTAccount(OwnerName))
      rk.SetAccessControl(ac)
      Return True
    Catch
      Debug.Print(Err.Description)
      Return False
    End Try
  End Function


На выделенной строчке код спотыкается.
Ошибка: Запрошенный доступ к реестру запрещен.

Вопрос: Что не так в моем коде? Как сделать чтоб заработало? (как администратор я имею право поменять владельца объекта)
...
Рейтинг: 0 / 0
А как в .Net обстоят дела с правами на объекты (реестр, файл...), сменой владельца и т.п.?
    #38844271
Фотография МСУ
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Дмитрий77 Вопрос: Что не так в моем коде? Как сделать чтоб заработало? (как администратор я имею право поменять владельца объекта)
Так может тебе нужно запустить твой код трастово через Run As Admin?
...
Рейтинг: 0 / 0
А как в .Net обстоят дела с правами на объекты (реестр, файл...), сменой владельца и т.п.?
    #38844279
Дмитрий77
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
МСУ,

Так я же уточнил: >(запущен из под администратора):
И подробно описал, что я сделал дополнительно:
>Добавил SE_TAKE_OWNERSHIP_NAME privilege для текущего процесса (через API, по идее должно было сработать).
>В реестр пустил,
>а rk.SetAccessControl(ac) делать все одно не хочет:
>: Не удалось выполнить запись в раздел реестра.

Вот так работает:

Код: vbnet
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
29.
30.
31.
32.
33.
34.
35.
36.
37.
38.
39.
40.
41.
42.
43.
44.
45.
46.
47.
48.
49.
50.
51.
52.
53.
54.
55.
56.
57.
58.
59.
60.
61.
62.
63.
64.
65.
66.
67.
68.
69.
70.
71.
72.
73.
74.
75.
76.
77.
78.
79.
80.
81.
82.
83.
84.
85.
86.
87.
88.
89.
90.
91.
92.
93.
94.
95.
96.
97.
98.
99.
100.
101.
102.
103.
104.
105.
106.
107.
108.
109.
110.
111.
112.
113.
114.
115.
116.
117.
118.
119.
  Public Function SetRegistryEntryOwner(ByVal Key As RegistryKey, ByVal SubKey As String, _
   ByVal OwnerName As String) As Boolean
    'назначает владельца ветки реестра
    Dim hToken As IntPtr
    Dim dwRes As Integer
    Dim pSIDAdmin As IntPtr

    'Create a SID for the BUILTIN\Administrators group.
    Dim siaNtAuthority As SID_IDENTIFIER_AUTHORITY

    siaNtAuthority.Value = {0, 0, 0, 0, 0, SECURITY_NT_AUTHORITY}
    If AllocateAndInitializeSid(siaNtAuthority, 2, _
     SECURITY_BUILTIN_DOMAIN_RID, DOMAIN_ALIAS_RID_ADMINS, _
     0, 0, 0, 0, 0, 0, pSIDAdmin) = False Then
      'Debug.Print "AllocateAndInitializeSid Error " & Err.LastDllError
      Return False
    End If

    'If the preceding call failed because access was denied,
    'enable the SE_TAKE_OWNERSHIP_NAME privilege, create a SID for
    'the Administrators group, take ownership of the object, and
    'disable the privilege. Then try again to set the object's DACL.

    ' Open a handle to the access token for the calling process.
    If OpenProcessToken(Process.GetCurrentProcess().Handle, _
                            TOKEN_ADJUST_PRIVILEGES Or TOKEN_QUERY, _
                            hToken) = False Then
      Debug.Print("OpenProcessToken Error " & Err.LastDllError)
      Return False
    End If

    'Enable the SE_TAKE_OWNERSHIP_NAME privilege.
    dwRes = SetPrivilege(hToken, SE_TAKE_OWNERSHIP_NAME, True)
    If dwRes <> 0 Then
      'Debug.Print "SetPrivilege (1) Error " & dwRes
      SetRegistryEntryOwner = False
      GoTo Cleanup
    End If

    'Set the owner in the object's security descriptor.
    dwRes = SetNamedSecurityInfo("CLASSES_ROOT\" & SubKey, SE_OBJECT_TYPE.SE_REGISTRY_KEY, _
     OWNER_SECURITY_INFORMATION, _
     pSIDAdmin, IntPtr.Zero, IntPtr.Zero, IntPtr.Zero)
    If dwRes <> ERROR_SUCCESS Then
      'Debug.Print "SetNamedSecurityInfo Error " & CStr(dwRes)
      SetRegistryEntryOwner = False
      GoTo Cleanup
    Else
      SetRegistryEntryOwner = True
    End If


    'Try
    '  Dim rk As RegistryKey = Key.OpenSubKey _
    '   (SubKey, RegistryKeyPermissionCheck.Default, Security.AccessControl.RegistryRights.TakeOwnership)
    '  Dim ac As RegistrySecurity = rk.GetAccessControl()  'New RegistrySecurity 
    '  ac.SetOwner(New NTAccount(OwnerName)) 'BUILTIN\Администраторы
    '  'ac.SetAccessRuleProtection(False,false)
    '  rk.SetAccessControl(ac)
    '  SetRegistryEntryOwner = True
    'Catch
    '  Debug.Print(Err.Description)
    '  SetRegistryEntryOwner = False
    'End Try

    'Disable the SE_TAKE_OWNERSHIP_NAME privilege.
    dwRes = SetPrivilege(hToken, SE_TAKE_OWNERSHIP_NAME, False)
    If dwRes <> 0 Then
      'Debug.Print "SetPrivilege (2) Error " & dwRes
      GoTo Cleanup
    End If

Cleanup:
    If hToken <> IntPtr.Zero Then CloseHandle(hToken)

  End Function

  'Enabling and Disabling Privileges in C++
  'http://msdn.microsoft.com/en-us/library/windows/desktop/aa446619(v=vs.85).aspx
  Public Function SetPrivilege( _
   ByVal hToken As IntPtr, _
   ByVal lpszPrivilege As String, _
   ByVal bEnablePrivilege As Boolean) As Integer
    ' hToken - access token handle
    ' lpszPrivilege - name of privilege to enable/disable
    ' bEnablePrivilege - to enable or disable privilege

    Dim tP As New TOKEN_PRIVILEGES
    Dim New_tp As New TOKEN_PRIVILEGES
    Dim mLUID As New LUID
    If LookupPrivilegeValue("", lpszPrivilege, mLUID) = False Then
      Debug.Print("LookupPrivilegeValue Error " & Err.LastDllError)
      SetPrivilege = Err.LastDllError
      Exit Function
    End If

    tP.PrivilegeCount = 1
    tP.pLuid = mLUID
    If bEnablePrivilege Then
      tP.Attributes = SE_PRIVILEGE_ENABLED
    Else
      tP.Attributes = 0
    End If
    If AdjustTokenPrivileges(hToken, False, tP, 4 + (12 * tP.PrivilegeCount), _
     New_tp, 4 + (12 * New_tp.PrivilegeCount)) = False Then
      Debug.Print("AdjustTokenPrivileges Error " & Err.LastDllError)
      SetPrivilege = Err.LastDllError
      Exit Function
    End If

    If Err.LastDllError = ERROR_NOT_ALL_ASSIGNED Then
      Debug.Print("AdjustTokenPrivileges Error " & Err.LastDllError)
      SetPrivilege = Err.LastDllError
      Exit Function
    End If

    'при успехе эта ф-ция вернет 0
    Return 0
  End Function



С SetNamedSecurityInfo вместо упомянутого .Net -кода по которому вопрос.
...
Рейтинг: 0 / 0
25 сообщений из 60, страница 1 из 3
Форумы / WinForms, .Net Framework [игнор отключен] [закрыт для гостей] / А как в .Net обстоят дела с правами на объекты (реестр, файл...), сменой владельца и т.п.?
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]