0 / 0 / 0
Регистрация: 13.03.2017
Сообщений: 2
1

Вывод на экран информации о жестком диске

13.03.2017, 17:35. Показов 3753. Ответов 3
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Доброго времени суток, товарищи. Заранее прошу прощения если не в том разделе пишу, но вопрос такой:
нужно написать программы которая выведет информацию об установленном в системе жестком диске (под Windows 7):
- модель;
- версию прошивки;
- серийный номер;
- сведения о памяти (свободно/занято/всего);
- список поддерживаемых стандартов ATA;
- список поддерживаемых режимов доступа к памяти.
В интернете нашел только теоретическую информацию о том что эти данные можно считать из портов или с помощью классов WMI, доступного описания как именно это сделать не нашел.
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
13.03.2017, 17:35
Ответы с готовыми решениями:

Вывод на экран количества разделов на жестком диске
Здравствуйте, пытаюсь понять и написать программу для работы жестким диском под DOS. Суть в том что...

Панель информации о жестком диске
Я сейчас программирую на Delphi. Мне нужно сделать аналог панели (которая показана на картинке) на...

Восстановление информации на жестком диске
в свойствах пишет память занята, а захожу не видит данные которые на нём есть. что может быть? где...

Вывод информации на экран о состоянии памяти на текущем диске А
Помогите пожалуйста! сделать до завтра желательно!!В долгу не останусь!!

3
Модератор
3401 / 2172 / 353
Регистрация: 13.01.2012
Сообщений: 8,413
14.03.2017, 07:12 2
Лучший ответ Сообщение было отмечено Андрей147 как решение

Решение

Андрей147
C++
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
//------------------------------------------------------------------------------
#include <sstream>
#include <Wbemcli.h>
#include <string>
//------------------------------------------------------------------------------
//#define USE_PREFIX
 
#ifdef USE_PREFIX
#define PREFIX(root, name) #root "." #name "="
#else
#define PREFIX(root, name) ""
#endif
 
#define ADD_L(x) L##x
#define READ_WMI(root, name) \
hr = pclsObj->Get(ADD_L(#name), 0, &vtProp, 0, 0);\
if (FAILED(hr))\
{\
    info << PREFIX(root, name) << std::endl;\
}\
else\
{\
    if (V_VT(&vtProp) == VT_BSTR)\
    {\
        info << PREFIX(root, name) << vtProp.bstrVal << std::endl;\
    }\
    else\
    {\
        VARIANT tmp;\
        VariantInit(&tmp);\
        HRESULT hr = VariantChangeType(&tmp, &vtProp, 0, VT_BSTR);\
        if (hr != S_OK)\
        {\
            info<< PREFIX(root, name) << std::endl;\
        }\
        else\
        {\
            info << PREFIX(root, name) << tmp.bstrVal << std::endl;\
        }\
        VariantClear(&tmp);\
    }\
}\
VariantClear(&vtProp);
//------------------------------------------------------------------------------
std::string get_device_number(const std::string &device_letter)
{
    char buffer[64];
    sprintf(buffer, "\\\\.\\%s:", device_letter.c_str());
 
    std::string res;
 
    HANDLE driveHandle;
    driveHandle = CreateFile(
        buffer,
        0,
        FILE_SHARE_READ | FILE_SHARE_WRITE,
        0,
        OPEN_EXISTING,
        FILE_ATTRIBUTE_NORMAL,
        0);
    if (driveHandle != INVALID_HANDLE_VALUE)
    {
        STORAGE_DEVICE_NUMBER sdn;
        DWORD bytesReturned;
 
        if (DeviceIoControl(
            driveHandle,
            IOCTL_STORAGE_GET_DEVICE_NUMBER,
            0, 0,
            &sdn, sizeof(sdn), &bytesReturned,
            0))
        {
            sprintf(buffer, "\\\\.\\PHYSICALDRIVE%i", (int)sdn.DeviceNumber);
            res = buffer;
        }
        else
        {
            VOLUME_DISK_EXTENTS vde;
 
            if (DeviceIoControl(
                driveHandle,
                IOCTL_VOLUME_GET_VOLUME_DISK_EXTENTS,
                0, 0,
                &vde, sizeof(vde), &bytesReturned,
                0) && vde.NumberOfDiskExtents)
            {
                sprintf(buffer, "\\\\.\\PHYSICALDRIVE%i", (int)vde.Extents[0].DiskNumber);
                res = buffer;
            }
        }
    }
 
    CloseHandle(driveHandle);
 
    return res;
}
 
std::wstring get_disk_drive_desc(const std::wstring &device_number)
{
    HRESULT hr;
 
    hr =  CoInitializeEx(0, COINIT_MULTITHREADED);
    if (FAILED(hr))
    {
        //return L"";
    }
 
    hr =  CoInitializeSecurity(
        0,
        -1,
        0,
        0,
        RPC_C_AUTHN_LEVEL_DEFAULT,
        RPC_C_IMP_LEVEL_IMPERSONATE,
        0,
        EOAC_NONE,
        0);
    if (FAILED(hr))
    {
        //CoUninitialize();
 
        //return L"";
    }
 
    IWbemLocator *pLoc;
    hr = CoCreateInstance(
        CLSID_WbemLocator,
        0,
        CLSCTX_INPROC_SERVER,
        IID_IWbemLocator, (LPVOID *)&pLoc);
    if (FAILED(hr))
    {
        //CoUninitialize();
 
        return L"";
    }
 
    IWbemServices *pSvc;
    hr = pLoc->ConnectServer(
         L"ROOT\\CIMV2",
         0,
         0,
         0,
         0,
         0,
         0,
         &pSvc);
    if (FAILED(hr))
    {
        pLoc->Release();
        //CoUninitialize();
 
        return L"";
    }
 
    hr = CoSetProxyBlanket(
       pSvc,
       RPC_C_AUTHN_WINNT,
       RPC_C_AUTHZ_NONE,
       0,
       RPC_C_AUTHN_LEVEL_CALL,
       RPC_C_IMP_LEVEL_IMPERSONATE,
       0,
       EOAC_NONE
    );
    if (FAILED(hr))
    {
        pSvc->Release();
        pLoc->Release();
        //CoUninitialize();
 
        return L"";
    }
 
    std::wstringstream info;
 
    IEnumWbemClassObject* pEnumerator;
 
    hr = pSvc->ExecQuery(
        L"WQL",
        L"SELECT * FROM Win32_DiskDrive",
        WBEM_FLAG_FORWARD_ONLY | WBEM_FLAG_RETURN_IMMEDIATELY,
        0,
        &pEnumerator);
    if (FAILED(hr))
    {
        pSvc->Release();
        pLoc->Release();
        //CoUninitialize();
 
        return L"";
    }
 
    hr = CoSetProxyBlanket(
       pEnumerator,
       RPC_C_AUTHN_WINNT,
       RPC_C_AUTHZ_NONE,
       0,
       RPC_C_AUTHN_LEVEL_CALL,
       RPC_C_IMP_LEVEL_IMPERSONATE,
       0,
       EOAC_NONE
    );
    if (FAILED(hr))
    {
        pEnumerator->Release();
        pSvc->Release();
        pLoc->Release();
        //CoUninitialize();
 
        return L"";
    }
 
    bool found = false;
 
    while (pEnumerator)
    {
        IWbemClassObject *pclsObj;
        ULONG uReturn;
        hr = pEnumerator->Next(WBEM_INFINITE, 1, &pclsObj, &uReturn);
        if (FAILED(hr))
        {
            break;
        }
        if (!uReturn)
        {
            break;
        }
 
        VARIANT vtProp;
 
        hr = pclsObj->Get(L"DeviceId", 0, &vtProp, 0, 0);
        if (FAILED(hr))
        {}
        else
        {
            found = device_number == vtProp.bstrVal;
 
            if (found)
            {
                READ_WMI(DiskDrive, Model)
                READ_WMI(DiskDrive, SerialNumber)
            }
        }
 
        VariantClear(&vtProp);
 
        pclsObj->Release();
 
        if (found) break;
    }
 
    if (!found)
    {
        info << PREFIX(DiskDrive, Model) << std::endl;
        info << PREFIX(DiskDrive, SerialNumber) << std::endl;
    }
 
    pEnumerator->Release();
 
    pSvc->Release();
    pLoc->Release();
    //CoUninitialize();
 
    return info.str();
}
Добавлено через 1 минуту
как называются остальные нужные параметры смотрим через WMI Explorer и документацию
1
0 / 0 / 0
Регистрация: 13.03.2017
Сообщений: 2
14.03.2017, 17:29  [ТС] 3
По данному коду есть 2 вопроса:
1) Как я понимаю это только описание функций. Функции начинаются с "std::"? Получается нужно добавить "main" и вызвать все эти функции по очереди для того что бы программы заработала?
2) можно ли добавить в данный код немного комментариев? не очень понятно как код работает.
0
Модератор
3401 / 2172 / 353
Регистрация: 13.01.2012
Сообщений: 8,413
15.03.2017, 06:24 4
Андрей147, когда я писал этот код у меня уже было достаточное для работы понимание того что такое C++, функция, main, std, COM и WMI. Если вы пока не имеете об этом представления - этот код не для вас, уточните у преподавателя методику применяемую при решении задачи. По любым вопросам схема такая: обращаетесь к своему опыту и здравому смыслу, потом в Гугл или к литературе, потом сюда чётко описывая проблему (обьяснить устройство мироздания не предлагать).
0
15.03.2017, 06:24
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
15.03.2017, 06:24
Помогаю со студенческими работами здесь

QML javascript - сохранение информации на жестком диске
Мне нужно запоминать информацию на жестком диске устройства. Разрабатываю на чистом QML+JS без...

Получение информации о жестком диске и оперативной памяти
Подскажите пожалуйста, как реализовать в c++ Builder код, для получения и вывода информации о...

Найти на жестком диске компьютера все файлы с заданным именем, поочередно вывести на экран их содержимое
Привет. Подсобите пожалуйста в решении задачки. Всё уже запускается, ищется, но, даже при...

Вывод информации о локальном диске
Здравствуйте! Подскажите по такому вопросу. Почему у меня не выводит в лейбл серийный номер ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru