# guns **Repository Path**: asling_zhang/guns ## Basic Information - **Project Name**: guns - **Description**: 不用写xml配置的后台管理系统!包含权限管理等模块!整合主流的springmvc + mybatis-plus + beetl! - **Primary Language**: Java - **License**: Not specified - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 1 - **Forks**: 7774 - **Created**: 2017-05-10 - **Last Updated**: 2020-12-19 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README #Guns 不用写xml配置的后台管理系统!包含权限管理等模块!整合主流的springmvc + mybatis-plus + beetl! ## 鸣谢 1.[SpringBlade](http://git.oschina.net/smallc/SpringBlade) 2.[beetl](http://ibeetl.com/) 3.[mybatis-plus](http://git.oschina.net/baomidou/mybatis-plus) ##功能简介 1. 用户管理 2. 角色管理 3. 菜单管理 4. 部门管理 4. 日志管理 5. 监控管理 6. 字典管理 7. 代码生成 ##使用说明 1. 导入sql/guns.sql文件到数据库 2. 启动项目,管理员账号admin/密码111111 ##所用框架 ###前端 1. bootstrap 2. jquery 3. bootstrap-table 4. layer 5. ztree 6. webuploader ###后端 1. springmvc 2. mybatis 3. mybatis-plus 4. spring 5. beetl 6. hibernate-validator 7. ehcache ##项目特点 1. 零springxml配置,完全采用javabean方式配置spring,新思路,配置简洁,不易出错。详情请见com.stylefeng.guns.project.config包中具体类。 2. 完善的日志记录体系,可记录登录日志,业务操作日志,通过@BussinessLog注解和LogObjectHolder.me().set()方法,业务操作日志可具体记录哪个用户,执行了哪些业务,修改了哪些数据,并且日志记录为异步执行,详情请见@BussinessLog注解和LogObjectHolder,LogManager,LogAop类。 3. 利用beetl模板引擎对前台页面进行封装和拆分,使臃肿的html代码变得简洁,更加易维护。 4. 对常用js插件进行二次封装,使js代码变得简洁,更加易维护,具体请见webapp/static/js/common文件夹内js代码。 5. 利用ehcache框架对经常调用的查询进行缓存,提升运行速度,具体请见ConstantFactory类中@Cacheable标记的方法。 6. controller层采用map + warpper方式的返回结果,返回给前端更为灵活的数据,具体参见com.stylefeng.guns.modular.system.warpper包中具体类。 7. 防止XSS攻击,通过XssFilter类对所有的输入的非法字符串进行过滤以及替换。 ##零spring xml配置示例 以下配置示例仅列出部分spring配置,详情请见com.stylefeng.guns.project.config包中具体的配置类 ###根配置 ``` @Configuration @ComponentScan(basePackages = {"com.stylefeng"}, excludeFilters = { @Filter(type = FilterType.ANNOTATION, value = EnableWebMvc.class)// 这个是为了不让扫描到springmvc的控制器 }) @EnableAspectJAutoProxy @Import(value = {DataSourceConfig.class, ShiroConfig.class, DruidMonitorConfig.class, EhcacheConfig.class}) public class RootSpringConfig { } ``` ###数据源配置 ``` @Configuration @EnableTransactionManagement @PropertySource("classpath:jdbc.properties") public class DataSourceConfig implements EnvironmentAware { private Environment em; /** * spring和MyBatis整合 */ @Bean public MybatisSqlSessionFactoryBean sqlSessionFactory(DataSource dataSource, GlobalConfiguration globalConfig) { MybatisSqlSessionFactoryBean sqlSessionFactory = new MybatisSqlSessionFactoryBean(); sqlSessionFactory.setDataSource(dataSource); sqlSessionFactory.setConfigLocation(new ClassPathResource("mybatis-config.xml")); Resource[] classPathResources = ResKit.getClassPathResources("classpath*:com/stylefeng/guns/**/mapping/*.xml"); sqlSessionFactory.setMapperLocations(classPathResources); //以下为mybatis-plus配置 PaginationInterceptor paginationInterceptor = new PaginationInterceptor(); paginationInterceptor.setDialectType("mysql"); sqlSessionFactory.setPlugins(new Interceptor[]{paginationInterceptor}); sqlSessionFactory.setGlobalConfig(globalConfig); return sqlSessionFactory; } } ``` ###零web.xml配置 ``` public class WebAppInitializer extends AbstractAnnotationConfigDispatcherServletInitializer { // spring应用上下文 @Override protected Class[] getRootConfigClasses() { return new Class[]{RootSpringConfig.class}; } // springmvc 上下文 @Override protected Class[] getServletConfigClasses() { return new Class[]{SpringMvcConfig.class}; } // 将DispatcherServlet映射到"/" @Override protected String[] getServletMappings() { return new String[]{"/"}; } } ``` ###springmvc配置 ``` @Configuration @EnableWebMvc @ComponentScan(basePackages = {"com.stylefeng.guns.**.controller", "com.stylefeng.guns.common.controller"}) @EnableAspectJAutoProxy @Import({ControllerAopConfig.class}) public class SpringMvcConfig extends WebMvcConfigurerAdapter { // beetl的视图解析器 @Bean public BeetlSpringViewResolver beetlViewResolver() { BeetlSpringViewResolver beetlSpringViewResolver = new BeetlSpringViewResolver(); beetlSpringViewResolver.setConfig(beetlConfiguration()); beetlSpringViewResolver.setContentType("text/html;charset=UTF-8"); beetlSpringViewResolver.setOrder(0); return beetlSpringViewResolver; } // 配置静态资源的处理,对静态资源的请求转发到servlet容器中默认的servlet上(对静态资源的请求不做处理) @Override public void configureDefaultServletHandling(DefaultServletHandlerConfigurer configurer) { configurer.enable(); } } ``` ##业务日志记录原理 日志记录采用aop(LogAop类)方式对所有包含@BussinessLog注解的方法进行aop切入,会记录下当前用户执行了哪些操作(即@BussinessLog value属性的内容),如果涉及到数据修改,会取当前http请求的所有requestParameters与LogObjectHolder类中缓存的Object对象的所有字段作比较(所以在编辑之前的获取详情接口中需要缓存被修改对象之前的字段信息),日志内容会异步存入数据库中(通过ScheduledThreadPoolExecutor类)。 ##beetl对前台页面的拆分与包装 例如,把主页拆分成三部分,每个部分单独一个页面,更加便于维护 ``` @include("/common/_tab.html"){} @include("/common/_right.html"){} @include("/common/_theme.html"){} ``` 以及对重复的html进行包装,使前端页面更加专注于业务实现,例如,把所有页面引用包进行提取 ```
${layoutContent}
``` 开发页面时,只需编写如下代码即可 ``` @layout("/common/_container.html"){
部门管理
@} ``` 以上beetl的用法请参考beetl说明文档。 ##效果图 ![输入图片说明](https://git.oschina.net/uploads/images/2017/0429/233329_a0c40981_551203.png "在这里输入图片标题") ![输入图片说明](https://git.oschina.net/uploads/images/2017/0429/233336_5784c639_551203.png "在这里输入图片标题") ![输入图片说明](https://git.oschina.net/uploads/images/2017/0429/233347_f70e3c71_551203.png "在这里输入图片标题") ![输入图片说明](https://git.oschina.net/uploads/images/2017/0429/233354_24c8da50_551203.png "在这里输入图片标题") ![输入图片说明](https://git.oschina.net/uploads/images/2017/0429/233402_594a588a_551203.png "在这里输入图片标题") ![输入图片说明](https://git.oschina.net/uploads/images/2017/0429/233410_6c4061e0_551203.png "在这里输入图片标题") ![输入图片说明](https://git.oschina.net/uploads/images/2017/0429/233417_6e9ecf5e_551203.png "在这里输入图片标题")