天天看点

对INI文件的读写和ODBC的读取

最近公司的服务器要改公网的IP,我一听傻了,因为公司的POS系统的IP也要改,服务器当然没问题,但在外边的客户端就麻烦了。。我总不可能去全国游一圈来改IP吧。当然,公司不介意我也接受(旅游全国我也想了不是一天两天了:)),想想就决定做个软件修改客户端的IP就可以了。反正记录IP的文件是个INI文件,由于客户端用的是SYBASE,而且用ODBC连接,本来有个也挺简单的方法,就是遍历计算机找到这个文件来修改。但我觉得这样不爽,所以想通过ODBC找到INI的路径(在ODBC里看到有相关的KEY),然后通过对INI的操作修改其中记录IP的KEY值就可以了。很简单的一个程序,下面把关键代码写下,免得下次要做这些操作的时候又要上网到处找.

//读写INI的CLASS

using System;

using System.Text;

using System.Runtime.InteropServices;

//using Microsoft.Win32;

namespace updatePosIP

{

 /// <summary>

 /// execINI 的摘要说明。

 /// </summary>

 public class execINI

 {

//  public execINI()

//  {

//   //

//   // TODO: 在此处添加构造函数逻辑

//   //

//  }

  #region the ini file api function

  [DllImport("kernel32")]

  private static extern long WritePrivateProfileString(string section, string key, string val, string filePath);

  [DllImport("kernel32")]

  private static extern int GetPrivateProfileString(string section, string key, string defVal, StringBuilder retVal, int size, string filePath);

  [DllImport("kernel32")]

  private static extern int GetPrivateProfileString(string section, string key, string defVal, Byte[] retVal, int size, string filePath);

  #endregion

  private string Path;

  public execINI(string filePath)

  {

   this.Path = filePath;

  }

  /** <summary>

        /// 读取INI文件

        /// </summary>

        /// <param name="Section">段,格式[]</param>

        /// <param name="Key">键</param>

        /// <returns>返回byte类型的section组或键值组</returns>

        public byte[] IniReadValues(string section, string key)

        {

            byte[] temp = new byte[255];

            int i = GetPrivateProfileString(section, key, "", temp, 255, this.Path);

            return temp;

       }

    }

}

//读取ODBC中的路径值,如果要修改值找相关的方法就可以了,自己修改一下就行

using System;

using Microsoft.Win32;

namespace updatePosIP

{

 /// <summary>

 /// execODBC 的摘要说明。

 /// </summary>

 public class execODBC

 {

  public execODBC()

  {

   //

   // TODO: 在此处添加构造函数逻辑

   //

  }

  public static string readOdbc(string keyPath)

  {

//   string strOdbc = @"SOFTWARE/ODBC/ODBC.INI";

   RegistryKey rootkey,okey;

   rootkey = Registry.LocalMachine;

            okey = rootkey.OpenSubKey(keyPath);

   if(okey == null) return null;

   return okey.GetValue("DatabaseFile") == null? null:Convert.ToString(okey.GetValue("DatabaseFile"));

  }

 }

}

剩下就是用个FROM调用就可以了。