Нужна помощь опытного программера. Это будет просто СУПЕР! если преклеятся к какоми нибуть сис файлу. А вот и идея. Думаю всем известно что обычный VB компилятор переменные не шифрует, тоесть можно изменить значение переменной даже если exe уже скомпилирован. Это может проверить любой, возьмите создайте строковую переменную, потом выведите в MsgBox эту переменную, допустим это будет "Hello World". Делаем exe смотрим через обычный блокнот и поиском можно найти нашу переменную "Hello World" или что-то наподобие "H e l l o W o r l d" вообщем там могут быть небольшие искажения, но НЕ БОЛЬШИЕ. А значит, если открыть наш компилированный exe как Binarry найти наш "Hello World" и открыть файл к которому нужно приклеятся, перевести его в Base64 и тот шифр Base64 закинуть в ту переменную, вместо "Hello Word". Далее в нашей программе та которая клеится куда-то, нужно написать декодер Base64, то что декодирует естетственно запускаем с теми же параметрами коммандной строки что и передыны были в нашу программу, ну и помимо запуска оригинального файла который мы получили разшифровав Base64, проигруем что-то своё. А вот что у меня неполучается, немогу его открыть как binarry, т.к. не умею (может за одно кто-то научит), также если "Hello World" с искажениями как его найти чтобы потом заменить, ну а запихнуть теда тот же Base64 даже с искажениями думаю несложно. Ну вот и всё, чисто стратегически - несложно, но практически, увы. Конечно понимаю что это не просто вапрос вроде " а как сдеть чего-то...", но может кто-то заинтерисуется потому что и самому интересно будет, если кто-то своротит такое - !!!!!ДЕЛИТЕСЬ СО ВСЕМИ!!!!! УДАЧИ.
Эта программа считает число пробелов в файле win.com
Прилеплять свою программу к другой, конечно, можно и так, но вирусы обычно по другому пишутся. В PE-заголовке меняют стартовый адрес, пишут в конец тело вируса, а в конце вируса пишут вызов предыдущего стартового адреса - нормального файла. Почитай спецификацию PE-формата...
Sharp, ty proboval?dumayu net. Ya da, i he hera ne vyshlo. sa poprobuj vot vhto sadelat`:sdelaj takoj exe, v katotom Hello World napisano, i pomenyaj ego na Hi(v Binary editory). i zapusti. dayu garantiyu chto ne zavustitsya.
Конечно же я пробовал. Читай бессмертного Billy Belcebu и узрей:
"Чексумма: Предположительно CRC файла. Как и в других микрософтовских форматах исполняемых файлов, это поле игнорируется и устанавливается в 0. Есть одно исключение из этого правила: в доверенных (trusted) сервисах и EXE это поле должно содержать верную чексумму."
Так что если поменять чексумму, Винда материться не будет. Это раз.
Если поменять "Hello, world!" на "Hi!" аккуратно, т.е. вставить после "!" chr(0) (помня, конечно же, об уникоде), а остальное оставить как есть, то материться Винда опять-таки не будет и спокойненько покажет нам "Hi!". Зато вот если грубо (да еще и в Notepad) выдрать с мясом кусок текста, то, безусловно, появится глюк. И объяснить это можно намного проще, чем стремлением Microsoft к сохранению чужих ехешников методом контроля CRC. А именно тем, что точка входа в программу, объявленная в заголовке, будет указывать на фигню, потому что код в VB-ехешнике находится ниже секции .data. Пример: сократите название фирмы - программа запустится, но не будет иметь ни информации об изготовителе, ни иконки, т.к. хотя точка входа в программу правильная, ресурсы размещены неправильно. А прежде чем говорить и страстно обвинять, все-таки стоит вооружиться спецификаций PE и почитать... Это я так, не в обиду.
Я хоть и не специалист по PE-заголовку (да и инфа вся сдохла вместе с винтом), но тоже подобное читал. CRC не добавляется почти не одним известным мне компилятором. Это может сделать только системный программист. Про VB ничего не знаю - скорее всего он при компиляции тоже не добавляет контрольную сумму.