基于C#winform设计。
首先创建一个类,我命名为IniFiles。并引入命名空间using System.Runtime.InteropServices;
接着,声明API函数
[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 def, StringBuilder retVal, int size, string filePath);
写入INI函数方法
/// <summary>
/// 写入INI文件
/// </summary>
/// <param name="Section">项目名称(如 [TypeName] )</param>
/// <param name="Key">键</param>
/// <param name="Value">值</param>
public void IniWriteValue(string Section, string Key, string Value)
{
WritePrivateProfileString(Section, Key, Value, this.inipath);
}
读取INI文件方法
/// <summary>
/// 读出INI文件
/// </summary>
/// <param name="Section">项目名称(如 [TypeName] )</param>
/// <param name="Key">键</param>
public string IniReadValue(string Section, string Key)
{
StringBuilder temp = new StringBuilder(500);
int i = GetPrivateProfileString(Section, Key, "", temp, 500, this.inipath);
return temp.ToString();
}
验证文件是否存在
/// <summary>
/// 验证文件是否存在
/// </summary>
/// <returns>布尔值</returns>
public bool ExistINIFile()
{
return File.Exists(inipath);
}
在其他窗体页面如何条用?请看:
这时候是创建INI文件(位置一般处于资源文件下binDebug目录)
public partial class Frm_Login : Form
{
HotelSystemORM.Unitl.IniFiles ini = new HotelSystemORM.Unitl.IniFiles(Application.StartupPath + @"MyConfig.INI");//Application.StartupPath只适用于winform窗体程序
}
生成了文件之后就可以写入和读取信息了。
ini.IniWriteValue("登入详细", "账号", "test");
ini.IniWriteValue("登入详细", "密码", "password");
读取登入信息(页面加载的时候)
if (ini.ExistINIFile())//验证是否存在文件,存在就读取
label1.Text = ini.IniReadValue("登入详细", "用户名");
完成!
IniFiles类全部完整代码
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.IO;
using System.Runtime.InteropServices;
namespace WindowsFormsApplication1
{
public class IniFiles
{
public string inipath;
//声明API函数
[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 def, StringBuilder retVal, int size, string filePath);
/// <summary>
/// 构造方法
/// </summary>
/// <param name="INIPath">文件路径</param>
public IniFiles(string INIPath)
{
inipath = INIPath;
}
public IniFiles() { }
/// <summary>
/// 写入INI文件
/// </summary>
/// <param name="Section">项目名称(如 [TypeName] )</param>
/// <param name="Key">键</param>
/// <param name="Value">值</param>
public void IniWriteValue(string Section, string Key, string Value)
{
WritePrivateProfileString(Section, Key, Value, this.inipath);
}
/// <summary>
/// 读出INI文件
/// </summary>
/// <param name="Section">项目名称(如 [TypeName] )</param>
/// <param name="Key">键</param>
public string IniReadValue(string Section, string Key)
{
StringBuilder temp = new StringBuilder(500);
int i = GetPrivateProfileString(Section, Key, "", temp, 500, this.inipath);
return temp.ToString();
}
/// <summary>
/// 验证文件是否存在
/// </summary>
/// <returns>布尔值</returns>
public bool ExistINIFile()
{
return File.Exists(inipath);
}
}
}
页面调用:
1 public class INIOperationClass 2 { 3 4 #region INI文件操作 5 6 /* 7 * 针对INI文件的API操作方法,其中的节点(Section)、键(KEY)都不区分大小写 8 * 如果指定的INI文件不存在,会自动创建该文件。 9 * 10 * CharSet定义的时候使用了什么类型,在使用相关方法时必须要使用相应的类型 11 * 例如 GetPrivateProfileSectionNames声明为CharSet.Auto,那么就应该使用 Marshal.PtrToStringAuto来读取相关内容 12 * 如果使用的是CharSet.Ansi,就应该使用Marshal.PtrToStringAnsi来读取内容 13 * 14 */ 15 16 #region API声明 17 18 /// <summary> 19 /// 获取所有节点名称(Section) 20 /// </summary> 21 /// <param name="lpszReturnBuffer">存放节点名称的内存地址,每个节点之间用 分隔</param> 22 /// <param name="nSize">内存大小(characters)</param> 23 /// <param name="lpFileName">Ini文件</param> 24 /// <returns>内容的实际长度,为0表示没有内容,为nSize-2表示内存大小不够</returns> 25 [DllImport("kernel32.dll", CharSet = CharSet.Auto)] 26 private static extern uint GetPrivateProfileSectionNames(IntPtr lpszReturnBuffer, uint nSize, string lpFileName); 27 28 /// <summary> 29 /// 获取某个指定节点(Section)中所有KEY和Value 30 /// </summary> 31 /// <param name="lpAppName">节点名称</param> 32 /// <param name="lpReturnedString">返回值的内存地址,每个之间用 分隔</param> 33 /// <param name="nSize">内存大小(characters)</param> 34 /// <param name="lpFileName">Ini文件</param> 35 /// <returns>内容的实际长度,为0表示没有内容,为nSize-2表示内存大小不够</returns> 36 [DllImport("kernel32.dll", CharSet = CharSet.Auto)] 37 private static extern uint GetPrivateProfileSection(string lpAppName, IntPtr lpReturnedString, uint nSize, string lpFileName); 38 39 /// <summary> 40 /// 读取INI文件中指定的Key的值 41 /// </summary> 42 /// <param name="lpAppName">节点名称。如果为null,则读取INI中所有节点名称,每个节点名称之间用 分隔</param> 43 /// <param name="lpKeyName">Key名称。如果为null,则读取INI中指定节点中的所有KEY,每个KEY之间用 分隔</param> 44 /// <param name="lpDefault">读取失败时的默认值</param> 45 /// <param name="lpReturnedString">读取的内容缓冲区,读取之后,多余的地方使用 填充</param> 46 /// <param name="nSize">内容缓冲区的长度</param> 47 /// <param name="lpFileName">INI文件名</param> 48 /// <returns>实际读取到的长度</returns> 49 [DllImport("kernel32.dll", CharSet = CharSet.Auto)] 50 private static extern uint GetPrivateProfileString(string lpAppName, string lpKeyName, string lpDefault, [In, Out] char[] lpReturnedString, uint nSize, string lpFileName); 51 52 //另一种声明方式,使用 StringBuilder 作为缓冲区类型的缺点是不能接受 字符,会将 及其后的字符截断, 53 //所以对于lpAppName或lpKeyName为null的情况就不适用 54 [DllImport("kernel32.dll", CharSet = CharSet.Auto)] 55 private static extern uint GetPrivateProfileString(string lpAppName, string lpKeyName, string lpDefault, StringBuilder lpReturnedString, uint nSize, string lpFileName); 56 57 //再一种声明,使用string作为缓冲区的类型同char[] 58 [DllImport("kernel32.dll", CharSet = CharSet.Auto)] 59 private static extern uint GetPrivateProfileString(string lpAppName, string lpKeyName, string lpDefault, string lpReturnedString, uint nSize, string lpFileName); 60 61 /// <summary> 62 /// 将指定的键值对写到指定的节点,如果已经存在则替换。 63 /// </summary> 64 /// <param name="lpAppName">节点,如果不存在此节点,则创建此节点</param> 65 /// <param name="lpString">Item键值对,多个用 分隔,形如key1=value1 key2=value2 66 /// <para>如果为string.Empty,则删除指定节点下的所有内容,保留节点</para> 67 /// <para>如果为null,则删除指定节点下的所有内容,并且删除该节点</para> 68 /// </param> 69 /// <param name="lpFileName">INI文件</param> 70 /// <returns>是否成功写入</returns> 71 [DllImport("kernel32.dll", CharSet = CharSet.Auto)] 72 [return: MarshalAs(UnmanagedType.Bool)] //可以没有此行 73 private static extern bool WritePrivateProfileSection(string lpAppName, string lpString, string lpFileName); 74 75 /// <summary> 76 /// 将指定的键和值写到指定的节点,如果已经存在则替换 77 /// </summary> 78 /// <param name="lpAppName">节点名称</param> 79 /// <param name="lpKeyName">键名称。如果为null,则删除指定的节点及其所有的项目</param> 80 /// <param name="lpString">值内容。如果为null,则删除指定节点中指定的键。</param> 81 /// <param name="lpFileName">INI文件</param> 82 /// <returns>操作是否成功</returns> 83 [DllImport("kernel32.dll", CharSet = CharSet.Auto, SetLastError = true)] 84 [return: MarshalAs(UnmanagedType.Bool)] 85 private static extern bool WritePrivateProfileString(string lpAppName, string lpKeyName, string lpString, string lpFileName); 86 87 #endregion 88 89 #region 封装 90 91 /// <summary> 92 /// 读取INI文件中指定INI文件中的所有节点名称(Section) 93 /// </summary> 94 /// <param name="iniFile">Ini文件</param> 95 /// <returns>所有节点,没有内容返回string[0]</returns> 96 public static string[] INIGetAllSectionNames(string iniFile) 97 { 98 uint MAX_BUFFER = 32767; //默认为32767 99 100 string[] sections = new string[0]; //返回值 101 102 //申请内存 103 IntPtr pReturnedString = Marshal.AllocCoTaskMem((int)MAX_BUFFER * sizeof(char)); 104 uint bytesReturned = INIOperationClass.GetPrivateProfileSectionNames(pReturnedString, MAX_BUFFER, iniFile); 105 if (bytesReturned != 0) 106 { 107 //读取指定内存的内容 108 string local = Marshal.PtrToStringAuto(pReturnedString, (int)bytesReturned).ToString(); 109 110 //每个节点之间用 分隔,末尾有一个 111 sections = local.Split(new char[] { '