我想把数据库的连接信息放到一个.INI的文件里。密码用二进制写,以方便以后
更改密码。如何写?谢谢!

解决方案 »

  1.   

    Filename:='c:\mytest.ini';
       Testini:=Tinifile.Create(filename);
       ss:=testini.ReadString('Diskid','patno','0');
       Showmessage(ss);
      

  2.   

    感觉是你用writestring就可以了,用readstring读出来,然后把string转byte不就好了吗?
      

  3.   

    请具体点如文件在d:\sam\sys.ini 如何写?本人菜鸟!
      

  4.   

    var
     filename,con_str:string;
     inifile:Tinifile;
    begin
     con_str:='Provider=SQLOLEDB.1;Persist Security Info=False;';
     if server_edit.Text<>'' then
       con_str:=con_str+'Data Source='+server_edit.Text+';';
     if db_edit.Text<>'' then
       con_str:=con_str+'Initial Catalog='+db_edit.Text+';';
     if user_edit.Text<>'' then
       con_str:=con_str+'User Id='+user_edit.Text+';';
     if pass_edit.Text<>'' then
       con_str:=con_str+'password='+pass_edit.Text+';';
     try
      with Form_DM.ADOCON_DB do
      begin
       connectionstring:=con_str;
       connected:=true;
       connected:=false;
      end;
     except
      messagebox(self.handle,'数据通道连接失败,请检查!','错误',MB_OK);
      exit;
     end;
     filename:=extractfilepath(application.exename)+'document\sys.ini';
     inifile:=Tinifile.Create(filename);
     inifile.WriteString('SYS','CON',con_str);
     messagebox(self.handle,'设置成功,请重新启动系统!','提示',MB_OK);
     inifile.Free;
     application.Terminate;
      

  5.   

    procedure TFormlogin.BitBtn1Click(Sender: TObject);
    var
      MyIniFile : TIniFile;
      TempString:string;
    begin
      TempString:=ExtractFilePath(Application.Exename);
      TempString:=TempString+'MyGPMS.ini';
     if (edit1.Text<>'') and (edit2.text<>'') then
     begin
       MyIniFile:=TIniFile.create(TempString);
       MyIniFile.writestring('数据库','SERVER NAME',edit1.text);
       MyIniFile.writestring('数据库','USER NAME',edit2.text);
       MyIniFile.writestring('数据库','PASSWORD',edit3.text);
     try
     with DM.Database do
     begin
       Close;
       TempString:=MyIniFile.ReadString('数据库','DATABASE NAME','');
       Params.Values['DATABASE NAME']:=TempString;   TempString:=MyIniFile.ReadString('数据库','SERVER NAME','');
       Params.Values['SERVER NAME']:=TempString;   TempString:=MyIniFile.ReadString('数据库','USER NAME','');
       Params.Values['USER NAME']:=TempString;   TempString:=MyIniFile.ReadString('数据库','PASSWORD','');
       Params.Values['PASSWORD']:= '' ;
       Open;
     end;
        formlogin.close;
        except
         application.messagebox('数据库登录错误!请重新确认服务器名及用户名!','错误!',mb_ok+mb_iconerror);
         edit1.text:='';
         edit2.text:='';
         edit3.text:='';
         edit1.SetFocus;
        end;
      

  6.   

    ini文件内容
      [数据库]
      连接=driver={SQL Server};Server=ip地址;DATABASE=数据库名;uid=用户名;pwd=密码
    然后在formcreate里面
    var
      inifile:tinifile;
    begin
      inifile:=tinifile.create(extractfilepath(appplication.exename)+'文件名.ini');
      youradoconnection.ConnectionString:=inifile.readstring('数据库','连接','');
    end;
    不知道是不是你想要的
      

  7.   

    INI文件的读写  
    bird
    摘 要:INI文件的读写
    关键字:INI 文件
    类 别:Object Pascal
     
     
    ini文件结构:
    [user1]
    password=password1
    power=power1[user2]
    password=password2
    power=power2.......[usern]
    password=passwordn
    power=powern
    一、有必要了解INI文件的结构:
        ;注释
        [小节名]
        关键字=值
        ...---- INI文件允许有多个小节,每个小节又允许有多个关键字, “=”后面是该关键字的值。 
    ---- 值的类型有三种:字符串、整型数值和布尔值。其中字符串存贮在INI文件中时没有引号,布尔真值用1表示,布尔假值用0表示。 ---- 注释以分号“;”开头。 二、定义
    ---- 1、在Interface的Uses节增加IniFiles; 
    ---- 2、在Var变量定义部分增加一行:        myinifile:Tinifile;---- 然后,就可以对变量myinifile进行创建、打开、读取、写入等操作了。 
    三、打开INI文件
        myinifile:=Tinifile.create('program.ini');---- 上面这一行语句将会为变量myinifile与具体的文件 program.ini建立联系,然后,就可以通过变量myinifile,来读写program.ini文件中的关键字的值了。 
    ---- 值得注意的是,如果括号中的文件名没有指明路径的话,那么这个Program.ini文件会存储在Windows目录中,把Program.ini文件存储在应用程序当前目录中的方法是:为其指定完整的路径及文件名。下面的两条语句可以完成这个功能: Filename:=ExtractFilePath(Paramstr(0))+'program.ini';
    myinifile:=Tinifile.Create(filename);四、读取关键字的值
    ---- 针对INI文件支持的字符串、整型数值、布尔值三种数据类型,TINIfiles类提供了三种不同的对象方法来读取INI文件中关键字的值。 
    ---- 假设已定义变量vs、vi、vb分别为string、 integer、boolean类型。 vs:=myinifile.Readstring
    ('小节名','关键字',缺省值);
    vi:=myinifile.Readinteger
    ('小节名','关键字',缺省值);
    vb:=myinifile.Readbool
    ('小节名','关键字',缺省值);---- 其中缺省值为该INI文件不存在该关键字时返回的缺省值。 
    五、写入INI文件
    ---- 同样的,TInifile类也提供了三种不同的对象方法,向INI文件写入字符串、整型数及布尔类型的关键字。 
    myinifile.writestring('小节名','关键字',变量或字符串值);
    myinifile.writeinteger('小节名','关键字',变量或整型数值);
    myinifile.writebool('小节名','关键字',变量或True或False);---- 当这个INI文件不存在时,上面的语句还会自动创建该INI文件。 
    六、删除关键字
    ---- 除了可用写入方法增加一个关键字,Tinifile类还提供了一个删除关键字的对象方法: 
    myinifile.DeleteKey('小节名','关键字');七、小节操作
    ---- 增加一个小节可用写入的方法来完成,删除一个小节可用下面的对象方法: 
        myinifile.EraseSection('小节名');---- 另外Tinifile类还提供了三种对象方法来对小节进行操作: 
    ---- myinifile.readsection('小节名',TStrings变量);可将指定小节中的所有关键字名读取至一个字符串列表变量中; ---- myinifile.readsections(TStrings变量);可将INI文件中所有小节名读取至一个字符串列表变量中去。 ---- myinifile.readsectionvalues('小节名',TStrings变量);可将INI文件中指定小节的所有行(包括关键字、=、值)读取至一个字符串列表变量中去。 八、释放
    在适当的位置用下面的语句释放myinifile:
        myinifile.distory;九、一个实例
    ---- 下面用一个简单的例子(如图),演示了建立、读取、存贮INI文件的方法。myini.ini文件中包含有“程序参数”小节,和用户名称(字符串)、是否正式用户(布尔值)和已运行时间(整型值)三个关键字。程序在窗体建立读取这些数据,并在窗体释放时写myini.ini文件。 
    ---- 附源程序清单 unit Unit1;
    interface
    uses
    Windows, Messages, SysUtils, Classes, Graphics, 
    Controls, Forms, Dialogs,inifiles,StdCtrls, ExtCtrls;
    type
      TForm1 = class(TForm)
        Edit1: TEdit;
        CheckBox1: TCheckBox;
        Edit2: TEdit;
        Label1: TLabel;
        Label2: TLabel;
        Timer1: TTimer;
        Label3: TLabel;
        procedure FormCreate(Sender: TObject);
        procedure FormDestroy(Sender: TObject);
        procedure Timer1Timer(Sender: TObject);
      private
        { Private declarations }
      public
        { Public declarations }
      end;
    var
      Form1: TForm1;implementation
    var
      myinifile:TInifile;
    {$R *.DFM}procedure TForm1.FormCreate(Sender: TObject);
    var
      filename:string;
    begin
      filename:=ExtractFilePath(paramstr(0))+'myini.ini';
      myinifile:=TInifile.Create(filename);
      edit1.Text:= myinifile.readstring
    ('程序参数','用户名称','缺省的用户名称');
      edit2.text:= inttostr(myinifile.readinteger
    ('程序参数','已运行时间',0));
      checkbox1.Checked:= myinifile.readbool
    ('程序参数','是否正式用户',False);
    end;procedure TForm1.FormDestroy(Sender: TObject);
    begin
      myinifile.writestring('程序参数','用户名称',edit1.Text);
      myinifile.writeinteger('程序参数','已运行时间',
    strtoint(edit2.text));
      myinifile.writebool('程序参数','是否正式用户',
    checkbox1.Checked);
      myinifile.Destroy;
    end;procedure TForm1.Timer1Timer(Sender: TObject);
    begin
      edit2.Text:=inttostr(strtoint(edit2.text)+1);
    end;end.
    转贴的,应该有所帮助!
      

  8.   

    讀INI文件
    procedure TMultiForm.FormCreate(Sender: TObject);
    var
     LOCINI:TINIFILE;
    BEGIN
       GETDIR(0,PATH);
       LOCINI:=TINIFILE.Create(PATH+'\SFIS.INI');
       try
        G_USER:=LOCINI.ReadString('OLEDB','USER','');
        G_PASSWORD:=LOCINI.ReadString('OLEDB','PASSWORD','');
        G_DB:=LOCINI.ReadString('OLEDB','DB','');
       finally
         Locini.Free;
       end;
    end;連結數據庫
    PROCEDURE TMultiForm.dbopen ;//FROM SHOW連接數據庫
    BEGIN
       TRY
          ADODB.Close;
          ADODB.Connected :=FALSE;
          ADODB.ConnectionString :='Provider=MSDAORA.1;Password='''+G_PASSWORD+''';User ID='''+G_USER+''';Data Source='''+G_DB+''';Persist Security Info=True';
          adodb.LoginPrompt :=false;
          ADODB.Connected :=TRUE;
          ADODB.Open;
       EXCEPT
          Showmessage('連接數據庫失敗,請重新打開');
          MultiForm.Enabled :=false;
          CheckRdF.Enabled :=false;
          ChckColor.Enabled :=false;
        END;
    END;
      

  9.   

    function TDATAmodule.LoadConnectInfo: boolean;
    var
      vIni:TIniFile;
      vDBNAME:string;
    begin
      Result:=False;
      vIni:=TIniFile.Create('d:\sam\sys.ini');
      vSERVERNAME:=vIni.ReadString( 'Option','DBServer','');
      vDBNAME:=vIni.ReadString( 'Option','SysDBName','');
      vIni.Free;
      try
        Database1.Connected:=False;
        Database1.Params.Values['DATABASE NAME']:=vDBNAME;
        Database1.Params.Values['SERVER NAME']:=vSERVERNAME;
        Database1.Connected:=True;
        Result:=true;
      except
        Result:=False;
      end;
    end;这是我常用的一个用ini文件存取数据库配置文件的方法。 我用的是sql server数据库
    其中的vservername和vdbname分别为数据库的服务器名称和数据库名称不过我这个没有加密