powered by simpleCommunicator - 2.0.53     © 2025 Programmizd 02
Форумы / Visual Basic [игнор отключен] [закрыт для гостей] / RegOpenKeyEx access denied
5 сообщений из 5, страница 1 из 1
RegOpenKeyEx access denied
    #37620355
takishoma
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Сразу оговорюсь - все происходит в Win7, в XP ошибка не повторяется.

Есть функция , которая в зависимости от параметра (от 1 до 4) возвращает значение из реестра.
Функция вызывается в цикле от 1 до 4.
Код: vbnet
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
Function cblExtendedRestGroupList(group As Integer) As String
  Select Case group
      Case 1
        cblExtendedRestGroupList = RegGetValue(HKEY_LOCAL_MACHINE, "SOFTWARE\OFReports\ExtendedRest", "GroupList01")
      Case 2
        cblExtendedRestGroupList = RegGetValue(HKEY_LOCAL_MACHINE, "SOFTWARE\OFReports\ExtendedRest", "GroupList02")
      Case 3
        cblExtendedRestGroupList = RegGetValue(HKEY_LOCAL_MACHINE, "SOFTWARE\OFReports\ExtendedRest", "GroupList03")
      Case 4
        cblExtendedRestGroupList = RegGetValue(HKEY_LOCAL_MACHINE, "SOFTWARE\OFReports\ExtendedRest", "GroupList04")
  End Select
End Function



далее сам метод RegGetValue


Код: 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.
Function RegGetValue$(MainKey&, SubKey$, value$)
    ' MainKey must be one of the Publicly declared HKEY constants.
    Dim sKeyType& 'to return the key type. This function expects REG_SZ or REG_DWORD
    Dim Ret& 'returned by registry functions, should be 0&
    Dim lpHKey& 'return handle to opened key
    Dim lpcbData& 'length of data in returned string
    Dim ReturnedString$ 'returned string value
    Dim fTempDbl!
    Dim ReturnedLong&
    If MainKey >= &H80000000 And MainKey <= &H80000006 Then
        ' Open key
        Ret = RegOpenKeyExA(MainKey, SubKey, 0&, KEY_READ, lpHKey)
        If Ret <> ERROR_SUCCESS Then
            RegGetValue = ""
            Exit Function 'No key open, so leave
        End If
        
        ' Set up buffer for data to be returned in.
        ' Adjust next value for larger buffers.
        lpcbData = MAX_BUFFER_SIZE
        ReturnedString = Space$(lpcbData)
        
        ' Read key
        Ret& = RegQueryValueExA(lpHKey, value, ByVal 0&, sKeyType, ByVal ReturnedString, lpcbData)
        If Ret <> ERROR_SUCCESS Then
            RegGetValue = "" 'Value probably doesn't exist
        Else
            If sKeyType = REG_DWORD Then
              Ret = RegQueryValueExA(lpHKey, value, ByVal 0&, sKeyType, ReturnedLong, 4)
              If Ret = ERROR_SUCCESS Then
                RegGetValue = CStr(ReturnedLong)
              End If
            Else
              RegGetValue = Left$(ReturnedString, lpcbData - 1)
            End If
        End If
        ' Always close opened keys.
        Ret = RegCloseKey(lpHKey)
    End If
End Function



Код: 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.
Option Explicit
Type SECURITY_ATTRIBUTES
        nLength As Long
        lpSecurityDescriptor As Long
        bInheritHandle As Long
End Type
Declare Function RegCloseKey& Lib "advapi32.dll" (ByVal hKey&)
Declare Function RegOpenKeyExA& Lib "advapi32.dll" (ByVal hKey&, ByVal lpszSubKey$, dwOptions&, ByVal samDesired&, lpHKey&)
Declare Function RegQueryValueExA& Lib "advapi32.dll" (ByVal hKey&, ByVal lpszValueName$, ByVal lpdwRes&, lpdwType&, lpDataBuff As Any, nSize&)
Declare Function RegCreateKeyEx& Lib "advapi32.dll" Alias "RegCreateKeyExA" (ByVal hKey&, ByVal lpSubKey$, ByVal Reserved&, ByVal lpClass$, ByVal dwOptions&, ByVal samDesired&, lpSecurityAttributes As SECURITY_ATTRIBUTES, phkResult&, lpdwDisposition&)
Declare Function RegSetValueEx& Lib "advapi32.dll" Alias "RegSetValueExA" (ByVal hKey&, ByVal lpszValueName$, ByVal dwRes&, ByVal dwType&, lpDataBuff As Any, ByVal nSize&)
Declare Function RegOpenKey Lib "advapi32.dll" Alias "RegOpenKeyA" (ByVal hKey As Long, ByVal lpSubKey As String, phkResult As Long) As Long
Private Declare Function RegCreateKey Lib "advapi32.dll" Alias "RegCreateKeyA" (ByVal hKey As Long, ByVal lpSubKey As String, phkResult As Long) As Long
Private Declare Function RegOpenKeyEx Lib "advapi32" Alias "RegOpenKeyExA" _
(ByVal hKey As Long, ByVal lpSubKey As String, ByVal ulOptions As Long, _
ByVal samDesired As Long, ByRef phkResult As Long) As Long
Declare Function RegSetValueExString Lib "advapi32.dll" Alias _
   "RegSetValueExA" (ByVal hKey As Long, ByVal lpValueName As String, _
   ByVal Reserved As Long, ByVal dwType As Long, ByVal lpValue As _
   String, ByVal cbData As Long) As Long
