Chinaunix首页 | 论坛 | 博客
  • 博客访问: 103121089
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-17 16:58:33

 来源:


INI文件是文本文件,由若干section组成,在每个带括号的标题下面,是若干个Keyword和一个等号,每个Keyword会控制应用程序某个功能的工作方式,等号右边的Value制定Keyword的方式,其一般形式如下:

[section1]
keyword1=value1
keyword2=value2
[section2]
keyword1=value1
keyword2=value2

其中SectionName和KeywordName分别是段名和关键字明,Value为关键字对应的设定值,如果等号右边无任何内容(value为空),表示Windows应用程序已为该Keyword指定了缺省值,如果在整个文件中找不到某个Keyword,同样表示为它们指定了缺省值,各Section所出现的顺序是无关紧要的,在每一个Section里,各个Keyword的顺序同样也无关紧要,Keyword的值的类型多为String或Integer,应分两种情况读写。

INI文件的书写有严格的要求:

1、Section的名称必须加以“[”和“]”,且“[”必须在屏幕的第一列。

2、Keyword名称也必须从屏幕的第一列开始书写,且后面必须紧跟“=”

3、可以对文件加以注释,每行注释须以“;”开头。

依照上述规则,我们编写下面的INI文件存储数据库的连接信息

[dbParam]
Data Source=GTSERVER
Initial Catalog=SuperWorkFlow
User ID=map
Password=map

下面要做的工作就是编写代码,在程序执行的时候从INI文件中读取数据库参数,为此,我编写了下面的代码:

//RWini.pas
{
模块名称:配置文件读写
编写人:blue
编写:2003-4-26
模块功能:从系统配置文件中读取系统运行所需的各项参数
 将系统运行所需的各项参数写入系统配置文件
 生成数据库连接字符串
}
unit RWini;
interface
uses INIFiles;
const strINIname = 'db.ini';//INI文件的文件名,大家根据具体情况修改
var
 iniParam : TINIFile;
 strLocal : String;
 procedure readParam(out server:String;
out database:string;out user:string;out password:string);
 procedure writeParam(server:string;database:string;
user:string;password:string);
 function getConnStr:string;
implementation

 procedure readParam(out server:String;
out database:string;out user:string;out password:string);
 begin
//从配置文件中读取数据库连接参数
server := iniParam.ReadString('dbParam','Data Source','');
database := iniParam.ReadString('dbParam','Initial Catalog','');
user := iniParam.ReadString('dbParam','User ID','');
password := iniParam.ReadString('dbParam','Password','');
 end;

 procedure writeParam(server:string;database:string;
user:string;password:string);
 begin
//将数据库连接参数写入配置文件
iniParam.WriteString('dbParam','Data Source',server);
iniParam.WriteString('dbParam','Initial Catalog',database);
iniParam.WriteString('dbParam','User ID',user);
iniParam.WriteString('dbParam','Password',password);
 end;

 function getConnStr:String;
 var
server,database,user,password : String;
 begin
//生成数据库连接串
readParam(server,database,user,password);
result := 'Provider=SQLOLEDB.1;
Password=' + password + ';Persist Security Info=True;
User ID=' + user + ';Initial Catalog=' + database + ';
Data Source=' + server; 
 end;

initialization
 getDir(0,strLocal);
 iniParam := TINIFile.Create(strLocal + '' + strINIname);

finalization
 iniParam.Free;
end.

在程序数据模块的Create事件中添加下面的代码:

procedure TDM.DataModuleCreate(Sender: TObject);
var
 confForm : TConf;
begin
 conn.ConnectionString := RWini.getConnStr;
 try
conn.Open;
 except
on Err : EOLEException do
begin
 confForm := TConf.Create(self);
 confForm.ShowModal; 
end;
 end;
end;

这样,在程序执行过程中,将自动从INI文件中读取数据库连接参数,连接数据库,如果连接出现错误,将显示参数配置窗口,让用户配置数据库连接参数。配置窗口的代码如下:

//上面的代码省略
uses RWini;

{ $R *.dfm}

procedure TConf.FormShow(Sender: TObject);
var
 sServer,sDatabase,sUser,sPassword : String;
begin
 readParam(sServer,sDatabase,sUser,sPassword);
 self.edtServer.Text := sServer;
 self.edtDatabase.Text := sDatabase;
 self.edtUser.Text := sUser;
 self.edtPassword.Text := sPassword;
 self.ActiveControl := self.btnOK;
end;

procedure TConf.btnCancelClick(Sender: TObject);
begin
 close;
end;

procedure TConf.btnOKClick(Sender: TObject);
var
 sServer,sDatabase,sUser,sPassword : String;
begin
 sServer := self.edtServer.Text;
 sDatabase := self.edtDatabase.Text;
 sUser := self.edtUser.Text;
 sPassword := self.edtPassword.Text;
 writeParam(sServer,sDatabase,sUser,sPassword);
 close;
end;
阅读(426) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~