jeesite功能模块解释

合集下载

功能模块介绍范文

功能模块介绍范文

功能模块介绍范文功能模块是指软件系统中的各个独立部分或组件,每个模块负责完成特定的功能或任务。

功能模块的设计和划分是软件开发过程中的重要环节,它能够提高软件的可维护性、可扩展性和可测试性,使开发人员能够更加方便地进行开发和维护工作。

功能模块可以根据不同的分类标准进行划分,如按照功能的复杂程度、业务逻辑的相关性、用户需求等等。

下面将介绍几种常见的功能模块划分方式。

1.系统管理模块:该模块主要负责系统的用户管理、权限控制、日志记录等功能。

它是整个软件系统的核心模块,能够确保系统的安全性和稳定性。

2.数据管理模块:该模块负责对系统中的数据进行管理和操作。

它包括数据的增删改查、数据的导入导出、数据的备份恢复等功能。

数据管理模块能够保证数据的有效性和一致性。

3.业务逻辑模块:该模块是根据系统的业务需求进行划分的,每个模块负责完成特定的业务逻辑。

例如,在一个电商网站中,可以有商品管理模块、订单管理模块、用户管理模块等等。

4.界面展示模块:该模块主要负责系统的用户界面展示。

它涉及到页面设计、交互设计、用户体验等方面。

界面展示模块能够直观地展示系统的功能和信息,提升用户的使用体验。

6.工具模块:该模块提供一些辅助性的功能,便于开发人员进行开发、测试和维护工作。

例如,日志管理工具模块可以记录系统运行过程中的日志信息,便于开发人员进行故障排查。

在软件开发过程中,功能模块的设计应该遵循一些原则和方法,如高内聚、低耦合、单一职责等。

高内聚指的是模块内部的各个功能元素之间的紧密程度,要求各个功能元素在逻辑上紧密相关,并且实现高度的独立性;低耦合则指的是模块之间的相互依赖程度,要求不同模块之间的依赖关系尽可能降低,以提高系统的灵活性和可扩展性;单一职责要求每个功能模块只负责完成一个特定的功能,避免一个模块承担过多的功能,导致代码冗余和混乱。

总之,功能模块是软件系统中的重要组成部分,其设计和划分对于软件开发和维护起到关键作用。

JeeSite开发(一)——JeeSite4开发基础实例

JeeSite开发(一)——JeeSite4开发基础实例

JeeSite开发(⼀)——JeeSite4开发基础实例⽬录: 〇、开发环境 ⼀、JeeSite介绍 ⼆、获取JeeSite4 三、运⾏JeeSite后台(部署运⾏) 四、启动并访问 五、增加⼀个功能模块〇、开发环境 JDK1.8、eclipse、maven、MySQL57⼀、JeeSite介绍 JeeSite 基于最主流的 Spring Boot 2 + MyBatis + Shiro + J2Cache/Redis + Beetl 的稳定架构。

前端采⽤了⽬前极为流⾏的扁平化响应式的设计风格,可以完美兼容电脑,平板,⼿机等多个平台。

基于 jQuery + Bootstrap + AdminLTE 实现。

⽤JeeSite可以快速搭建⼀个web⽹站,⽽且可以不写或者只需写很少的业务代码。

⼆、获取JeeSite4 以下为其⽬录:三、运⾏JeeSite后台(部署运⾏)3.1 引⼊项⽬ 1.将以上的web⽬录复制到⾃⼰的⼯作⽬录,并按需重命名(例如:jeesite-demo)。

2.打开其中的poi.xml⽂件,修改其中的第⼗三⾏,改为您刚刚修改的⽂件夹名,例如:<artifactId>jeesite-demo</artifactId> 3.⽽后在eclipse中将其引⼊进来,右键空⽩处->Import->选择Maven下的Existing Maven Projects,点确定,此时Maven会⾃动加载依赖包,效果如下。

3.2 初始化数据库 1.配置my.ini:打开MySQL安装⽂件夹下的my.ini⽂件, 在[mysqld]下增加 sql_mode="ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION" 2.在MySQL中创建⽤户和数据库set global read_only=0;set global optimizer_switch='derived_merge=off';create user 'jeesite'@'%' identified by 'jeesite';create database jeesite DEFAULT CHARSET 'utf8mb4' COLLATE 'utf8mb4_unicode_ci';grant all privileges on jeesite.* to 'jeesite'@'%' identified by 'jeesite';flush privileges; 3.在刚刚引⼊的项⽬中,找到 /src/main/resources/config/application.yml ⽂件,修改MySQL数据库配置:# 数据库连接jdbc:# Mysql 数据库配置type: mysqldriver: com.mysql.jdbc.Driverurl: jdbc:mysql://127.0.0.1:3306/jeesite?useSSL=false&useUnicode=true&characterEncoding=utf-8&zeroDateTimeBehavior=convertToNullusername: jeesitepassword: jeesitetestSql: SELECT 1 4.双击运⾏项⽬下的 /bin/init-data.bat 脚本,将会⾃动初始化数据库(建表)四、启动并访问 1.可在 /src/main/resources/config/application.yml ⽂件中修改服务器端⼝和部署路径server:port: 8980servlet:context-path: /jeesite-demotomcat:uri-encoding: UTF-8 2.启动:由于JeeSite集成了Spring boot框架,即内部集成了tomcat服务器,所以只需右键点击com.jeesite.modules.config.Application.java⽂件,再点击 Run As -> Java Application 即可启动服务。

jeesite js 调用java方法

jeesite js 调用java方法

阅读文章全文,其构成专注于深度和广度的要求并包含了丰富的技术性讨论,如下所述:1. 介绍在当今数字化世界中,前端和后端技术的结合变得愈发重要。

jeesite js 调用 Java 方法正是这种结合中的一个关键环节。

在本文中,我们将深入探讨这一主题,并为您提供详细的指南和见解。

2. 深入了解jeesite js让我们对jeesite js 进行简要介绍。

jeesite是一款基于Spring框架的开源企业级应用开发框架,而jeesite js则是其前端部分。

它提供了丰富的前端功能,允许开发者与后端Java方法进行交互。

在接下来的部分,我们将深入讨论jeesite js 如何调用后端的Java方法。

3. 调用Java方法的基本步骤在使用jeesite js 调用Java方法之前,有几个基本步骤需要遵循。

我们需要确保在后端Java代码中已经编写了需要调用的方法。

在jeesite js 中,我们需要设置好相关的参数和路径,以确保前端可以正确地与后端进行通信。

在接下来的章节中,我们将对这些步骤进行更详细的探讨。

4. 深度探讨jeesite js 调用Java方法的具体实现现在让我们深入讨论jeesite js 如何调用Java方法。

我们需要在jeesite js 中使用ajax方法,以便发起对后端方法的调用。

我们需要定义后端方法的路径和参数,使得前端可以正确地传递数据给后端。

在后端Java代码中,我们需要编写对应的方法,以接收并处理前端传递的数据。

通过在jeesite js 中调用这些方法,我们可以实现前后端的完美交互。

5. 总结与回顾通过本文的讨论,我们对jeesite js 调用Java方法有了更深入的了解。

我们深入探讨了基本步骤和具体实现方法,并希望这些内容能够为您在实际开发中带来帮助。

我们也意识到在前后端交互中需要严格的参数和路径设置,以确保数据的正确传输和处理。

6. 个人观点与理解对于jeesite js 调用Java方法这一主题,我个人认为它是前后端交互中的一项关键技术。

jeesite 说明文档-2.文件结构与配置

jeesite  说明文档-2.文件结构与配置

第2章文件结构与配置作者:ThinkGem更新日期:2014-4-8 1.文件结构1.1.源码目录src/main/java1.2.资源目录src/main/resource1.3.发布目录src/main/webapp1.4.执行目录dbbin2.jeesite.properties2.1.数据源配置# 数据库驱动,连接设置。

jdbc.driver=oracle.jdbc.driver.OracleDriverjdbc.url=jdbc:oracle:thin:@127.0.0.1:1521:orclername=jeesitejdbc.password=123456# 连接池设置,初始大小,最小,最大连接数。

jdbc.pool.init=1jdbc.pool.minIdle=3jdbc.pool.maxActive=20# 测试连接sql语句jdbc.testSql=SELECT'x'FROM DUAL2.2.系统配置# 配置产品名称,版权日期和版本号productName=JeeSite AdmincopyrightYear=2014version=V1.1.1# 是否是演示模式,如果是,则如下模块,无法进行保存操作# sys: area/office/user/role/menu/dict, cms: site/category demoMode=false# 管理端跟路径adminPath=/a# 前端跟路径frontPath=/f# 信息发布时的URL后缀,可配置HTML后缀的页面进行缓存urlSuffix=.html# 分页大小,默认每页15条page.pageSize=15# 硕正组件是否使用Cache(一般开发阶段,关闭Cache)eCache=false# 设置通知间隔访问时间,单位毫秒.oa.notify.remind.interval=600002.3.框架参数配置# 设置SESSION超时时间,web.xml里设置无效,单位毫秒. session.sessionTimeout=120000session.sessionTimeoutClean=120000# 缓存设置ehcache.configFile=cache/ehcache-local.xml#ehcache.configFile=cache/ehcache-rmi.xml# 首页地址web.view.index=/a# 视图文件配置,前缀和后缀web.view.prefix=/WEB-INF/views/web.view.suffix=.jsp# 最大上传字节数 10M=10*1024*1024(B)=10485760web.maxUploadSize=10485760# 设置日志拦截器,拦击的URI,@RequestMapping 值web.logInterceptExcludeUri=/,/login,/sys/menu/tree,/sys/menu/treeData,/oa/oaNotify/self/countweb.logInterceptIncludeRequestMapping=save,delete,import,updateSort# 工作流配置activiti.isSynActivitiIndetity=falseactiviti.export.diagram.path=c:/activiti_diagram#activiti font (windows font: \u5B8B\u4F53 linux font: simsun)activiti.diagram.activityFontName=\u5B8B\u4F53belFontName=\u5B8B\u4F53activiti.form.server.url=http://127.0.0.1:8075/xxxx3.pom.xml3.1.修改项目名称artifactId:项目名称version:版本修改完成后运行eclipse.bat重新生成项目文件。

JeeSite

JeeSite

JeeSite企业信息管理系统基础框架目录1.JEESITE概述 (4)1.1.简介 (4)1.2.为何选择 (4)1.3.相关技术 (5)1.4.安全考虑 (6)2.管理功能演示 (7)2.1.管理登录 (7)2.1.1.登录界面 (7)2.1.2.主题切换 (8)2.2.总体介绍 (11)2.2.1.客户端验证 (11)2.2.2.提交结果信息 (11)2.3.控制面板 (12)2.3.1.个人资料 (12)2.3.2.修改密码 (12)2.4.机构用户 (12)2.4.1.用户管理 (12)2.4.2.机构管理 (14)2.4.3.区域管理 (16)2.5.系统设置 (18)2.5.1.菜单管理 (18)2.5.2.角色管理 (19)2.5.3.字典管理 (21)2.6.内容管理 (22)2.6.1.内容管理 (22)2.6.2.评论管理 (27)2.6.3.栏目管理 (28)2.6.4.站点管理 (29)2.6.5.公共留言 (31)2.6.6.文件管理 (32)2.6.7.网站展示(基础主题) (34)3.功能组件 (40)3.1.U TILS (41)3.2.T AGLIB (42)3.3.EL F UNCTION (42)3.4.J AVA S CRIPT (42)4.快速体验 (42)4.1.在线体验 (42)4.2.本地体验 (43)5.交流、反馈、参与贡献 (43)6.未来开发计划 (43)1.JeeSite概述1.1.简介JeeSite是一个开源的企业信息管理系统基础框架。

主要定位于“企业信息管理”领域,可用作企业信息管理类系统、网站后台管理类系统等。

JeeSite是非常强调开发的高效性、健壮性和安全性的。

JeeSite是轻量级的,简单易学,本框架以Spring Framework为核心、Spring MVC(相比Struts2更容易上手、更易用)作为模型视图控制器、Spring Data JPA + Hibernate作为数据库操作层,此组合是Java界业内最经典、最优的搭配组合进行封装。

jeesite快速开发平台(七)----代码生成原理

jeesite快速开发平台(七)----代码生成原理

jeesite快速开发平台(七)----代码⽣成原理⼀、原理讲解jeesite代码⽣成⽤的是FreeMarker模板引擎结合xml技术来实现的,定义的模板都放在resources/templates/modules/gen下⼀看就知道crud就是基本的增删改查,dao是数据库操作,treetable是有关树⽅⾯的模板,其中主要的配置⽂件就是config.xml,该⽂件中定义了⽣成的模板,以及java类型,查询类型,字段显⽰类型等⼀些数据。

1. <?xml version="1.0" encoding="utf-8"?>2. <config>3. <!-- ⽣成分类 -->4. <category>5. <category value="curd" label="增删改查(单表)">6. <template>curd/controller.xml</template>7. <template>curd/service.xml</template>8. <template>category-ref:dao</template>9. <template>curd/viewForm.xml</template>10. <template>curd/viewList.xml</template>11. </category>12. <category value="curd_many" label="增删改查(⼀对多)">13. <template>curd/controller.xml</template>14. <template>curd/serviceMany.xml</template>15. <template>category-ref:dao</template>16. <template>curd/viewFormMany.xml</template>17. <template>curd/viewList.xml</template>18. <childTable>19. <template>category-ref:dao</template>20. </childTable>21. </category>22. <category value="dao" label="仅持久层(dao/entity/mapper)">23. <template>dao/dao.xml</template>24. <template>dao/entity.xml</template>25. <template>dao/mapper.xml</template>26. </category>27. <category value="treeTable" label="树结构表(⼀体)">28. <template>treetable/controller.xml</template>29. <template>treetable/service.xml</template>30. <template>treetable/dao.xml</template>31. <template>treetable/entity.xml</template>32. <template>treetable/mapper.xml</template>33. <template>treetable/viewForm.xml</template>34. <template>treetable/viewList.xml</template>35. </category>36. <category value="treeTableAndList" label="树结构表(左树右表)">37. <template>category-ref:dao</template>38. </category>39. </category>40. <!-- java类型 -->41. <javaType>42. <dict value="String" label="String"/>43. <dict value="Long" label="Long"/>44. <dict value="Integer" label="Integer"/>45. <dict value="Double" label="Double"/>46. <dict value="java.util.Date" label="Date"/>47. <dict value="er" label="User"/>48. <dict value="com.thinkgem.jeesite.modules.sys.entity.Office" label="Office"/>49. <dict value="com.thinkgem.jeesite.modules.sys.entity.Area" label="Area"/>50. <dict value="This" label="ThisObj" description="⽣成当前对象"/>51. <dict value="Custom" label="Custom" description="⾃定义对象,⽣成后⼿动设置"/>52. </javaType>53. <!-- 查询类型 -->54. <queryType>55. <dict value="=" label="="/>56. <dict value="!=" label="!="/>57. <dict value=">" label=">"/>58. <dict value=">=" label=">="/>59. <dict value="<" label="<"/>60. <dict value="<=" label="<="/>61. <dict value="between" label="Between"/>62. <dict value="like" label="Like"/>63. <dict value="left_like" label="Left Like"/>64. <dict value="right_like" label="Right Like"/>65. </queryType>66. <!-- 字段显⽰类型 -->67. <showType>68. <dict value="input" label="单⾏⽂本"/>69. <dict value="textarea" label="多⾏⽂本"/>70. <dict value="select" label="下拉选项"/>71. <dict value="radiobox" label="单选按钮"/>72. <dict value="checkbox" label="复选框"/>73. <dict value="dateselect" label="⽇期选择"/>74. <dict value="userselect" label="⼈员选择"/>75. <dict value="officeselect" label="部门选择"/>76. <dict value="areaselect" label="区域选择"/>77. <dict value="treeselect" label="树选择控件"/>78. <dict value="fileselect" label="⽂件上传选择"/>79. </showType>80. </config>其中1. <childTable>2. <template>category-ref:dao</template>3. </childTable>定义了⼦表,初看jeesite的代码⽣成,有个困惑的地⽅就是,⼀般通过FreeMarker进⾏代码⽣成定义的模板都是ftl格式的,⽽这⾥却是xml,什么⿁,难道这⾥不是⽤FreeMarker进⾏⽣成的??我们先来看下xml⽂件中的内容就清楚了:1. <?xml version="1.0" encoding="utf-8"?>2. <template>3. <name>controller</name>4. <filePath>src/main/java/${packageName}/${moduleName}/web/${subModuleName}</filePath>5. <fileName>${ClassName}Controller.java</fileName>6. <content><![CDATA[7. /**8. * Copyright &copy; 2012-2016 <a href="https:///thinkgem/jeesite">JeeSite</a> All rights reserved.9. */10. package ${packageName}.${moduleName}.web<#if subModuleName != "">.${subModuleName}</#if>;11.12. import javax.servlet.http.HttpServletRequest;13. import javax.servlet.http.HttpServletResponse;14.15. import org.apache.shiro.authz.annotation.RequiresPermissions;16. import org.springframework.beans.factory.annotation.Autowired;17. import org.springframework.stereotype.Controller;18. import org.springframework.ui.Model;19. import org.springframework.web.bind.annotation.ModelAttribute;20. import org.springframework.web.bind.annotation.RequestMapping;21. import org.springframework.web.bind.annotation.RequestParam;22. import org.springframework.web.servlet.mvc.support.RedirectAttributes;23.24. import mon.config.Global;25. import mon.persistence.Page;26. import mon.web.BaseController;27. import mon.utils.StringUtils;28. import ${packageName}.${moduleName}.entity<#if subModuleName != "">.${subModuleName}</#if>.${ClassName};29. import ${packageName}.${moduleName}.service<#if subModuleName != "">.${subModuleName}</#if>.${ClassName}Service;30.31. /**32. * ${functionName}Controller33. * @author ${functionAuthor}34. * @version ${functionVersion}35. */36. @Controller37. @RequestMapping(value = "${r"${adminPath}"}/${urlPrefix}")38. public class ${ClassName}Controller extends BaseController {39.40. @Autowired41. private ${ClassName}Service ${className}Service;42.43. @ModelAttribute44. public ${ClassName} get(@RequestParam(required=false) String id) {45. ${ClassName} entity = null;46. if (StringUtils.isNotBlank(id)){47. entity = ${className}Service.get(id);48. }49. if (entity == null){50. entity = new ${ClassName}();51. }52. return entity;53. }54.55. @RequiresPermissions("${permissionPrefix}:view")56. @RequestMapping(value = {"list", ""})57. public String list(${ClassName} ${className}, HttpServletRequest request, HttpServletResponse response, Model model) {58. Page<${ClassName}> page = ${className}Service.findPage(new Page<${ClassName}>(request, response), ${className});59. model.addAttribute("page", page);60. return "${lastPackageName}/${viewPrefix}List";61. }62.63. @RequiresPermissions("${permissionPrefix}:view")64. @RequestMapping(value = "form")65. public String form(${ClassName} ${className}, Model model) {66. model.addAttribute("${className}", ${className});67. return "${lastPackageName}/${viewPrefix}Form";68. }69.70. @RequiresPermissions("${permissionPrefix}:edit")71. @RequestMapping(value = "save")72. public String save(${ClassName} ${className}, Model model, RedirectAttributes redirectAttributes) {73. if (!beanValidator(model, ${className})){74. return form(${className}, model);75. }76. ${className}Service.save(${className});77. addMessage(redirectAttributes, "保存${functionNameSimple}成功");78. return "redirect:"+Global.getAdminPath()+"/${viewPrefix}/?repage";79. }80.81. @RequiresPermissions("${permissionPrefix}:edit")82. @RequestMapping(value = "delete")83. public String delete(${ClassName} ${className}, RedirectAttributes redirectAttributes) {84. ${className}Service.delete(${className});85. addMessage(redirectAttributes, "删除${functionNameSimple}成功");86. return "redirect:"+Global.getAdminPath()+"/${viewPrefix}/?repage";87. }88.89. }]]>90. </content>91. </template>其中的xml格式为:1. <?xml version="1.0" encoding="utf-8"?>2. <template>3. <name>controller</name>4. <filePath>src/main/java/${packageName}/${moduleName}/web/${subModuleName}</filePath>5. <fileName>${ClassName}Controller.java</fileName>6. <content><![CDATA[]]>7. </content>8. </template>发现其中的奥秘没,他把模板内容都放在了content标签的CDATA[]区。

jeesite介绍

jeesite介绍

JeeSite介绍框架简介JeeSite是一个开源的企业信息管理系统基础框架。

主要定位于“企业信息管理”领域,可用作企业信息管理类系统、网站后台管理类系统等。

JeeSite是非常强调开发的高效性、健壮性和安全性的。

JeeSite是轻量级的,简单易学,本框架以Spring Framework为核心、Spring MVC作为模型视图控制器、Hibernate作为数据库操作层,此组合是Java界业内最经典、最优的搭配组合。

前端界面风格采用了结构简单、性能优良、页面精致的Twitter Bootstrap作为前端展示框架。

JeeSite 已内置一系列企业信息管理系统的基础功能,目前包括三大模块,系统管理(SYS)模块、内容管理(CMS)模块和在线办公(OA)模块。

系统管理模块,包括企业组织架构(用户管理、机构管理、区域管理)、菜单管理、角色权限管理、字典管理等功能;内容管理模块,包括内容管理(文章、链接),栏目管理、站点管理、公共留言、文件管理、前端网站展示等功能;在线办公模块,提供简单的请假流程实例。

JeeSite提供了常用工具进行封装,包括日志工具、缓存工具、服务器端验证、数据字典、当前组织机构数据(用户、机构、区域)以及其它常用小工具等。

另外还提供一个基于本基础框架的代码生成器,为你生成基本模块代码,如果你使用了JeeSite基础框架,就可以很快速开发出优秀的信息管理系统。

为何选择1.使用Apache License2.0协议,源代码完全开源,无商业限制。

2.使用目前最主流的J2EE开发框架,简单易学,学习成本低。

3.数据库无限制,支持MySql、Oracle、SQL Server、H2等数据库。

4.模块化设计,层次结构清晰。

内置一系列企业信息管理的基础功能。

5.操作权限控制精密细致,对所有管理链接都进行权限验证,可控制到按钮。

6.数据权限控制精密细致,对指定数据集权限进行过滤,七种数据权限可供选择。

功能模块说明

功能模块说明

功能模块说明功能模块是指软件系统中独立的、可复用的、具有特定功能的组件。

一个软件系统通常由多个功能模块组成,每个模块负责实现系统中的一些具体功能。

下面是对几个常见的功能模块进行详细说明。

1.用户管理模块:这个模块负责管理系统的用户信息,包括用户的注册、登录、权限管理等功能。

用户管理模块通常还提供密码加密、用户信息存储和验证等功能,确保系统的安全性。

2. 数据库模块:这个模块负责管理系统的数据,包括数据的存储、检索和更新。

数据库模块需要提供数据库连接、数据表的创建和维护、数据查询和更新等功能。

常见的数据库模块有MySQL、Oracle等。

3.订单管理模块:这个模块负责管理系统中的订单信息,包括订单的创建、支付、发货、退货等功能。

订单管理模块通常还需要与库存管理模块进行交互,确保订单的库存充足。

4.财务管理模块:这个模块负责管理系统的财务信息,包括收入、支出、财务报表等功能。

财务管理模块需要提供账户管理、交易记录查询和统计等功能,以便系统管理员进行财务分析和决策。

6.报表模块:这个模块负责生成系统的各种报表,如销售报表、财务报表、库存报表等。

报表模块通常需要提供报表的生成、导出、打印等功能,以便系统管理员进行数据分析和决策。

7.日志模块:这个模块负责记录系统中的操作日志和错误日志,以便进行系统监控和故障排查。

日志模块通常需要提供日志的记录、查询和分析等功能,以便快速定位和解决问题。

8.授权模块:这个模块负责实现系统的访问控制和权限管理,以确保只有具备相应权限的用户才能访问系统的特定功能。

授权模块通常需要提供用户权限的定义、角色管理、菜单管理等功能,以便系统管理员进行权限配置。

9.工作流模块:这个模块负责管理系统中的业务流程,包括任务分配、处理流程和流程监控等功能。

工作流模块通常需要提供工作流的设计、执行和调度等功能,以便系统管理员进行业务流程管理。

总之,一个软件系统的功能模块是系统中独立且可复用的组件,每个模块负责实现系统中的一些具体功能。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

安全模块
用户密码加密存储
用户密码加密算法:对用户的密码进行sha-1算法加密。

迭代1024次,并将salt放在前16位中。

SystemService中
/**
* 生成安全的密码,生成随机的16位salt并经过1024次 sha-1 hash
*/
public static String entryptPassword(String plainPassword) { byte[] salt = Digests.generateSalt(SALT_SIZE);//16
byte[] hashPassword =
Digests.sha1(plainPassword.getBytes(), salt, HASH_INTERATIONS);
return
Encodes.encodeHex(salt)+Encodes.encodeHex(hashPassword);
}
解密同步配置:因为用户密码在存储的时候是用的加密存储,所以对应的解密一定要一至细节如下。

SystemAuthorizingRealm中
@PostConstruct
public void initCredentialsMatcher() {
HashedCredentialsMatcher matcher = new HashedCredentialsMatcher(SystemService.HASH_ALGORITHM);//SHA-1 matcher.setHashIterations(SystemService.HASH_INTERATIONS);/ /1024
setCredentialsMatcher(matcher);
}
安全码验证
当同一个用户请超过3次。

用户登陆页面(sysLogin.jsp)向ValidateCodeServlet请求验证图片
ValidateCodeServlet生成验证图片并存入Session中
系统扩展了SystemAuthorizingRealm ,FormAuthenticationFilter 和UsernamePasswordToken两个类
在Shiro验证的时候FormAuthenticationFilter会提取出validateCode并存入UsernamePasswordToken中
然后在SystemAuthorizingRealm中先判断是否需要验证validateCode
如果需要则从session中获取先前存入的session code并与UsernamePasswordToken 中的code进行比对
主题更换
在head.jsp中通过查询cookie.theme.value值来替换bootstrap的css文件,默认是'cerulean',细节如下:
<link href="${ctxStatic}/bootstrap/2.3.1/css_${not empty cookie.theme.value ?
cookie.theme.value:'cerulean'}/bootstrap.min.css"
type="text/css" rel="stylesheet" />
更改主题的接口为:
LoginControler中
@RequestMapping(value = "/theme/{theme}")
public String getThemeInCookie(@PathVariable String theme, HttpServletRequest request, HttpServletResponse response){ if (StringUtils.isN otBlank(theme)){
CookieUtils.setCookie(response, "theme", theme);
}else{
theme = CookieUtils.getCookie(request, "theme");
}
return"redirect:"+request.getParameter("url");
}
缓存设计
对每一个用户所需要用到的资源都用Map做了缓存。

如果用户不存在则是创建一个Map<String, Object>对象,如果存在,则取principal中的Map<String, Object>对象做为缓存,因为principal会随着用户的logout自动释放,每一个用户都有自己的缓存。

这样每个用户的缓存是独立的。

获取逻辑如下
public static Map<String, Object> getCacheMap(){
Map<String, Object> map = Maps.newHashMap();
try{
Subject subject = SecurityUtils.getSubject();
Principal principal =
(Principal)subject.getPrincipal();
return principal!=null?principal.getCacheMap():map;
}catch (UnavailableSecurityManagerException e) {
}catch (InvalidSessionException e){
}
return map;
}
放入Shiro管理的principal是自定义的如下:
SystemAuthorizingRealm中的子类
public static class Principal implements Serializable
用户信息模块
与用户相关的接口全部在UserController中。

所有接口先统一通过下面代码获取用户信息。

如果当前用户没有给定id则认为是新用户。

创建一个空用户
@ModelAttribute
public User get(@RequestParam(required=false) String id) { if (StringUtils.isNotBlank(id)){
return systemService.getUser(id);
}else{
return new User();
}
}
创建用户接口
/sys/user/form
从下面代码可以看出,谁创建的就以谁的公司和办公室为默认值
if(user.getCompany() == null|| user.getCompany().getId() == null) {
user.setCompany(UserUtils.getUser().getCompany());//
用当前用户所在的公司创建
}
if(user.getOffice() == null|| user.getOffice().getId() == null) {
user.setOffice(UserUtils.getUser().getOffice());//用
当前用户所在办公室创建
}
默认根路径跳转
<!-- 定义无Controller的path<->view直接映射 -->
<mvc:view-controller path="/"
view-name="redirect:${web.view.index}"/>
翻页处理
mon.persistence.Page<T>
的toString()方法中实现BootStrap显示细节,因为数据在Page之中。

在Jsp页面中使用<div class="pagination">${page}</div>
roleForm.jsp中树形目录选择
office弹出对话框式树型选择
用tags:treeselect标签将界面操作逻辑封装
在tags:treeselect中用jBox来调用/tag/treeselect转向tagTreeselect.jsp页面,并传入相关参数,其中重要的参数为url,即要展示的JSON格式数据来源
tagTreeselect.jsp:中只负责数据展示,与选择等相关操作。

(用zNode tree 来展示)
当发生“确定”与双击操作时都是调用jBox的ok键
而ok键事件发生后:jBox会拿到tree结点对像,并从对像上获取id和name 并写入input中
角色授权树型选择操作
先通过后台传过来的数据构建zNode tree
由zNode tree来管理数据的选择
在表单提交时(submitHandler)获取选择数据并添加到相应的input中。

然后提交。

如下图
这里用了一个小技巧。

springMVC 进行前后台数据绑定的时候其实是调用Model的set与get 方法。

(所以只要有这两个方法即可,不用有成员变员也行)
给Role模型添加了两个方法,并用Transient来标记不写入数据库。

如下
这样就可以自动把数据写回到Role中。

相关文档
最新文档