
Последние записи
- Прозрачность тайлсета в TPNGImage
- Как сделать VBA макрос в excel
- Поиск по столбцу 1-ого не нулевого значения (формулой в Microsoft Office Excel)
- Простановка единиц в ячейки под объектами (Microsoft Office Excel)
- Расчет затраченного времени между определенным рабочим временем (формулой в Microsoft Office Excel)
- Мигающий экран на Assembler
- VBA-макрос по копированию 10 строчек в выбранном диапазоне в Microsoft Office Excel
- Копирование только нужного диапазона в Microsoft Office Excel
- Перенос диапазона стоки в Microsoft Office Excel на другой лист по условию
- Мелодия в Pascal.ABC.Net с помощью System.Console.Beep — задержка воспроизведения звука

2nd
Июл
Как зашифровать текстовый файл
Posted by Chas under Delphi
Делаю небольшую программу Тест — Проверка знаний.Хочу признаться что исходник не мой,там все вопросы и ответы сохранены в текстовом файле.Вот и вопрос,как мне его зашифровать чтобы никто не смог увидеть ответы?
Программа почти что готова.
psycho-coder
Вот в виде библиотеки. Его можно от туда выдрать. Писал прогу похожую на твою и именно эту либу использовал. Либу писал сам.
Можно один раз пройтись. Можно два ))
library crypt;
uses
SysUtils,
Classes;
procedure CryptFile(const fileName: String); StdCall;
var
fs: TFileStream;
i, len: Longint;
c1, c2: Byte;
begin
try
fs := TFileStream.Create(fileName, fmOpenReadWrite);
len := fs.Size;
for i := 0 to len - 2 do
begin
fs.Seek(i, soFromBeginning);
fs.Read(c1, 1);
fs.Seek(i+1, soFromBeginning);
fs.Read(c2, 1);
c1 := c1 + c2;
fs.Seek(i, soFromBeginning);
fs.Write(c1, 1);
end;
for i := 0 to len - 2 do
begin
fs.Seek(i, soFromBeginning);
fs.Read(c1, 1);
fs.Seek(i+1, soFromBeginning);
fs.Read(c2, 1);
c1 := c1 + c2;
fs.Seek(i, soFromBeginning);
fs.Write(c1, 1);
end;
fs.Free;
except
fs.Free;
end;
end;
procedure DeCryptFile(const fileName: String); StdCall;
var
fs: TFileStream;
i, len: Longint;
c1, c2: Byte;
begin
try
fs := TFileStream.Create(fileName, fmOpenReadWrite);
len := fs.Size - 1;
for i := len downto 1 do
begin
fs.Seek(i, soFromBeginning);
fs.Read(c1, 1);
fs.Seek(i-1, soFromBeginning);
fs.Read(c2, 1);
c1 := c2 - c1;
fs.Seek(i-1, soFromBeginning);
fs.Write(c1, 1);
end;
for i := len downto 1 do
begin
fs.Seek(i, soFromBeginning);
fs.Read(c1, 1);
fs.Seek(i-1, soFromBeginning);
fs.Read(c2, 1);
c1 := c2 - c1;
fs.Seek(i-1, soFromBeginning);
fs.Write(c1, 1);
end;
fs.Free;
except
end;
end;
exports CryptFile index 10;
exports DeCryptFile index 20;
begin
end.
Serge_Bliznykov
То, что проблема решена, это отлично!
я просто хотел сказать… «я тебе один умный вещ скажу, только ты не обижайся»
1) в обычной жизни отлично себя рекомендует обычный xor При достаточной длинной строке ключа шифр получается вполне стойкий даже к частотному анализу и простым методам криптоанализа.
Так что — рекомендую!
Удобство XOR в том, что Символ xor Ключ = Зашифрованный Символ
а затем Зашифрованный Символ xor Ключ = Символ
Только не используйте в качестве ключа ОДИНОЧНЫЙ символ! Такой символ находится быстро!
2) есть отличные бесплатные библиотеки, которые обеспечат шифрацию, стандартными криптоалгоритмами (Rijndael (он же AES) , Blowfish и т.д.)
Stilet
А я дополню моего уважаемого коллегу, Сержа, сократив код до такого:
program Project1;
{$APPTYPE CONSOLE}
uses
SysUtils;
var s:string;
function XORString(str:String; XORKey:byte):string;
var e:integer;
begin
result:='';
//********* FOR ******************
for e :=1 to length(str) do
begin
result:=result+chr(byte(str[e]) xor XORKey);
end;
//******* END FOR ****************{}
end;
begin
AssignFile(input,'file2.txt');reset(input);
AssignFile(output,'file3.txt');rewrite(output);
while not eof(input) do begin
readln(s);
write(XORString(s,200));
end;
CloseFile(output);
CloseFile(input);
{ TODO -oUser -cConsole Main : Insert code here }
end.