INI 파일 읽기/쓰기
에 클래스가 있습니까?표준 .ini 파일을 읽고 쓸 수 있는 NET 프레임워크:
[Section]
<keyname>=<value>
...
는 델파는이를 가지고 .TIniFile구성 요소와 C#과 유사한 것이 있는지 알고 싶습니다.
서문
먼저 INI 파일의 한계에 대한 이 MSDN 블로그 게시물을 읽으십시오.당신의 필요에 맞으면 계속 읽으세요.
이는 원본 Windows P/Invoke를 사용하여 작성한 간결한 구현이므로 모든 Windows 버전에서 지원됩니다.NET이 설치되었습니다(예: Windows 98 - Windows 11).이에 따라 퍼블릭 도메인에 공개합니다. 귀하는 귀속 없이 자유롭게 상업적으로 사용할 수 있습니다.
극소수 계층
▁called다라는 새로운 합니다.IniFile.cs프로젝트:
using System.IO;
using System.Reflection;
using System.Runtime.InteropServices;
using System.Text;
// Change this to match your program's normal namespace
namespace MyProg
{
class IniFile // revision 11
{
string Path;
string EXE = Assembly.GetExecutingAssembly().GetName().Name;
[DllImport("kernel32", CharSet = CharSet.Unicode)]
static extern long WritePrivateProfileString(string Section, string Key, string Value, string FilePath);
[DllImport("kernel32", CharSet = CharSet.Unicode)]
static extern int GetPrivateProfileString(string Section, string Key, string Default, StringBuilder RetVal, int Size, string FilePath);
public IniFile(string IniPath = null)
{
Path = new FileInfo(IniPath ?? EXE + ".ini").FullName;
}
public string Read(string Key, string Section = null)
{
var RetVal = new StringBuilder(255);
GetPrivateProfileString(Section ?? EXE, Key, "", RetVal, 255, Path);
return RetVal.ToString();
}
public void Write(string Key, string Value, string Section = null)
{
WritePrivateProfileString(Section ?? EXE, Key, Value, Path);
}
public void DeleteKey(string Key, string Section = null)
{
Write(Key, null, Section ?? EXE);
}
public void DeleteSection(string Section = null)
{
Write(null, null, Section ?? EXE);
}
public bool KeyExists(string Key, string Section = null)
{
return Read(Key, Section).Length > 0;
}
}
}
사용방법
다음 세 가지 방법 중 하나로 INI 파일을 엽니다.
// Creates or loads an INI file in the same directory as your executable
// named EXE.ini (where EXE is the name of your executable)
var MyIni = new IniFile();
// Or specify a specific name in the current dir
var MyIni = new IniFile("Settings.ini");
// Or specify a specific name in a specific dir
var MyIni = new IniFile(@"C:\Settings.ini");
다음과 같은 값을 쓸 수 있습니다.
MyIni.Write("DefaultVolume", "100");
MyIni.Write("HomePage", "http://www.google.com");
다음과 같은 파일을 만드는 방법
[MyProg]
DefaultVolume=100
HomePage=http://www.google.com
INI 파일에서 값을 읽으려면:
var DefaultVolume = MyIni.Read("DefaultVolume");
var HomePage = MyIni.Read("HomePage");
선택적으로 설정할 수 있습니다.[Section]의:
MyIni.Write("DefaultVolume", "100", "Audio");
MyIni.Write("HomePage", "http://www.google.com", "Web");
다음과 같은 파일을 만드는 방법
[Audio]
DefaultVolume=100
[Web]
HomePage=http://www.google.com
다음과 같은 키가 있는지 확인할 수도 있습니다.
if(!MyIni.KeyExists("DefaultVolume", "Audio"))
{
MyIni.Write("DefaultVolume", "100", "Audio");
}
다음과 같은 키를 삭제할 수 있습니다.
MyIni.DeleteKey("DefaultVolume", "Audio");
다음과 같이 전체 섹션(모든 키 포함)을 삭제할 수도 있습니다.
MyIni.DeleteSection("Web");
개선 사항이 있으시면 언제든지 의견을 말씀해 주십시오!
의 작성자.NET Framework에서는 INI 파일 대신 XML 기반 구성 파일을 사용하도록 합니다.그래서 아니요, 그것들을 읽기 위한 내장된 메커니즘은 없습니다.
그러나 타사 솔루션을 사용할 수 있습니다.
- INI 핸들러는 INI 파서와 같은 NuGet 패키지로 가져올 수 있습니다.
- 당신은 당신만의 INI 핸들러를 쓸 수 있습니다. 이것은 구식이고 힘든 방법입니다.이를 통해 구현에 대한 통제력을 강화할 수 있으며, 이를 나쁜 일이나 좋은 일에 사용할 수 있습니다.C#, P/Invoke 및 Win32를 사용하는 INI 파일 처리 클래스를 참조하십시오.
CodeProject "C#을 사용하는 INI 파일 처리 클래스"에 대한 이 문서는 도움이 될 것입니다.
작성자는 커널32.dll의 두 가지 함수를 노출하는 C# 클래스 "Ini"를 만들었습니다.다음과 같습니다.WritePrivateProfileString그리고.GetPrivateProfileString은 두의 네임스페이스가 입니다.System.Runtime.InteropServices그리고.System.Text.
Ini 클래스를 사용하는 단계
프로젝트 네임스페이스 정의에서 추가
using INI;
다음과 같은 INI 파일 만들기
INIFile ini = new INIFile("C:\\test.ini");
사용하다IniWriteValue새 사용합니다.IniReadValue특정 섹션의 키에서 값을 읽습니다.
참고: 처음부터 시작하는 경우 다음 MSDN 기사를 읽을 수 있습니다.방법: C# 프로젝트에 응용 프로그램 구성 파일을 추가합니다.응용 프로그램을 구성하는 더 좋은 방법입니다.
저는 다음과 같은 간단한 구현을 발견했습니다.
http://bytes.com/topic/net/insights/797169-reading-parsing-ini-file-c
내가 필요로 하는 것에 잘 작동합니다.
사용 방법은 다음과 같습니다.
public class TestParser
{
public static void Main()
{
IniParser parser = new IniParser(@"C:\test.ini");
String newMessage;
newMessage = parser.GetSetting("appsettings", "msgpart1");
newMessage += parser.GetSetting("appsettings", "msgpart2");
newMessage += parser.GetSetting("punctuation", "ex");
//Returns "Hello World!"
Console.WriteLine(newMessage);
Console.ReadLine();
}
}
코드는 다음과 같습니다.
using System;
using System.IO;
using System.Collections;
public class IniParser
{
private Hashtable keyPairs = new Hashtable();
private String iniFilePath;
private struct SectionPair
{
public String Section;
public String Key;
}
/// <summary>
/// Opens the INI file at the given path and enumerates the values in the IniParser.
/// </summary>
/// <param name="iniPath">Full path to INI file.</param>
public IniParser(String iniPath)
{
TextReader iniFile = null;
String strLine = null;
String currentRoot = null;
String[] keyPair = null;
iniFilePath = iniPath;
if (File.Exists(iniPath))
{
try
{
iniFile = new StreamReader(iniPath);
strLine = iniFile.ReadLine();
while (strLine != null)
{
strLine = strLine.Trim().ToUpper();
if (strLine != "")
{
if (strLine.StartsWith("[") && strLine.EndsWith("]"))
{
currentRoot = strLine.Substring(1, strLine.Length - 2);
}
else
{
keyPair = strLine.Split(new char[] { '=' }, 2);
SectionPair sectionPair;
String value = null;
if (currentRoot == null)
currentRoot = "ROOT";
sectionPair.Section = currentRoot;
sectionPair.Key = keyPair[0];
if (keyPair.Length > 1)
value = keyPair[1];
keyPairs.Add(sectionPair, value);
}
}
strLine = iniFile.ReadLine();
}
}
catch (Exception ex)
{
throw ex;
}
finally
{
if (iniFile != null)
iniFile.Close();
}
}
else
throw new FileNotFoundException("Unable to locate " + iniPath);
}
/// <summary>
/// Returns the value for the given section, key pair.
/// </summary>
/// <param name="sectionName">Section name.</param>
/// <param name="settingName">Key name.</param>
public String GetSetting(String sectionName, String settingName)
{
SectionPair sectionPair;
sectionPair.Section = sectionName.ToUpper();
sectionPair.Key = settingName.ToUpper();
return (String)keyPairs[sectionPair];
}
/// <summary>
/// Enumerates all lines for given section.
/// </summary>
/// <param name="sectionName">Section to enum.</param>
public String[] EnumSection(String sectionName)
{
ArrayList tmpArray = new ArrayList();
foreach (SectionPair pair in keyPairs.Keys)
{
if (pair.Section == sectionName.ToUpper())
tmpArray.Add(pair.Key);
}
return (String[])tmpArray.ToArray(typeof(String));
}
/// <summary>
/// Adds or replaces a setting to the table to be saved.
/// </summary>
/// <param name="sectionName">Section to add under.</param>
/// <param name="settingName">Key name to add.</param>
/// <param name="settingValue">Value of key.</param>
public void AddSetting(String sectionName, String settingName, String settingValue)
{
SectionPair sectionPair;
sectionPair.Section = sectionName.ToUpper();
sectionPair.Key = settingName.ToUpper();
if (keyPairs.ContainsKey(sectionPair))
keyPairs.Remove(sectionPair);
keyPairs.Add(sectionPair, settingValue);
}
/// <summary>
/// Adds or replaces a setting to the table to be saved with a null value.
/// </summary>
/// <param name="sectionName">Section to add under.</param>
/// <param name="settingName">Key name to add.</param>
public void AddSetting(String sectionName, String settingName)
{
AddSetting(sectionName, settingName, null);
}
/// <summary>
/// Remove a setting.
/// </summary>
/// <param name="sectionName">Section to add under.</param>
/// <param name="settingName">Key name to add.</param>
public void DeleteSetting(String sectionName, String settingName)
{
SectionPair sectionPair;
sectionPair.Section = sectionName.ToUpper();
sectionPair.Key = settingName.ToUpper();
if (keyPairs.ContainsKey(sectionPair))
keyPairs.Remove(sectionPair);
}
/// <summary>
/// Save settings to new file.
/// </summary>
/// <param name="newFilePath">New file path.</param>
public void SaveSettings(String newFilePath)
{
ArrayList sections = new ArrayList();
String tmpValue = "";
String strToSave = "";
foreach (SectionPair sectionPair in keyPairs.Keys)
{
if (!sections.Contains(sectionPair.Section))
sections.Add(sectionPair.Section);
}
foreach (String section in sections)
{
strToSave += ("[" + section + "]\r\n");
foreach (SectionPair sectionPair in keyPairs.Keys)
{
if (sectionPair.Section == section)
{
tmpValue = (String)keyPairs[sectionPair];
if (tmpValue != null)
tmpValue = "=" + tmpValue;
strToSave += (sectionPair.Key + tmpValue + "\r\n");
}
}
strToSave += "\r\n";
}
try
{
TextWriter tw = new StreamWriter(newFilePath);
tw.Write(strToSave);
tw.Close();
}
catch (Exception ex)
{
throw ex;
}
}
/// <summary>
/// Save settings back to ini file.
/// </summary>
public void SaveSettings()
{
SaveSettings(iniFilePath);
}
}
joorage의 대답에 있는 코드는 영감을 줍니다.
유감스럽게도 키의 문자 케이스를 변경하고 주석을 처리하지 않습니다.그래서 저는 매우 더러운 INI 파일을 읽을 수 있을 정도로 강력하고 키를 있는 그대로 검색할 수 있는 것을 만들었습니다.
섹션, 키 및 값을 저장하고 파일을 한 번에 읽기 위해 중첩된 대소문자 구분 없는 문자열 사전인 일부 LINQ를 사용합니다.
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
class IniReader
{
Dictionary<string, Dictionary<string, string>> ini = new Dictionary<string, Dictionary<string, string>>(StringComparer.InvariantCultureIgnoreCase);
public IniReader(string file)
{
var txt = File.ReadAllText(file);
Dictionary<string, string> currentSection = new Dictionary<string, string>(StringComparer.InvariantCultureIgnoreCase);
ini[""] = currentSection;
foreach(var line in txt.Split(new[]{"\n"}, StringSplitOptions.RemoveEmptyEntries)
.Where(t => !string.IsNullOrWhiteSpace(t))
.Select(t => t.Trim()))
{
if (line.StartsWith(";"))
continue;
if (line.StartsWith("[") && line.EndsWith("]"))
{
currentSection = new Dictionary<string, string>(StringComparer.InvariantCultureIgnoreCase);
ini[line.Substring(1, line.LastIndexOf("]") - 1)] = currentSection;
continue;
}
var idx = line.IndexOf("=");
if (idx == -1)
currentSection[line] = "";
else
currentSection[line.Substring(0, idx)] = line.Substring(idx + 1);
}
}
public string GetValue(string key)
{
return GetValue(key, "", "");
}
public string GetValue(string key, string section)
{
return GetValue(key, section, "");
}
public string GetValue(string key, string section, string @default)
{
if (!ini.ContainsKey(section))
return @default;
if (!ini[section].ContainsKey(key))
return @default;
return ini[section][key];
}
public string[] GetKeys(string section)
{
if (!ini.ContainsKey(section))
return new string[0];
return ini[section].Keys.ToArray();
}
public string[] GetSections()
{
return ini.Keys.Where(t => t != "").ToArray();
}
}
저는 제가 c#로 완전히 만든 IniParser 라이브러리를 소개하고 싶습니다. 그래서 그것은 어떤 OS에도 종속성이 없기 때문에 모노 호환이 가능합니다.MIT 라이센스가 있는 오픈 소스 - 모든 코드에서 사용할 수 있습니다.
GitHub에서 소스를 확인할 수 있으며, NuGet 패키지로도 사용할 수 있습니다.
뻔뻔스럽게 플러그를 꽂아서 미안하지만 이 답변을 다시 방문하는 사람들에게 도움이 되기를 바랍니다.
하지 않은 , 그리고 이 읽기액세는필않경사지우중용인며를 .Microsoft.Extensions.Confiuration기본적으로 ASP와 함께 번들로 제공됩니다.NET Core이지만 일반 프로그램과도 작동합니다.) NuGet 패키지를 사용하여 ini 파일을 구성 설정으로 가져올 수 있습니다.
public Startup(IHostingEnvironment env)
{
var builder = new ConfigurationBuilder()
.SetBasePath(env.ContentRootPath)
.AddIniFile("SomeConfig.ini", optional: false);
Configuration = builder.Build();
}
땅콩버터.INI는 INI 파일 조작을 위한 Nuget 패키지 클래스입니다.주석을 포함한 읽기/쓰기를 지원합니다. 주석은 쓰기 시 보존됩니다.그것은 상당히 인기 있고, 테스트되고, 사용하기 쉬운 것으로 보입니다.그것은 또한 완전히 자유롭고 오픈 소스입니다.
고지 사항:저는 피넛버터의 저자입니다.INI.
일반적으로 C# 및 를 사용하여 응용 프로그램을 생성할 때 사용합니다.NET 프레임워크. INI 파일을 사용할 수 없습니다.설정은 XML 기반 구성 파일 또는 레지스트리에 저장하는 것이 일반적입니다.그러나 소프트웨어가 기존 응용 프로그램과 설정을 공유하는 경우 다른 곳에서 정보를 복제하는 대신 구성 파일을 사용하는 것이 더 쉬울 수 있습니다.
.NET 프레임워크는 INI 파일을 직접 사용할 수 없습니다.그러나 플랫폼 호출 서비스(P/Invoke)와 함께 Windows API 기능을 사용하여 파일에 쓰고 파일에서 읽을 수 있습니다.이 링크에서 우리는 INI 파일을 나타내는 클래스를 만들고 Windows API 함수를 사용하여 파일을 조작합니다.다음 링크를 통해 확인해 주십시오.
섹션이 없고 다른 dll이 없는 단순한 판독기를 원한다면 간단한 해결책이 있습니다.
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace Tool
{
public class Config
{
Dictionary <string, string> values;
public Config (string path)
{
values = File.ReadLines(path)
.Where(line => (!String.IsNullOrWhiteSpace(line) && !line.StartsWith("#")))
.Select(line => line.Split(new char[] { '=' }, 2, 0))
.ToDictionary(parts => parts[0].Trim(), parts => parts.Length>1?parts[1].Trim():null);
}
public string Value (string name, string value=null)
{
if (values!=null && values.ContainsKey(name))
{
return values[name];
}
return value;
}
}
}
사용 샘플:
file = new Tool.Config (Path.GetDirectoryName(System.Reflection.Assembly.GetExecutingAssembly().Location) + "\\config.ini");
command = file.Value ("command");
action = file.Value ("action");
string value;
//second parameter is default value if no key found with this name
value = file.Value("debug","true");
this.debug = (value.ToLower()=="true" || value== "1");
value = file.Value("plain", "false");
this.plain = (value.ToLower() == "true" || value == "1");
한편, 파일 내용 구성(표시된 대로 라인 주석에 # 기호 지원):
#command to run
command = php
#default script
action = index.php
#debug mode
#debug = true
#plain text mode
#plain = false
#icon = favico.ico
다음 방법을 사용해 보십시오.
public static Dictionary<string, string> ParseIniDataWithSections(string[] iniData)
{
var dict = new Dictionary<string, string>();
var rows = iniData.Where(t =>
!String.IsNullOrEmpty(t.Trim()) && !t.StartsWith(";") && (t.Contains('[') || t.Contains('=')));
if (rows == null || rows.Count() == 0) return dict;
string section = "";
foreach (string row in rows)
{
string rw = row.TrimStart();
if (rw.StartsWith("["))
section = rw.TrimStart('[').TrimEnd(']');
else
{
int index = rw.IndexOf('=');
dict[section + "-" + rw.Substring(0, index).Trim()] = rw.Substring(index+1).Trim().Trim('"');
}
}
return dict;
}
키가 "-"인 사전을 만듭니다.다음과 같이 로드할 수 있습니다.
var dict = ParseIniDataWithSections(File.ReadAllLines(fileName));
입당이 늦었지만 오늘도 같은 문제가 있었고 다음과 같은 실행문을 작성했습니다.
using System.Text.RegularExpressions;
static bool match(this string str, string pat, out Match m) =>
(m = Regex.Match(str, pat, RegexOptions.IgnoreCase)).Success;
static void Main()
{
Dictionary<string, Dictionary<string, string>> ini = new Dictionary<string, Dictionary<string, string>>();
string section = "";
foreach (string line in File.ReadAllLines(.........)) // read from file
{
string ln = (line.Contains('#') ? line.Remove(line.IndexOf('#')) : line).Trim();
if (ln.match(@"^[ \t]*\[(?<sec>[\w\-]+)\]", out Match m))
section = m.Groups["sec"].ToString();
else if (ln.match(@"^[ \t]*(?<prop>[\w\-]+)\=(?<val>.*)", out m))
{
if (!ini.ContainsKey(section))
ini[section] = new Dictionary<string, string>();
ini[section][m.Groups["prop"].ToString()] = m.Groups["val"].ToString();
}
}
// access the ini file as follows:
string content = ini["section"]["property"];
}
이 구현에서는 찾을 수 없는 섹션 또는 속성을 처리하지 않습니다.이를 위해 다음을 확장해야 합니다.Dictionary<,>-class를 사용하여 찾을 수 없는 키를 처리합니다.
의 인스턴스를 일련화하려면 다음과 같이 하십시오.Dictionary<string, Dictionary<string, string>>완전히.ini-file, 저는 다음 코드를 사용합니다.
string targetpath = .........;
Dictionary<string, Dictionary<string, string>> ini = ........;
StringBuilder sb = new StringBuilder();
foreach (string section in ini.Keys)
{
sb.AppendLine($"[{section}]");
foreach (string property in ini[section].Keys)
sb.AppendLine($"{property}={ini[section][property]");
}
File.WriteAllText(targetpath, sb.ToString());
Common Library에는 Ini Parser가 있습니다.NET
이는 단면/값을 얻기 위한 다양한 매우 편리한 과부하를 가지며 매우 가벼운 무게입니다.
정규 표현을 사용한 저만의 버전이 있습니다.이 코드는 각 섹션 이름이 고유하다고 가정하지만, 그렇지 않은 경우 사전을 목록으로 대체해야 합니다.이 함수는 ';' 문자로 시작하는 .ini 파일 주석을 지원합니다.섹션은 일반적으로 [섹션]으로 시작하고 키 값 쌍도 일반적으로 "key = value"로 표시됩니다.섹션의 경우와 동일한 가정 - 키 이름이 고유합니다.
/// <summary>
/// Loads .ini file into dictionary.
/// </summary>
public static Dictionary<String, Dictionary<String, String>> loadIni(String file)
{
Dictionary<String, Dictionary<String, String>> d = new Dictionary<string, Dictionary<string, string>>();
String ini = File.ReadAllText(file);
// Remove comments, preserve linefeeds, if end-user needs to count line number.
ini = Regex.Replace(ini, @"^\s*;.*$", "", RegexOptions.Multiline);
// Pick up all lines from first section to another section
foreach (Match m in Regex.Matches(ini, "(^|[\r\n])\\[([^\r\n]*)\\][\r\n]+(.*?)(\\[([^\r\n]*)\\][\r\n]+|$)", RegexOptions.Singleline))
{
String sectionName = m.Groups[2].Value;
Dictionary<String, String> lines = new Dictionary<String, String>();
// Pick up "key = value" kind of syntax.
foreach (Match l in Regex.Matches(ini, @"^\s*(.*?)\s*=\s*(.*?)\s*$", RegexOptions.Multiline))
{
String key = l.Groups[1].Value;
String value = l.Groups[2].Value;
// Open up quotation if any.
value = Regex.Replace(value, "^\"(.*)\"$", "$1");
if (!lines.ContainsKey(key))
lines[key] = value;
}
if (!d.ContainsKey(sectionName))
d[sectionName] = lines;
}
return d;
}
벨과 호루라기(섹션)가 필요 없는 경우 다음과 같은 라이너가 있습니다.
List<(string, string)> ini = File.ReadLines(filename)
.Select(s => {
var spl = s.Split('=', 2);
return spl.Length == 2 ? (spl[0], spl[1]) : (s, "");
})
.Select(vt => (vt.Item1.Trim(), vt.Item2.Trim()))
.Where(vt => vt.Item1 != "")
.ToList();
쓰기:
File.WriteAllLines(filename, ini.Select(vt => $"{vt.Item1}={vt.Item2}"));
(중복에 대해 신경 쓰지 않는 경우 사용).ToDictionary()대신에.ToList()더 쉽게 액세스할 수 있음)
여기 제 수업이 있습니다. 매력적으로 작동합니다.
public static class IniFileManager
{
[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);
[DllImport("kernel32.dll")]
private static extern int GetPrivateProfileSection(string lpAppName,
byte[] lpszReturnBuffer, int nSize, string lpFileName);
/// <summary>
/// Write Data to the INI File
/// </summary>
/// <PARAM name="Section"></PARAM>
/// Section name
/// <PARAM name="Key"></PARAM>
/// Key Name
/// <PARAM name="Value"></PARAM>
/// Value Name
public static void IniWriteValue(string sPath,string Section, string Key, string Value)
{
WritePrivateProfileString(Section, Key, Value, sPath);
}
/// <summary>
/// Read Data Value From the Ini File
/// </summary>
/// <PARAM name="Section"></PARAM>
/// <PARAM name="Key"></PARAM>
/// <PARAM name="Path"></PARAM>
/// <returns></returns>
public static string IniReadValue(string sPath,string Section, string Key)
{
StringBuilder temp = new StringBuilder(255);
int i = GetPrivateProfileString(Section, Key, "", temp,
255, sPath);
return temp.ToString();
}
}
정적 클래스이므로 IniFileManager를 호출하면 됩니다.섹션 또는 IniFileManager를 읽기 위한 IniWriteValue입니다.섹션을 읽기 위한 IniReadValue입니다.
전체 개체를 xml에 저장할 수 있고 저장된 xml에서 개체를 채울 수 있으므로 xml 파일에서 데이터를 읽고 써야 합니다.물체를 조작하는 것이 더 쉽습니다.
방법은 다음과 같습니다. XML 파일에 개체 데이터 쓰기: https://msdn.microsoft.com/en-us/library/ms172873.aspx XML 파일에서 개체 데이터 읽기: https://msdn.microsoft.com/en-us/library/ms172872.aspx
언급URL : https://stackoverflow.com/questions/217902/reading-writing-an-ini-file
'programing' 카테고리의 다른 글
| Xcode 5에 iOS 6 SDK를 설치할 수 있습니까? (0) | 2023.05.14 |
|---|---|
| Xcode9 iOS11 앱 릴리스에 CFBundleIconName 누락 (0) | 2023.05.14 |
| 잠재적으로 위험한 요청입니다.클라이언트에서 양식 값이 탐지되었습니다. (0) | 2023.05.14 |
| Azure 서브스크립션 ID, AAD 테넌트 ID 및 AAD App Client ID가 비밀/PII로 간주됩니까? (0) | 2023.05.14 |
| Mongoose/MongoDB 결과 필드가 Javascript에서 정의되지 않은 것으로 나타납니다. (0) | 2023.05.14 |