如何编写正则表达式以从连接字符串中检索密码。
连接字符串是这样的:
USER ID=system;PASSWORD = ab;DATA ..
或
USER ID=system;PASSWORD=ab;DATA ...
或
USER ID=system;PASSWORD =ab;DATA...
或
USER ID=system;PASSWORD= ab;DATA ...
尝试使用ConnectionStringBuilder的方法。适用于SQL Server。但是在Oracle的情况下它抛出了这个异常:
Invalid length for connection option 'Data Source', maximum length is 128.
Oracle连接字符串:
USER ID=sa;PASSWORD=abc;DATA SOURCE="(DESCRIPTION =(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.1)(PORT = 8080))(CONNECT_DATA =(SERVER = DEDICATED)(SERVICE_NAME = Orcl)))"
答案 0 :(得分:9)
是否要求您使用正则表达式? .NET具有内置的功能:
var sb = new SqlConnectionStringBuilder("USER ID=system;PASSWORD =ab;");
Console.WriteLine(sb.Password);
这可能比使用正则表达式更强大。这些字段的规则相当全面,很容易制作适用于大多数连接字符串的正则表达式,但在某些情况下会失败。有关必须嵌入此类正则表达式的规则列表,请参阅the connection string rules。
答案 1 :(得分:1)
正则表达式:
.*PASSWORD[ ]*=[ ]*([^;]+)