从连接字符串中获取用户名和密码的正确方法是什么?

24

我有一个这样的连接字符串:

"SERVER=localhost;DATABASE=tree;UID=root;PASSWORD=branch;Min Pool Size = 0;Max Pool Size=200"

我该如何获取数据库中的各种参数?我可以像下面这样获取数据库名和服务器:

serverName = conObject.DataSource;
dbName = conObject.Database;

我同样需要用户名和密码,但是MySqlConnection对象上没有设置相关属性。

目前我的做法是这样的:

public static void GetDatabaseParameters(string connectionString, out string serverName, out string dbName, out string userName, out string password)
{
    Match m = Regex.Match(connectionString, "SERVER=(.*?);DATABASE=(.*?);UID=(.*?);PASSWORD=(.*?);.*");

    //serverName = m.Groups[1].Value;
    //dbName = m.Groups[2].Value;
    userName = m.Groups[3].Value;
    password = m.Groups[4].Value;
}

这里是否有公认的惯例?

1个回答

62
你可以使用 SqlConnectionStringBuilder 类。
string conString = "SERVER=localhost;DATABASE=tree;UID=root;PASSWORD=branch;Min Pool Size = 0;Max Pool Size=200";
SqlConnectionStringBuilder builder = new SqlConnectionStringBuilder(conString);
string user = builder.UserID;
string pass = builder.Password;

这对MySQL也适用吗? - nawfal
1
如果您使用特殊的.NET组件来连接MySQL,那么应该使用特定的ConnectionStringBuilder,例如MySqlConnectionStringBuilder。 - Devart
1
如果你有一个MySqlConnectionStringBuilder类,它不是框架的默认部分,那么就可以了。在这里看 http://forums.mysql.com/read.php?38,60345 - krystan honour
如何从中获取DatabaseName,我在构建器中没有找到任何类似的属性? - Imran Rizvi
@ImranRizvi builder.Database 会为 MySQL 连接器提供它。 - nawfal
似乎在.NET Core中仍然可以工作。 - Chaim Eliyah

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接