170 похожих чатов

Есть утилиты на гитхабе чтобы отреверсить .dll и получить .h

? Или как вручную написать с r2 например? я нашел одну китайскую, но она выдает только c++ классы в хедерах, а в либе еще дофига остальных функций

23 ответов

14 просмотров

Что ты вообще пытаешься сделать?

Michael- Автор вопроса
blue hatred
Что ты вообще пытаешься сделать?

китайос прислал SDK без хедеров. Надо сделать приложение на этом SDK а для этого нужны хотя бы .h и .lib, а не только .dll. насколько я понял- это дллки MSVC++ (выпросить .h не вариант, они затерялись хз где)

Michael
китайос прислал SDK без хедеров. Надо сделать прил...

тебе с этим вопросом в @pro_winapi на самом деле, а вообще GetProcAddress если тебе нужны именно функции

Michael
китайос прислал SDK без хедеров. Надо сделать прил...

в общем случае, максимум, что ты сможешь сделать это сгенерить .lib

usernameak
я и хедеры наревершивал

это уже не столь тривиально, в общем случае

disba1ancer
это уже не столь тривиально, в общем случае

Ну тебе это в любом случае нужно будет сделать. Вообще в целом самое тривиальное здесь это именно GetProcAddress

blue hatred
Ну тебе это в любом случае нужно будет сделать. Во...

я к тому что не всегда можно узнать типы аргументов функции, а иногда надо значть что за структуры были в хедере, а это только реверсом можно выяснить, какие-нибудь полезные константы, возможно, что к либе имеется документация, в которую протекли какие-то части хедера, это слегка всё упростить, но боли всё ещё останется много, кстати, это не мне надо, а автору исходного вопроса

Michael
китайос прислал SDK без хедеров. Надо сделать прил...

Самоо разумное вытрясти таки нормальную поставку. С остальным мжешь вляпаться на долгие месяцы реверса и потом оказаться виноватым, что не сделал.

Каких то супер разумных утилит не встречал. Об экспортах все очень подробно рассказывает dumpbin. Но этой информации обычно недостаточно. Приходится включать мозг и иду. В результате получится .h и из него делается import .lib

Viktor Chyzhdzenka
Самоо разумное вытрясти таки нормальную поставку. ...

ну ты человека то не пугай, это на самом деле не так сложно, как кажется, но вообще да, странно что к либе не приложили хедеры, с такими партнерами работать как минимум вообще не нужно

blue hatred
ну ты человека то не пугай, это на самом деле не т...

Это дурная работа. В теории сделать можно, да. Но вот сколько времени у него уйдет никто не знает и даже он сам. Может 3 дня, а может 3 месяца.

disba1ancer
для import lib хватит и самой dll

А ещё бывает экспорт по ординалам.. вообще скучно. Ситуация, конечно, имеет место быть. На мою похожа. Когда-то в темных 90-х начальник выдал мне кассовый аппарат и затертую дискету к нему, на которой ничего кроме .длл не было. Подключи - #тыжпрограммист! С этого и началось мое грехопадение... Жалею. Никому не советую ходить по этой дорожке, когда в жизни много прямых и хлебных путей. Оффтоп, короче.

usernameak
дорожка скользкая, но интересная

Нихрена не интересная. Можно получить предложение "от одной организации", от которого очень сложно отказаться. И вообще - любопытство грех.

blue hatred
ну ты человека то не пугай, это на самом деле не т...

Вообще, это невозможно. Но когда везёт, то кажется, что несложно

blue hatred
ну ты человека то не пугай, это на самом деле не т...

Для рядового прогера реверс оч оч сложен

blue hatred
Ну невозможно так невозможно)

ну общего алгоритма для реверса выхлопа оптимизирующего компилятора и правда нет, иначе бы все брали просто hexrays =)

Похожие вопросы

Обсуждают сегодня

Такс, блин, таки кто-то знает, каким образом работают макросы stdin/stdout/stderr? Я влез в stdio.h, там определения нет, отладил через асмокод - вызывается функция со странны...
The Bird of Hermes
18
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
Всем привет, на линуксе лучше на fasm или nasm учиться писать для начала ?
meszjol
14
Если у меня есть такой класс: Object = {} function Object:new(a_name, a_transform, a_color, a_mesh, a_material, a_shader, a_textures) local private = {} private.n...
Cuarno Vile
4
Гайз, кто-нибудь пробовал запустить probe-rs под камень, которого нет в probe-rs? Мб есть какой-нибудь пример у кого... Через target-gen попробовал сгенерировать chip-descript...
Максим Смирнов
2
А еще в перле можно уже @arr1 + @arr2?
Sergei Zhmylove
53
было так ;void set_http_ver(RESPD* ptr, char* version, uint32_t length) // example: 'RTSP/1.1 ' set_http_ver: mov eax, [esp + 4] mov ecx, [esp + 8] ...
Mixail Frolov
5
@MrMiscipitlick А можешь макрос написать, который будет вычислять смещение относительно переданных меток? Просто .label1-.label2, и вернуть значение.
КТ315
35
зачем же переименовывать ? чтобы кол-во участников возросло или вдруг IBM от этого снова на свифте начнет кодить ? Я не понимаю что страшного в том что свифт гавно, если это т...
Oleh Nerzh
10
здравствуйте. совершаю вот такую вещь: strcpy(line, (char)current_number); где current number — неподписанный шорт, line — массив чаров. ругань следующая: main.c:29:30: error...
Roberto's Ширгозиев
13
Карта сайта