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;
                }
            }
  • 相关阅读:
    开发一个cube.js cratedb driver
    dremio 时间操作函数
    authelia web sso 解决方案
    dremio sql server 出现无法绑定由多个部分组成的标识符的解决方法
    cratedb 4.5 企业特性可以免费使用了
    cube.js 新版本cubestore 禁用
    spring-native 编译spring 应用为graalvm native 镜像
    streamsets tar 模式启动
    streamset data collector 新注册机制
    Swarm 集群管理
  • 原文地址:https://www.cnblogs.com/DM428/p/8676629.html
Copyright © 2011-2022 走看看