Java 的 SystemInfoUtil 类

本贴最后更新于 2686 天前,其中的信息可能已经时异事殊

本文由黑壳网原创

本文来源 Java 的 SystemInfoUtil 类 - 黑壳网

壳叔搞笑一刻

单位有个女同事,平时爱占小便宜。
今天一上班,辫子上绑着根捆蛋糕的绳子。
我们问她:今天怎么绑这么一根东西。
她回答到:今天我生日,给你们提个醒,别忘了给我发红包。
我去,早知道不问她了……

今天闲着没事,正好公司项目后台想显示一下服务器的各种信息,感觉不至于那么 low,所以根据网上的一些资料,整理出这个么一个工具类。
其实代码 so easy 重在理解。就像解决错误一样,你不能一味的去各种试一试改一改,你得去了解这个错误,才能对症下药。

工具类简单说明
getSystemInfo() 获取系统环境等相关信息
其实获取服务器环境的信息代码简单,大多数都是从 Java 的 System 这个大佬身上获取出来的。没什么可说的只要根据需求取值就可以了。不一定所有的都会用上所以根据需要适当调整

getDatabaseMajorVersion() 获取数据库的主要版本等信息
通过 jdbc 读取数据库数据信息~ 只不过这里的以下代码是从 jdbc.properties 配置文件中获取的, 根据自己这个地方自己进行适当的修改。

getProjectInfo() 获取项目版本信息
这个地方是直接读取配置文件,将相关的信息读取出来。

	/**
     * 从配置文件读取 链接数据库信息
     * 然后建立连接
     * 用适当的驱动程序连接到DBMS,看下面的代码[自行修改您所连接的数据库相关信息]:
     */
    props.load(SystemInfoUtil.class.getClassLoader().getResourceAsStream("jdbc.properties"));
    String url = props.getProperty("jdbcUrl");
    String user = props.getProperty("username");
    String password = props.getProperty("password");
    String driver = props.getProperty("driverClasss");

详细代码

SystemInfoUtil

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.io.IOException;
import java.lang.reflect.Method;
import java.net.InetAddress;
import java.net.UnknownHostException;
import java.sql.Connection;
import java.sql.DatabaseMetaData;
import java.sql.DriverManager;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.HashMap;
import java.util.Locale;
import java.util.Map;
import java.util.Properties;
import java.util.logging.SimpleFormatter;

/**
 * 获取系统信息以及服务器信息
 * Created by kzyuan on 2017/6/22.
 */
public class SystemInfoUtil {

    private static Logger logger = LoggerFactory.getLogger(SystemInfoUtil.class);

    /**
     * 服务器环境相关信息
     *
     * @return
     */
    public Map getSystemInfo() {
        Map<String, String> map = new HashMap<String, String>();

        /**
         * java.version Java 运行时环境版本
         */
        map.put("java_version", System.getProperty("java.version"));
        /**
         * java.vendor Java 运行时环境供应商
         */
        map.put("java_vendor", System.getProperty("java.vendor"));
        /**
         * java.vendor.url Java 供应商的 URL
         */
        map.put("java_vendor_url", System.getProperty("java.vendor.url"));
        /**
         * java.home Java 安装目录
         */
        map.put("java_home", System.getProperty("java.home"));
        /**
         * java.vm.specification.version Java 虚拟机规范版本
         */
        map.put("java_vm_specification_version", System.getProperty("java.vm.specification.version"));
        /**
         * java.vm.specification.vendor Java 虚拟机规范供应
         */
        map.put("java_vm_specification_vendor", System.getProperty("java.vm.specification.vendor"));
        /**
         *  java.vm.specification.name Java 虚拟机规范名称
         */
        map.put("java_vm_specification_name", System.getProperty("java.vm.specification.name"));

        /**
         * java.vm.version   Java 虚拟机实现版本
         */
        map.put("java_vm_version", System.getProperty("java.vm.version"));
        /**
         * java.vm.vendor   Java 虚拟机实现供应商
         */
        map.put("java_vm_vendor", System.getProperty("java.vm.vendor"));
        /**
         * java.vm.name   Java 虚拟机实现名称
         */
        map.put("java_vm_name", System.getProperty("java.vm.name"));
        /**
         * java.specification.version   Java 运行时环境规范版本
         */
        map.put("java_specification_version", System.getProperty("java.specification.version"));
        /**
         * java.specification.vendor   Java 运行时环境规范供应商
         */
        map.put("java_specification_vendor", System.getProperty("java.specification.vendor"));
        /**
         * java.specification.name   Java 运行时环境规范名称
         */
        map.put("java_specification_name", System.getProperty("java.specification.name"));
        /**
         * java.class.version   Java 类格式版本号
         */
        map.put("java_class_version", System.getProperty("java.class.version"));
        /**
         * java.class.path   Java 类路径
         */
        map.put("java_class_path", System.getProperty("java.class.path"));
        /**
         * java.library.path   加载库时搜索的路径列表
         */
        map.put("java_library_path", System.getProperty("java.library.path"));
        /**
         * java.io.tmpdir   默认的临时文件路径
         */
        map.put("java_io_tmpdir", System.getProperty("java.io.tmpdir"));
        /**
         * java.compiler   要使用的 JIT 编译器的名称
         */
        map.put("java_compiler", System.getProperty("java.compiler"));
        /**
         * java.ext.dirs   一个或多个扩展目录的路径
         */
        map.put("java_ext_dirs", System.getProperty("java.ext.dirs"));
        /**
         * os.name   操作系统的名称
         */
        map.put("os_name", System.getProperty("os.name"));
        /**
         * os.arch   操作系统的架构
         */
        map.put("os_arch", System.getProperty("os.arch"));
        /**
         * os.version   操作系统的版本
         */
        map.put("os_version", System.getProperty("os.version"));
        /**
         * file.separator   文件分隔符(在 UNIX 系统中是“/”)
         */
        map.put("file_separator", System.getProperty("file.separator"));
        /**
         * path.separator   路径分隔符(在 UNIX 系统中是“:”)
         */
        map.put("path_separator", System.getProperty("path.separator"));
        /**
         * line.separator   行分隔符(在 UNIX 系统中是“/n”)
         */
        map.put("line_separator", System.getProperty("line.separator"));
        /**
         * user.name   用户的账户名称
         */
        map.put("user_name", System.getProperty("user.name"));
        /**
         * user.home   用户的主目录
         */
        map.put("user_home", System.getProperty("user.home"));
        /**
         * user.dir   用户的当前工作目录
         */
        map.put("user_dir", System.getProperty("user.dir"));

        /**
         * file_encoding 获取JVM编码格式
         */
        map.put("file_encoding", System.getProperty("file.encoding"));

        /**
         *  获取操作系统的编码
         */
        map.put("sun_jnu_encoding", System.getProperty("sun.jnu.encoding"));
        InetAddress netAddress = getInetAddress();
        /**
         *  host_ip 获取本地IP
         */
        map.put("host_ip", getHostIp(netAddress));

        /**
         * host_name 获取本地主机名
         */
        map.put("host_name", getHostName(netAddress));


        Locale locale = Locale.getDefault();
        /**
         * language 获取语言
         */
        map.put("language",locale.getLanguage());

        /**
         * country 获取语言国家
         */
        map.put("country",locale.getCountry());
        return map;
    }

    /**
     * 获取本地主机
     *
     * @return
     */
    public static InetAddress getInetAddress() {
        try {
            return InetAddress.getLocalHost();
        } catch (UnknownHostException e) {
            logger.error("UnknownHostException", e);
        }
        return null;
    }

    /**
     * 通过InetAddress获取本地Ip
     *
     * @param netAddress
     * @return
     */
    public static String getHostIp(InetAddress netAddress) {
        if (null == netAddress) {
            return null;
        }
        String ip = netAddress.getHostAddress();
        return ip;
    }

    /**
     * 通过InetAddress获取本地主机的名字
     *
     * @param netAddress
     * @return
     */
    public static String getHostName(InetAddress netAddress) {
        if (null == netAddress) {
            return null;
        }
        String name = netAddress.getHostName();
        return name;
    }

    /**
     * 通过Jdbc的方式获取数据库的版本
     *
     * @return
     */
    protected Map getDatabaseMajorVersion() {
        Map<String, String> map = new HashMap<String, String>();
        PropertyUtil propertyUtil = new PropertyUtil();
        Properties props = new Properties();

        try {

            /**
             * 从配置文件读取 链接数据库信息
             * 然后建立连接
             * 用适当的驱动程序连接到DBMS,看下面的代码[自行修改您所连接的数据库相关信息]:
             */
            props.load(SystemInfoUtil.class.getClassLoader().getResourceAsStream("jdbc.properties"));
            String url = props.getProperty("jdbcUrl");
            String user = props.getProperty("username");
            String password = props.getProperty("password");
            String driver = props.getProperty("driverClasss");
            // 加载驱动程序
            // 下面的代码为加载JDBD-ODBC驱动程序
            Class.forName(driver);
            // 用url创建连接
            Connection con = DriverManager.getConnection(url, user, password);
            // 获取数据库的信息
            DatabaseMetaData dbMetaData = con.getMetaData();

            /**
             * 返回一个String类对象,代表数据库的URL
             */
            map.put("URL", dbMetaData.getURL());

            /**
             * 返回连接当前数据库管理系统的用户名。
             */
            map.put("userName", dbMetaData.getUserName());

            /**
             * 返回一个boolean值,指示数据库是否只允许读操作。
             */
            map.put("isReadOnly", dbMetaData.isReadOnly() + "");

            /**
             * 返回数据库的产品名称。
             */
            map.put("DatabaseProductName", dbMetaData.getDatabaseProductName());

            /**
             * 返回数据库的版本号。
             */
            map.put("DatabaseProductVersion", dbMetaData.getDatabaseProductVersion());


            Method gdbmvMethod = DatabaseMetaData.class.getMethod("getDatabaseMajorVersion", null);
            /**
             * 数据库真正的版本号
             */
            map.put("version", gdbmvMethod.invoke(dbMetaData, null)+"");

            /**
             * 返回驱动驱动程序的名称。
             */
            map.put("DriverName", dbMetaData.getDriverName());

            /**
             * 返回驱动程序的版本号。
             */
            map.put("DriverVersion", dbMetaData.getDriverVersion());
            // 关闭连接
            con.close();
        } catch (Exception e) {
            // 输出异常信息
            logger.error("Exception", e);
        }
        return map;
    }

    /**
     * 项目信息
     *
     * @return
     */
    protected Map getProjectInfo() {
        Map<String, String> map = new HashMap<String, String>();
        Properties props = new Properties();
        try {
            /**
             * 从配置文件中获取相关网站信息
             */
            props.load(SystemInfoUtil.class.getClassLoader().getResourceAsStream("common.properties"));
        } catch (IOException e) {
            logger.error("IOException", e);
        }

        /**
         * 项目版本
         */
        map.put("project_version",props.getProperty("project.version"));
        /**
         * 项目编码
         */
        map.put("project_build_sourceEncoding",props.getProperty("project.build.sourceEncoding"));
        SimpleDateFormat time=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");

        /**
         * 项目启动日期
         */
        map.put("start_date",time.format(new Date()));
        return map;
    }


}

代码下载地址
[url=https://bhusk99.ctfile.com/fs/12729178-209651307]SystemInfoUtil.java[/url]

  • Java

    Java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由 Sun Microsystems 公司于 1995 年 5 月推出的。Java 技术具有卓越的通用性、高效性、平台移植性和安全性。

    3186 引用 • 8212 回帖 • 1 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
ykz200
我是壳叔,我正在想一个很棒的idea 北京

推荐标签 标签

  • 尊园地产

    昆明尊园房地产经纪有限公司,即:Kunming Zunyuan Property Agency Company Limited(简称“尊园地产”)于 2007 年 6 月开始筹备,2007 年 8 月 18 日正式成立,注册资本 200 万元,公司性质为股份经纪有限公司,主营业务为:代租、代售、代办产权过户、办理银行按揭、担保、抵押、评估等。

    1 引用 • 22 回帖 • 753 关注
  • 单点登录

    单点登录(Single Sign On)是目前比较流行的企业业务整合的解决方案之一。SSO 的定义是在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统。

    9 引用 • 25 回帖
  • sts
    2 引用 • 2 回帖 • 193 关注
  • frp

    frp 是一个可用于内网穿透的高性能的反向代理应用,支持 TCP、UDP、 HTTP 和 HTTPS 协议。

    20 引用 • 7 回帖 • 2 关注
  • SSL

    SSL(Secure Sockets Layer 安全套接层),及其继任者传输层安全(Transport Layer Security,TLS)是为网络通信提供安全及数据完整性的一种安全协议。TLS 与 SSL 在传输层对网络连接进行加密。

    70 引用 • 193 回帖 • 436 关注
  • 架构

    我们平时所说的“架构”主要是指软件架构,这是有关软件整体结构与组件的抽象描述,用于指导软件系统各个方面的设计。另外还有“业务架构”、“网络架构”、“硬件架构”等细分领域。

    142 引用 • 442 回帖
  • Eclipse

    Eclipse 是一个开放源代码的、基于 Java 的可扩展开发平台。就其本身而言,它只是一个框架和一组服务,用于通过插件组件构建开发环境。

    75 引用 • 258 回帖 • 619 关注
  • OpenResty

    OpenResty 是一个基于 NGINX 与 Lua 的高性能 Web 平台,其内部集成了大量精良的 Lua 库、第三方模块以及大多数的依赖项。用于方便地搭建能够处理超高并发、扩展性极高的动态 Web 应用、Web 服务和动态网关。

    17 引用 • 47 关注
  • GraphQL

    GraphQL 是一个用于 API 的查询语言,是一个使用基于类型系统来执行查询的服务端运行时(类型系统由你的数据定义)。GraphQL 并没有和任何特定数据库或者存储引擎绑定,而是依靠你现有的代码和数据支撑。

    4 引用 • 3 回帖 • 6 关注
  • Swift

    Swift 是苹果于 2014 年 WWDC(苹果开发者大会)发布的开发语言,可与 Objective-C 共同运行于 Mac OS 和 iOS 平台,用于搭建基于苹果平台的应用程序。

    36 引用 • 37 回帖 • 535 关注
  • 招聘

    哪里都缺人,哪里都不缺人。

    190 引用 • 1057 回帖 • 1 关注
  • 大疆创新

    深圳市大疆创新科技有限公司(DJI-Innovations,简称 DJI),成立于 2006 年,是全球领先的无人飞行器控制系统及无人机解决方案的研发和生产商,客户遍布全球 100 多个国家。通过持续的创新,大疆致力于为无人机工业、行业用户以及专业航拍应用提供性能最强、体验最佳的革命性智能飞控产品和解决方案。

    2 引用 • 14 回帖
  • 书籍

    宋真宗赵恒曾经说过:“书中自有黄金屋,书中自有颜如玉。”

    77 引用 • 390 回帖
  • 笔记

    好记性不如烂笔头。

    308 引用 • 793 回帖
  • Firefox

    Mozilla Firefox 中文俗称“火狐”(正式缩写为 Fx 或 fx,非正式缩写为 FF),是一个开源的网页浏览器,使用 Gecko 排版引擎,支持多种操作系统,如 Windows、OSX 及 Linux 等。

    8 引用 • 30 回帖 • 407 关注
  • BND

    BND(Baidu Netdisk Downloader)是一款图形界面的百度网盘不限速下载器,支持 Windows、Linux 和 Mac,详细介绍请看这里

    107 引用 • 1281 回帖 • 29 关注
  • 倾城之链
    23 引用 • 66 回帖 • 139 关注
  • 职场

    找到自己的位置,萌新烦恼少。

    127 引用 • 1705 回帖
  • HTML

    HTML5 是 HTML 下一个的主要修订版本,现在仍处于发展阶段。广义论及 HTML5 时,实际指的是包括 HTML、CSS 和 JavaScript 在内的一套技术组合。

    107 引用 • 295 回帖
  • 脑图

    脑图又叫思维导图,是表达发散性思维的有效图形思维工具 ,它简单却又很有效,是一种实用性的思维工具。

    25 引用 • 83 回帖 • 1 关注
  • 钉钉

    钉钉,专为中国企业打造的免费沟通协同多端平台, 阿里巴巴出品。

    15 引用 • 67 回帖 • 337 关注
  • TextBundle

    TextBundle 文件格式旨在应用程序之间交换 Markdown 或 Fountain 之类的纯文本文件时,提供更无缝的用户体验。

    1 引用 • 2 回帖 • 45 关注
  • abitmean

    有点意思就行了

    30 关注
  • 京东

    京东是中国最大的自营式电商企业,2015 年第一季度在中国自营式 B2C 电商市场的占有率为 56.3%。2014 年 5 月,京东在美国纳斯达克证券交易所正式挂牌上市(股票代码:JD),是中国第一个成功赴美上市的大型综合型电商平台,与腾讯、百度等中国互联网巨头共同跻身全球前十大互联网公司排行榜。

    14 引用 • 102 回帖 • 377 关注
  • 域名

    域名(Domain Name),简称域名、网域,是由一串用点分隔的名字组成的 Internet 上某一台计算机或计算机组的名称,用于在数据传输时标识计算机的电子方位(有时也指地理位置)。

    43 引用 • 208 回帖
  • Tomcat

    Tomcat 最早是由 Sun Microsystems 开发的一个 Servlet 容器,在 1999 年被捐献给 ASF(Apache Software Foundation),隶属于 Jakarta 项目,现在已经独立为一个顶级项目。Tomcat 主要实现了 JavaEE 中的 Servlet、JSP 规范,同时也提供 HTTP 服务,是市场上非常流行的 Java Web 容器。

    162 引用 • 529 回帖 • 6 关注
  • Typecho

    Typecho 是一款博客程序,它在 GPLv2 许可证下发行,基于 PHP 构建,可以运行在各种平台上,支持多种数据库(MySQL、PostgreSQL、SQLite)。

    12 引用 • 65 回帖 • 453 关注