Автор работы: Пользователь скрыл имя, 09 Июня 2010 в 02:12, Не определен
Отчёт по практике
Санкт-Петербургский
государственный
университет аэрокосмического приборостроения
Кафедра №
35
Проверила |
Коренева Е.А. |
Выполнил
студент гр. 3551 |
Чёрный А.С. |
Спб,
2006г.
1. Содержание……………………………………………………
2. Постановка задачи…………………………………
3. Формализация
задачи………………………………………………………………
4. Алгоритм программы
Алгоритм
функции FileExists………………………………
Алгоритм
процедуры CheckParameters………………………………………
Алгоритм
основной программы………………………………………………………
5. Листинг программы
Листинг
основной программы………………………………………………………
Листинг
модуля………………………………………………………………
6. Отзыв vBulletin о методе шифрования XOR………………………………………17
7. Список
литературы……………………………………………………
2.ПОСТАНОВКА ЗАДАЧИ.
Реализовать
алгоритм шифрования XOR с открытым ключом.
3.ФОРМАЛИЗАЦИЯ
ЗАДАЧИ.
Имя файла,
который нужно зашифровать, будем
передавать первым параметром при запуске
программы. Вторым параметром будет ключ.
Сообщение о начале процесса шифрования
и его окончания будут выводиться на экран.
Операция
XOR в Паскале эквивалентна сложению по
модулю 2 в математической логике.
Очевидно,
что повторная обработка XOR вернёт
всё в исходное состояние.
Чтение
и запись будет осуществляться блоками
с помощью процедур BlockRead и BlockWrite
соответственно. Привидём некоторые сведения
по данным процедурам.
Процедура | BlockRead |
Модуль | System |
Назначение | Считывает одну или более записей в переменную |
Целевая платформа | Защищенный режим, реальный режим, Windows |
Описание | procedure BlockRеаd(var f: File; var Buff; Count: Word [;Result: Word ]) |
Примечания.
Параметр f представляет собой файловую
переменную, Buff (буфер) - любая переменная,
Count (счетчик) - выражение длиной в слово
и Result (результат) - это также переменная
длиной в слово.
Данная
процедура считывает из файла File
записи, количество которых не превосходит
числа, указанного в переменной Count, начиная
с первого байта, занятого переменной
Buff. Действительное число полных считанных
записей (меньшее или равное значению
переменной Count) возвращается в необязательном
параметре Result. Если этот параметр не задан,
то в том случае, когда число прочитанных
записей не будет совпадать со значением
переменной Count, произойдет ошибка ввода-вывода.Параметр
f представляет собой файловую переменную,
Buff (буфер) - любая переменная, Count (счетчик)
- выражение длиной в слово и Result (результат)
- это также переменная длиной в слово.
Данная процедура считывает из файла File
записи, количество которых не превосходит
числа, указанного в переменной Count, начиная
с первого байта, занятого переменной
Buff. Действительное число полных считанных
записей (меньшее или равное значению
переменной Count) возвращается в необязательном
параметре Result. Если этот параметр не задан,
то в том случае, когда число прочитанных
записей не будет совпадать со значением
переменной Count, произойдет ошибка ввода-вывода.
Весь размер переданного блока не превышает
числа байт, опрееляемых произведением
значения переменной Count и длины записи,
указываемой при открытии файла (по умолчанию
128). Если это произведение превышает 65535
(64К байта), то возникает ошибка.
Параметр
Result является необязательным. Он работает
следующим образом. Если был передан весь
блок, то при возврате управления в параметре
Result будет содержаться то же значение,
что и в переменной Count. В противном случае
значение параметра Result будет меньше:
до того, как успела завершиться передача,
был обнаружен символ конца файла. В этом
случае, если размер записи файла превышает
единицу, то в параметре Result возвращается
число полных прочитанных записей. Таким
образом, возможная неполная последняя
запись в параметре Result не учитывается.
В результате
выполнения процедуры BlockRеаd текущая
позиция в файле продвигается
на число записей, заданных переменной
Result.
При использовании
директивы компилятора {$I-} функция
IОRеsult будет возвращать 0, если операция
завершилась успешно и ненулевой код ошибки
в противном случае.
BlockWrite записывает
Count записей из Buf в F. Запись это
блок байтов, размер которого
определен процедурами Rewrite или
Reset. Если записи не удается
записать на диск, то происходит
ощибка периода выполнения. Реакция на
ошибку зависит от дерективы $I.
Важно не упустить остаток чтения, если в файле не будет укладываться полный размер блока.
5. Листинг программы
5.1 Листинг основной
программы
program
CryptIt;
uses
Crt, CryptXor;
var
fileInput, fileOutput : file ;
Key : array [0..15] of byte;
Buffer : array [0..BufferSize-1] of byte;
strTemp : string;
KeyLength : byte;
i, j, n, m : word;
Buffer_For_Mod : byte;
fileInput_Size, ind
: longint;
begin
{Очистка экрана и приветствие}
ClrScr;
TextColor(LightBlue);
Writeln ('CryptIt v1.0', #10#13);
TextColor(Brown);
{Связать файловые переменные с конкретными файлами}
Assign(fileInput, Paramstr(1));
Assign(fileOutput, 'C:\fileTemp.txt');
{Проверить параметры}
CheckParameters;
{Проверить существование входного файла}
if FileExists(ParamStr(1)) = false then
begin
Writeln('Open file error in ', ParamStr (1));
Halt(2);
end
else
Reset(fileInput, 1);
{Получить размер входного файла}
fileInput_Size := FileSize(fileInput);
{Проверка размера входного файла}
if fileInput_Size = 0 then
begin
Writeln('File size error ', ParamStr(1));
Halt(2);
end;
{Подготовка выходного файла}
Rewrite(fileOutput, 1);
{Проверка открытия выходного файла}
if FileExists('C:\fileTemp.txt') = false then
begin
Writeln('Open temp file error');
Halt(2);
end;
{strTemp = наш ключ}
strTemp := ParamStr(2);
{Определим длину ключа}
KeyLength := Length(strTemp);
{Если длина ключа больше 16, определить е+ в 15}
if
KeyLength > 16 then
KeyLength := 15;
{Формирование ключа. Инвертирование позиции.}
for i := 1 to KeyLength do
Key[i-1] := not
(ord(strTemp[i]));
{Обнуление переменных}
i := 0;
ind := 0;
n := 0;
Writeln('In
progres. Wait, please...');
{Работа с основным блоком}
for j := 1 to fileInput_Size div BufferSize do
begin
BlockRead (fileInput, Buffer, BufferSize);
{I-}
if IOResult <> 0 then
begin
Writeln('Reading error ', ParamStr(1));
Halt(3);