写了个开源项目 Nginx 图形化监控控制台系统 基于JSP + AmazeUI home 编辑时间 2019/05/04 ![Nginx GUI JSP](/api/file/getImage?fileId=5d527c4416199b2a52000b00) ## 还在开发中!! 开发进度 20% ## 需求 最近搞了一个开源项目:Nginx GUI 图形化监控控制台系统 尽可能追求快速开发和减少服务器性能开销 所以最终决定用 JSP + AmazeUI 来实现 估计有不少Java开发人员从学完JSP以后再也没用到过 其实我觉得JSP用在小型 微型项目里很合适,非常方便 ## 方案 1. 静态依赖例如js css 图标等全部基于七牛云提供的公开免费CDN仓库 staticfile.org 2. 后端只依赖一个jstl 1.2,所有代码写在一个JSP里 (虽然这样看起来有点老套,不太符合开发规范?但是方便啊~内存占用低,反正就自己用) ## 截图 **Nginx 配置页面** ![](/api/file/getImage?fileId=5d527c4416199b2a52000b01) ## 源码地址 Github : [https://github.com/18121259693/nginx-gui-jsp](https://github.com/18121259693/nginx-gui-jsp) ## 核心代码 `index.jsp` ```jsp <%@ page contentType="text/html;charset=UTF-8" language="java" %> <% // 测试访问路径 http://localhost:8080/index.jsp?active=index&token=e10adc3949ba59abbe56e057f20f883e // jsp 获取url参数token做最简单的登录权限控制 例如用 123456的MD5 e10adc3949ba59abbe56e057f20f883e if (!"e10adc3949ba59abbe56e057f20f883e".equalsIgnoreCase(request.getParameter("token"))) { out.print("{'msg':'error','code':'403'}"); return; } String active = request.getParameter("active"); // 基本信息配置 request.setAttribute("logPath", "C:\\Users\\Administrator\\Documents\\nginx\\logs\\"); request.setAttribute("configPath", "C:\\Users\\Administrator\\Documents\\nginx\\conf\\"); request.setAttribute("active", active == null ? active : "index"); %> <html lang="zh-CN"> <head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1"> <title>Nginx 监控管理系统</title> <link rel="icon" type="image/png" href=""> <%-- 用七牛云免费的 AmazeUI https cdn --%> <link href="https://cdn.staticfile.org/amazeui/2.7.2/css/amazeui.min.css" rel="stylesheet"> <style> <%-- 直接在jsp里写 css --%> @media only screen and (min-width: 641px) { .am-offcanvas { display: block; position: static; background: none; } .am-offcanvas-bar { position: static; width: auto; background: none; -webkit-transform: translate3d(0, 0, 0); -ms-transform: translate3d(0, 0, 0); transform: translate3d(0, 0, 0); } .am-offcanvas-bar:after { content: none; } } @media only screen and (max-width: 640px) { .am-offcanvas-bar .am-nav > li > a { color: #ccc; border-radius: 0; border-top: 1px solid rgba(0, 0, 0, .3); box-shadow: inset 0 1px 0 rgba(255, 255, 255, .05) } .am-offcanvas-bar .am-nav > li > a:hover { background: #404040; color: #fff } .am-offcanvas-bar .am-nav > li.am-nav-header { color: #777; background: #404040; box-shadow: inset 0 1px 0 rgba(255, 255, 255, .05); text-shadow: 0 1px 0 rgba(0, 0, 0, .5); border-top: 1px solid rgba(0, 0, 0, .3); font-weight: 400; font-size: 75% } .am-offcanvas-bar .am-nav > li.am-active > a { background: #1a1a1a; color: #fff; box-shadow: inset 0 1px 3px rgba(0, 0, 0, .3) } .am-offcanvas-bar .am-nav > li + li { margin-top: 0; } } .my-button { position: fixed; top: 0; right: 0; border-radius: 0; } .my-sidebar { padding-right: 0; border-right: 1px solid #eeeeee; } </style> </head> <body> <div class="am-g"> <div class="am-u-md-11 am-u-md-push-1"> <div class="am-g"> <div class="am-u-sm-11 am-u-sm-centered"> <div class="am-cf am-article"> 展示部分 </div> </div> </div> </div> <div class="am-u-md-1 am-u-md-pull-11 my-sidebar"> <div class="am-offcanvas" id="sidebar"> <div class="am-offcanvas-bar"> <ul class="am-nav"> <li class="am-nav-header">NGINX</li> <li><a href="#">首页</a></li> <li><a href="#">配置</a></li> <li><a href="#">日志</a></li> </ul> </div> </div> </div> <a href="#sidebar" class="am-btn am-btn-sm am-btn-success am-icon-bars am-show-sm-only my-button" data-am-offcanvas><span class="am-sr-only">侧栏导航</span></a> <%-- 用七牛云免费的 AmazeUI https cdn --%> <script src="https://cdn.staticfile.org/jquery/2.2.4/jquery.min.js"></script> <script src="https://cdn.staticfile.org/amazeui/2.7.2/js/amazeui.min.js"></script> <script> <%-- 直接在jsp里写 js --%> </script> </body> </html> ``` ## END 其他线上项目 个人博客: https://zzzmh.cn 学习笔记: https://leanote.zzzmh.cn 极简壁纸: https://bz.zzzmh.cn 极简插件: https://chrome.zzzmh.cn 联系方式: [admin@zzzmh.cn](mailto:admin@zzzmh.cn) 送人玫瑰,手留余香 赞赏 Wechat Pay Alipay 【转载】Nginx配置文件nginx.conf中文详解 油猴脚本 入门教程