职业IT人-IT人生活圈

 找回密码
 成为会员
搜索
查看: 945|回复: 0

ASP.NET技巧:获取本机上配置好的Oracle服务名

[复制链接]
joe 发表于 2007-1-25 13:34 | 显示全部楼层 |阅读模式
/*
        获取Oracle服务名
        1。查询注册表,获取oracle安装根目录
            如:HKEY_LOCAL_MACHINE\\SOFTWARE\\ORACLE\\ORACLE_HOME   REG_SZ  E:\\ORACLE\\ORA92
            得知oracle服务名文件所在地:根目录\\network\\ADMIN\\tnsnames.ora
            
        2。解析该文件,该文件结构如
            # ------------------------------------------------
            PORTAL =
            (DESCRIPTION =
                (ADDRESS_LIST =
                (ADDRESS = (PROTOCOL = TCP)(HOST = 134.104.52.6)(PORT = 1521))
                )
                (CONNECT_DATA =
                (SERVICE_NAME = portal)
                )
            )

        3。解析要点:
            一行一行获取再解析
            跳过以#打头的注释行
            过滤掉空格后,首字符在A~z之间的行就包含了Oracle服务名
            截取该行第一个“=”号左边的字符串,trim处理后就是Oracle服务名了
        */
        public static string[] GetOracleTnsNames()
        {
            try
            {
                // 查询注册表,获取oracle服务文件路径
                RegistryKey key = Registry.LocalMachine.OpenSubKey(\"SOFTWARE\").OpenSubKey(\"ORACLE\");
                string home = (string)key.GetValue(\"ORACLE_HOME\");
                string file = home + @\"\\network\\ADMIN\\tnsnames.ora\";

                // 解析文件
                string line;
                ArrayList arr = new ArrayList();
                StreamReader sr = new StreamReader(file);
                while ((line = sr.ReadLine()) != null)
                {
                    line = line.Trim();
                    if (line != \"\")
                    {
                        char c = line[0];
                        if ( c>= \'A\' && c<=\'z\')
                            arr.Add(line.Substring(0, line.IndexOf(\' \')));
                    }
                }
                sr.Close();

                // 返回字符串数组
                return (string[])arr.ToArray(typeof(string));
            }
            catch (Exception ex)
            {
                return null;
            }
        }
您需要登录后才可以回帖 登录 | 成为会员

本版积分规则

QQ|手机版|小黑屋|网站帮助|职业IT人-IT人生活圈 ( 粤ICP备12053935号-1 )|网站地图
本站文章版权归原发布者及原出处所有。内容为作者个人观点,并不代表本站赞同其观点和对其真实性负责,本站只提供参考并不构成任何投资及应用建议。本站是信息平台,网站上部分文章为转载,并不用于任何商业目的,我们已经尽可能的对作者和来源进行了通告,但是能力有限或疏忽造成漏登,请及时联系我们,我们将根据著作权人的要求立即更正或者删除有关内容。

GMT+8, 2024-5-11 15:02 , Processed in 0.128592 second(s), 20 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表