最近公司的服务器要改公网的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调用就可以了。