Const HKEY_CLASSES_ROOT = &H80000000
Const HKEY_CURRENT_USER = &H80000001
Public Const HKEY_LOCAL_MACHINE = &H80000002
Const HKEY_USERS = &H80000003
Public Const REG_SZ = 1 ' Unicode nul terminated string
Public Const KEY_ALL_ACCESS = &H3F
Const ERROR_SUCCESS = 0&
Const MAX_BUFFER_SIZE = 35000
Const REG_DWORD = 4& ' 32-bit number
Const KEY_QUERY_VALUE = &H1&
Public Const KEY_SET_VALUE = &H2&
Const KEY_CREATE_SUB_KEY = &H4&
Const KEY_ENUMERATE_SUB_KEYS = &H8&
Const KEY_NOTIFY = &H10&
Const KEY_CREATE_LINK = &H20&
Const READ_CONTROL = &H20000
Const WRITE_DAC = &H40000
Const WRITE_OWNER = &H80000
Const SYNCHRONIZE = &H100000
Const STANDARD_RIGHTS_REQUIRED = &HF0000
Const STANDARD_RIGHTS_READ = READ_CONTROL
Const STANDARD_RIGHTS_WRITE = READ_CONTROL
Const STANDARD_RIGHTS_EXECUTE = READ_CONTROL
Const KEY_READ = STANDARD_RIGHTS_READ Or KEY_QUERY_VALUE Or KEY_ENUMERATE_SUB_KEYS Or KEY_NOTIFY
Const Key_Write = STANDARD_RIGHTS_WRITE Or KEY_SET_VALUE Or KEY_CREATE_SUB_KEY
Const KEY_EXECUTE = KEY_READ




Первые три раза функция отрабатывает успешно, а на четвертый RegOpenKeyExA возвращает 5 (видимо access denied).
Как так? Это ведь одна и та же ветка реестра.

При этом, если закомментировать все предыдущие вызовы и оставить только четвертый - падает сразу.

Заранее спасибо за помощь.
...
Рейтинг: 0 / 0
RegOpenKeyEx access denied
    #37622759
takishoma
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Как оказалось, код ошибки 5 это ERROR_CANTWRITE. Тем не менее, вопрос остается открытым...
...
Рейтинг: 0 / 0
RegOpenKeyEx access denied
    #37622813
Фотография Antonariy
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
А зачем эта лестница? Можно же в одну строчку.
Код: vbnet
1.
cblExtendedRestGroupList = RegGetValue(HKEY_LOCAL_MACHINE, "SOFTWARE\OFReports\ExtendedRest", "GroupList0" & group)
...
Рейтинг: 0 / 0
RegOpenKeyEx access denied
    #37623289
takishoma
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
можно, но, к сожалению, проблему это не решает. RegOpenKeyExA вообще не использует параметр value$, при этом каким-то образом на него регаирует
...
Рейтинг: 0 / 0
RegOpenKeyEx access denied
    #37623387
takishoma
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Проблема решена заменой
Declare Function RegOpenKeyExA& Lib "advapi32.dll" (ByVal hKey&, ByVal lpszSubKey$, dwOptions&, ByVal samDesired&, lpHKey&)
на
Declare Function RegOpenKeyExA& Lib "advapi32.dll" (ByVal hKey&, ByVal lpszSubKey$, ByVal dwOptions&, ByVal samDesired&, lpHKey&)

Надеюсь, кому-то это поможет.
...
Рейтинг: 0 / 0
5 сообщений из 5, страница 1 из 1
Форумы / Visual Basic [игнор отключен] [закрыт для гостей] / RegOpenKeyEx access denied
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


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