Форум программистов, компьютерный форум, киберфорум
C/С++ под Linux
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/8: Рейтинг темы: голосов - 8, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 15.05.2011
Сообщений: 8

Антивирус

25.05.2011, 11:07. Показов 1597. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени стуток. Взял себе на курсовую написать простенький антивирус . Задача такова: Условный антивирусный файловый сканер.
Сканировать рекурсивно папку, заданную пользователем.
Осуществлять поиск сигнатур, известных сканеру.
Выводить инфицированные объекты на экран в формате:
путь к файлу: название сигнатуры условного вируса.
Каждая сигнатура - это запись в файле сигнатур, который
хранится в папке антивируса (база).
Сигнатура состоит из нескольких полей:
1) Название, срока. Пример: Worm.LoveSan
2) Длина тела, целое число.
3) Собственно тело, последовательность байт.
Основу я уже сделал, у меня антивирус проходит рекурсивно папку и ищет название условного вируса, но пока я это название задаю программно. Можете мне помочь сделать сравнение не только по названию но и по пункту 2 и 3 и желательно чтобы эти данные брались из файла base

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
#include <sys/stat.h>
#include <ftw.h>
#include <stdio.h>
#include <stdlib.h>
#include <dirent.h>
#include <sys/dir.h>
#include <sys/stat.h>
#include <string.h>
 
int rek (const char *name, const struct stat *status, int type) //Функция которая вызывается для каждого файла или каталога, найденого в поддереве. (нужна для рекурсивного обхода)
{
    FILE *f1;
    f1 = fopen("Buf.txt", "a+");
    if (type == FTW_F)
        fprintf(f1 ,"%s %ld\n", name, status->st_size);
    fclose(f1);
    return 0;
}
 
int main (int argc, char *argv)
{
 
    int rek (const char *, const struct stat *, int); 
    FILE *f1, *f2, *f3, *f4;
    char filename[256];
    int i, sch, k;
    char b[1024];
 
    f2 = fopen("Buf.txt", "w");
    fprintf(f3, "");
 
    printf("Введите точку отчета!\n");
    scanf("%s", filename);
 
    if ((f1 = fopen(filename, "r")) == NULL)
    {
        printf("Не верно указана точка отсчета!");
        return 0;
    }
    else
        ftw(filename, rek, 1);
    fclose(f1);
    fclose(f2);
    
    if ((f3 = fopen("Base.txt", "r")) == NULL)
    {
        printf("Антивирусная база не найдена!");
        return 0;
    }
    if ((f4 = fopen("Buf.txt", "r")) == NULL)
    {
        printf("Не найден отчет сканирования!");
        return 0;
    }
    i = 0;
    sch = 1;
    k = 0;
    while(1) {
        int c = getc(f4);
        if (c == EOF)
            break;
        b[i] = c;
        
        if (b[i] == '\n' || b[i] == '/' || b[i] == ' ')
        {
            b[i] = '\0';
            sch = strcmp(b, "Worm.Love");
            if ( sch == 0 )
            {
                printf("Обнаружен вирус! %s\n", b);
                k++;
            }
            i = 0;
        }       
        else
            ++i;
        }
    if (sch != 0 && k == 0)
    {
        printf("Вирусы не обнаружены!\n");
    }
    printf("Обнаруженно вирусов: %d\n", k);
 
    fclose(f3);
    fclose(f4);
}
f1-указываем путь к директории
f2- обнулить старые значения в buf
f3- открытие антивирусной базы
f4-открытие результата сканирования

Сам файл с базой открываю но как теперь сравнивать значения от туда с проверяемым файлом я не знаю. Сенсей сказал что сравнение с базой должно проходить в функции rek.

Файлы программы:
Buf.txt - результат сканирования
base.txt- вирусная база
Worm.Love -наш злой условный вирус=)
r.c -прога
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
25.05.2011, 11:07
Ответы с готовыми решениями:

Разница антивирус и антивирус интернет секьюрити!?
привет всем! ребята объясните пожалуйста разницу антивирус и антивирус интернет секьюрити!?

Антивирус
Где можно бесплатно скачать рабочий антивирус Касперский?

антивирус
есть на телефон нокия 6300 антивирус

4
4866 / 3287 / 468
Регистрация: 10.12.2008
Сообщений: 10,570
26.05.2011, 08:33
когда ошибки, возвращаешь ноль, а надо не ноль

C
1
2
3
4
        while(1) {
                int c = getc(f4);
                if (c == EOF)
                        break;
C
1
2
        while((с = getc(f4)) != EOF) {
            ;
граница цикла должна быть ясной

странно, что отчёт сканирования открывается на чтение
странно, что база открывается, но не читается

словесное описание
Code
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
main {
    принять исходные данные
    открыть базу
    сканировать файлы
    вывести результаты
}
 
принять исходные данные {
    
}
 
открыть базу {
    
}
 
сканировать файлы {
    while(есть файл)
        if(это_вирус(файл))
            сохранить координаты
}
 
это_вирус(файл) {
    базу на начало
    while(есть строка в базе)
        if(файл соответствует строке)
            возвратить истину
    возвратить ложь
}
 
вывести результаты {
    
}
1
0 / 0 / 0
Регистрация: 15.05.2011
Сообщений: 8
27.05.2011, 16:15  [ТС]
когда ошибки, возвращаешь ноль, а надо не ноль
C
1
2
3
4
 while(1) {
                int c = getc(f4);
                if (c == EOF)
                        break;
C
1
2
while((с = getc(f4)) != EOF) {
            ;
граница цикла должна быть ясной
С начало так и было но преподаватель сказал что на выходе функции getc(f4) interget, второй вариант этого не гарантирует.

сканировать файлы {
while(есть файл)
if(это_вирус(файл))
сохранить координаты
}
Можешь пожалуйста дать код, тут загвоздка у меня?
0
4866 / 3287 / 468
Регистрация: 10.12.2008
Сообщений: 10,570
28.05.2011, 06:32
Цитата Сообщение от Rydj
второй вариант этого не гарантирует
чего ?

Цитата Сообщение от Rydj
Можешь пожалуйста дать код, тут загвоздка у меня?
нужно сделать список файлов и использовать его
а список можно получать функцией

Code
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
сканировать файлы {
    получить список файлов
    while(есть файл)
        if(это_вирус(файл))
            сохранить координаты
}
 
получить список файлов {
    создать общий список
    while(есть каталог) {
        зайти в каталог
        получить список файлов каталога
        добавить в общий список
    }
    вернуть общий список    
}
0
Эксперт по компьютерным сетямЭксперт NIX
 Аватар для Dmitry
13440 / 7534 / 830
Регистрация: 09.09.2009
Сообщений: 29,554
20.12.2011, 01:03
имхо, пора банить tornado2012 и вычищать его спам
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
20.12.2011, 01:03
Помогаю со студенческими работами здесь

антивирус
Перемещено из раздела &quot;Системный софт&quot; переставил windows7 отформатировал оба раздела при окрывании любой папки выскакивает окно что...

Антивирус
Вопрос таков, какой принцип работы антивируса, как можно это реализовать в делфи7, ну хотя бы самый простой.=-O

Антивирус
Недавно задумался написать антивирусник, задумался о том как это можно осуществить, в голову пришло только открыть файл для чтения и искать...

Антивирус в Windows XP
Подскажите пожалуйста! Вот у меня на компе стоит две винды:семерка и хрюша! Я что через одну, что через другую пользуюсь интернетом! Так...

АНТИВИРУС
Всем привет, помогите пожалуйста написать антивирус в С++ или С#..


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
Уведомление о неверно выбранном значении справочника
Maks 06.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "НарядПутевка", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если в документе выбран неверный склад. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru