我试图在C#中以编程方式创建一个UDL文件.在我的程序中,我想向用户显示数据链接属性窗口,但是我有自己的连接字符串默认值.我最初想过要做以下事情:
string[] lines = new string[]
{
"[oledb]",
"; Everything after this line is an OLE DB initstring",
"Provider=SQLOLEDB.1;Persist Security Info=False"
};
File.WriteAllLines("Test.udl", lines);
Process p = Process.Start("Test.udl");
p.WaitForExit();
但是,我在尝试打开文件时收到此错误:
File cannot be opened. Ensure it is a valid Data Link file.
这很奇怪,因为我创建了一个空文件,将其命名为something.udl,打开它,单击OK,然后打开文件的内容:
[oledb]
; Everything after this line is an OLE DB initstring
Provider=SQLOLEDB.1;Persist Security Info=False
但是在连接字符串的末尾有一个换行符.我使用KDiff来比较这个文件和我在程序中创建的文件,它说“文件是相同的文本,但它们不是二进制相等”或类似的东西.
我相信它与File.WriteAllLines方法如何写入字符串有关.所以我试图在方法中使用不同的编码,但没有成功.关于我哪里出错的任何想法?
我使用this MSDN link作为UDL文件的参考.还有一点值得注意的是,如果我打开一个新的文本文件并过去我的行数组中的所有行,我会得到同样的错误.
最佳答案 您需要做的就是使用Unicode编码:
File.WriteAllLines("Test.udl", lines, Encoding.Unicode);