zoukankan      html  css  js  c++  java
  • C#检验IIS版本、SQL Server版本、SilverLight版本

    之前做一个小项目,使用C#检验这些软件的版本,到处找了一些代码,也能作用,记录一下,以防以后用到。

    一、检验IIS版本

    public static bool checkIIS(string destVersion)
    {
                try
                {
                    RegistryKey rk = Registry.LocalMachine;
                    RegistryKey ver = rk.OpenSubKey(@"SOFTWAREMicrosoftInetStp");
                    int majorVersion = Convert.ToInt32(ver.GetValue("majorversion"));
                    int minorVersion = Convert.ToInt32(ver.GetValue("minorversion"));
                    Version versionStr = new Version(majorVersion + "." + minorVersion);
                    if (versionStr >= new Version(destVersion))
                        return true;
                    return false;
                }
                catch
                {
                    return false;
                }
    }

    二、检验SQL Server版本

    public static bool checkSQLServer(string destVersion)
            {
                RegistryKey localKey;
                if (Environment.Is64BitOperatingSystem)
                    localKey = RegistryKey.OpenBaseKey(RegistryHive.LocalMachine, RegistryView.Registry64);
                else
                    localKey = RegistryKey.OpenBaseKey(RegistryHive.LocalMachine, RegistryView.Registry32);
    
                RegistryKey sub = localKey.OpenSubKey(@"SOFTWAREMicrosoftMicrosoft SQL Server");
                object keyInst = null;
                if (sub != null)
                    keyInst = sub.GetValue("InstalledInstances");
    
                if (keyInst != null)
                {
                    try
                    {
                        Version SQLVer = null;
                        foreach (string str in (string[])keyInst)
                        {
                            RegistryKey subSQL = localKey.OpenSubKey(@"SOFTWAREMicrosoftMicrosoft SQL ServerInstance NamesSQL");
                            object keySQL = subSQL.GetValue(str);
                            RegistryKey subVer = localKey.OpenSubKey(@"SOFTWAREMicrosoftMicrosoft SQL Server" + (string)keySQL + @"Setup");
                            object keyVer = subVer.GetValue("Version");
                            //get version numer
                            SQLVer = new Version((string)keyVer);
                        }
                        //SQL Version should >= 12.1.4100.1
                        Version tagVer = new Version(destVersion);
                        if (SQLVer >= tagVer)
                        {
                            return true;
                        }
                        else
                        {
                            return false;
                        }
                    }
                    catch
                    {
                        return false;
                    }
    
                }
                else
                    return false;
            }

    三、检验SilverLight版本

    public static bool checkSilverLight(string destVersion)
            {
                try
                {
                    Version version;
                    RegistryKey rk = Registry.LocalMachine;
                    RegistryKey ver = rk.OpenSubKey(@"SOFTWAREMicrosoftSilverlight");
                    if (ver == null)
                        ver = rk.OpenSubKey(@"SOFTWAREWow6432NodeMicrosoftSilverlight");
                    version = new Version(ver.GetValue("Version").ToString());
    
                    //version >= 5.1
                    if (version >= new Version(destVersion))
                        return true;
                    return false;
                }
                catch
                {
                    return false;
                }
            }
  • 相关阅读:
    YYHSOI模拟赛题解(T6围栏问题)
    取水
    Spring.Net实现跨数据库服务层事务管理
    使用node.js + jsonserver + mock.js 搭建本地开发mock数据服务
    [转]SQL SERVER整理索引碎片测试
    asp.net mvc 安全测试漏洞 " HTTP 动词篡改的认证旁路" 问题解决
    JavaScript中子类调用父类方法的实现
    asp.net mvc 安全测试漏洞 "跨站点请求伪造" 问题解决
    C#学习记录3下——类的封装,继承,多态
    C#学习记录8——XAML
  • 原文地址:https://www.cnblogs.com/DM428/p/8676629.html
Copyright © 2011-2022 走看看