如何锁定一个文本文件不让用户编辑(100分)

  • 主题发起人 主题发起人 yanlei
  • 开始时间 开始时间
Y

yanlei

Unregistered / Unconfirmed
GUEST, unregistred user!
原因是这样,自己的软件日志是文本文件,是软件自动记录,不应让用户修改
 
1、对文本加密以使用户无法修改。
2、将此日志改用注册表写。
3、设置文件属性为隐藏。
4、将此文本放到windows系统目录,比如c:/windows/ or c:/windows/system/ or c:/winnt/
这样用户不易发现此文件。
5、建一个库,建一个表,设立char或者text字段,专门写日志,数据库本身加口令。
 
日志在不启动我的软件,能方便看到,如果这样我还要编其他程序,有没有更好的方法
 
1、拷到软盘上。
2、你离开时将硬盘上的文本文件删除。
3、将软盘带走。[:)]
 
//日志在不启动我的软件,能方便看到,如果这样我还要编其他程序,有没有更好的方法
这个可能不好办啊,用户既然能不启用你的软件查看日志,那么就不能加密,
他也肯定知道这个文件在什么地方,叫什么名。(设为只读?太[:D])

要想控制,就必须自己写日志查看工具。
 
如果用户有无上权限,告诉他:不能修改这个文件.
否则,让系统管理员设置此文件的安全属性.
 
日志怎么能让用户自由查看、编辑呢?日志不应该用文本文件。如果一定要让用户方便查
阅,你不防在程序退出时写一个文本文件让用户查看,真正的信息存在一个加密的文件中
或数据库中。
 
这涉及到文件读写的加密问题。
在Delphi中预定义了Tfilestream类,通过它可以对磁盘文件进行读写,选定Tfilestream为
基类,通过对其核心的两个读、写方法进行重载,编写定制的文件流,实现对文件的读、写
进行加密。

定制文件流(Tmystream)的声明:

type
Tmystream=class(Tfilestream)
private
fkey:string;
public
constructor create
(const filename:string;mode:word);
function read(var buffer;count:longint):
longint;override;
function write(const buffer;count:longint):
longint;override;
property key:string read fkey write fkey ;
end;

在Tmystream的声明中,对read、write两个方法进行了重载,并添加了一个新的特性key,
用以存储对文件进行加密时所需的密码。为实现文件读写的加密,在write方法中,将key
的每个字符依次与buffer中的字符相加,将得到的结果写入文件,实现加密;在read方法
中,将读出的内容依次与key的每个字符相减,实现解密。

function Tmystream.write(const buffer;
count:longint):longint;
var
Pbu,Pmy,mykey:pchar;
i,enc:integer;
begin
getmem(pmy,count); //为pmy分配内存
mykey:=pchar(key); //将key转换为pchar指针
try
pbu:=pchar(@buffer); //将buffer转换为pchar指针
for i:=0 to count-1 do
//将key的每个字符以此与buffer的
每个字符循环相加,结果放入pmy指向的内存区
begin
enc:=(ord(pbu)+ord(mykey
[(i mod length(key))])) mod 256;
Pmy:=char(enc);
end;
result:=inherited write(Pmy^,count);
//将pmy指向的内容写入文件
finally
freemem(Pmy,count);
end;
end;
function Tmystream.read(var buffer;count:longint):
longint;
var
Pbu,Pmy,mykey:pchar;
i,mycount,enc:integer;
begin
getmem(Pmy,count);//为pmy分配内存
mykey:=pchar(key);//将key转换为pchar指针
try
mycount:=inherited read(Pmy^,count);
//将文件内容读入pmy指向内存区
Pbu:=Pchar(@buffer);将buffer转换为pchar指针
for i:=0 to mycount-1 do//将key的每个字符依次
与pmy的每个字符循环相减,结果放入pbu指向的变量
begin
enc:=(ord(Pmy)-ord(mykey
[(i mod length(key))])) mod 256;
Pbu:=chr(enc);
end;
finally
freemem(Pmy,count);
end;
result:=mycount;
end;

完成定制文件流的编写后,便可在程序中应用,实现文件的读写加密:

unit Unit1;
interface
uses
Windows, Messages, SysUtils, Classes,
Graphics, Controls, Forms, Dialogs,
ExtCtrls, StdCtrls,unit2,unit3;
//unit2定义了Tmystream
//unit3定义了输入密码对话框form3
type
TForm1 = class(TForm)
Button1: TButton;
Button2: TButton;
Button3: TButton;
OpenDialog1: TOpenDialog;
SaveDialog1: TSaveDialog;
Panel1: TPanel;
Panel2: TPanel;
Memo1: TMemo;
Splitter1: TSplitter;
Memo2: TMemo;
procedure Button2Click(Sender: TObject);
procedure Button3Click(Sender: TObject);
procedure Button1Click(Sender: TObject);
private
{ Private declarations }
public
{ Public declarations }
end;
var
Form1: TForm1;
implementation
{$R *.DFM}
procedure TForm1.Button2Click(Sender: TObject);
//将选定的加密文件解开,读入memo2
var
encstr:Tmystream;
begin
if opendialog1.Execute and (form3.showmodal=mrok)
then
begin
encstr:=Tmystream.create
(opendialog1.filename,fmopenread);
encstr.key:=form3.Edit1.Text;
try
memo2.lines.LoadFromStream(encstr);
finally
encstr.Free;
end;
end;
end;

procedure TForm1.Button3Click(Sender: TObject);
//将memo1中的内容加密,用指定文件名另存
var
encstr:Tmystream;
begin
if savedialog1.Execute and (form3.showmodal=mrok)
then
begin
encstr:=Tmystream.create(savedialog1.filename,
fmcreate);
encstr.key:=form3.Edit1.Text;
try
memo1.lines.SaveToStream(encstr);
finally
encstr.Free;
end;
end;
end;

procedure TForm1.Button1Click(Sender: TObject);
//将指定文件读入memo1
var
mystr:Tfilestream;
begin
if opendialog1.Execute then
begin
mystr:=Tfilestream.create
(opendialog1.filename,fmopenread);
try
memo1.lines.LoadFromStream(mystr);
finally
mystr.Free;
end;
end;
end;
end.
 
对日志文件做dac验证码。
 
后退
顶部