jeesite介绍

合集下载

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流程条件表达式

jeesite流程条件表达式

jeesite流程条件表达式Jeesite流程条件表达式的作用和使用方法Jeesite作为一款开源的企业级快速开发平台,广泛应用于各种Web应用的开发中。

其流程引擎模块提供了强大的流程管理功能,可以帮助开发者快速构建复杂的流程系统。

而在Jeesite流程引擎中,条件表达式则扮演着重要的角色,用于控制流程中各个环节的执行条件,从而实现流程的逻辑控制。

Jeesite的流程条件表达式支持多种类型的表达式,包括布尔表达式、数值比较表达式、日期比较表达式等。

开发者可以根据实际需求选择合适的表达式类型,并通过简单的配置实现复杂的条件判断。

下面将逐一介绍这些表达式的使用方法。

布尔表达式是最常用的条件表达式类型之一,用于判断某个变量或表达式的真假。

在Jeesite中,可以使用"=="、"!="、"&&"、"||"等运算符构建布尔表达式。

例如,可以使用"#{entity.status == '1'}"来判断实体的状态是否为1。

如果为真,则执行相应的操作,否则跳过。

数值比较表达式用于判断两个数值之间的大小关系。

Jeesite支持大于、小于、等于等比较操作符。

例如,可以使用"#{entity.age > 18}"来判断实体的年龄是否大于18岁。

如果为真,则执行相应的操作,否则跳过。

日期比较表达式用于判断两个日期之间的先后关系。

Jeesite支持大于、小于、等于等比较操作符。

例如,可以使用"#{entity.joinDate < '2021-01-01'}"来判断实体的入职日期是否早于2021年1月1日。

如果为真,则执行相应的操作,否则跳过。

除了以上介绍的表达式类型,Jeesite还支持更多的条件表达式,如字符串比较表达式、集合包含表达式等。

jeesite 页面 formatter 用法 -回复

jeesite 页面 formatter 用法 -回复

jeesite 页面formatter 用法-回复jeesite是一个基于Java的快速开发平台,提供了大量的开发工具和畅捷的开发方式,使开发人员能够快速构建高质量的Web应用程序。

其中,页面formatter是jeesite平台中一个非常重要的组件,它主要用于对页面的数据进行格式化和处理,以达到页面数据展示的规范和美观效果。

在jeesite平台上,我们可以使用页面formatter实现以下几个方面的功能:1. 数据格式化:jeesite的页面formatter可以帮助我们对页面上展示的数据进行格式化处理。

例如,在用户管理模块中,我们可能需要将用户的注册时间以特定的格式展示,使用formatter就可以很方便地实现这一需求。

2. 数据转换:有时候,我们需要将页面上展示的数据进行转换,例如将数字型的数据转换为字符型,或者将日期型的数据转换为特定的显示格式。

在jeesite平台上,我们可以通过定义formatter来实现这些转换功能,使得页面数据的展示更加符合用户的需求。

3. 数据校验:在表单提交的过程中,我们需要对输入的数据进行校验,以保证数据的合法性。

jeesite的formatter组件提供了强大的数据校验功能,可以帮助开发人员快速实现表单校验的需求,提高开发效率和数据安全性。

使用jeesite页面formatter的步骤如下:步骤一:创建formatter类首先,我们需要创建一个类来实现formatter的功能。

这个类通常继承自jeesite中的Formatter类,并实现其中的format和parse方法。

format 方法用于将数据格式化为字符串进行展示,而parse方法则用于将字符串解析为数据类型进行后续处理。

步骤二:注册formatter在jeesite平台上,我们需要将自定义的formatter注册到系统中,以便系统能够识别和使用这个formatter。

注册的方式通常是在系统启动时将formatter添加到FormatterRegistry中。

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 字段控制

jeesite 字段控制

jeesite 字段控制Jeesite字段控制为标题,下面将介绍Jeesite中的字段控制功能以及它的作用。

一、什么是Jeesite字段控制?Jeesite是一款基于Java开发的开源框架,用于快速搭建企业级Java Web应用。

在Jeesite中,字段控制是指通过对表单中的字段进行配置和管理,实现对字段的显示、验证、权限等方面的控制。

通过字段控制,开发人员可以灵活地对表单进行定制,满足不同业务需求。

二、字段控制的作用1. 显示控制:字段控制可以根据业务需求决定字段是否显示。

例如,在某些情况下,某个字段可能需要隐藏起来,只在特定条件下才显示出来,通过字段控制就可以实现这一功能。

2. 验证控制:字段控制可以对字段进行验证,确保用户输入的数据符合一定的规则和格式。

例如,对于手机号码字段,可以通过字段控制设置必须为11位数字的验证规则。

3. 权限控制:字段控制可以对字段的访问权限进行管理。

通过字段控制,可以设置某些字段只能由特定角色或用户访问,从而实现对敏感数据的保护。

4. 其他控制:字段控制还可以实现其他一些功能,如字段的默认值设置、只读控制等。

三、如何进行字段控制在Jeesite中,字段控制是通过在实体类中使用注解来实现的。

以下是一些常用的字段控制注解:1. @FormField:用于配置字段的显示名称、验证规则等信息。

2. @ExcelField:用于配置字段在Excel导入导出时的相关信息。

3. @ShowInView:用于配置字段在列表、详情等页面中的显示方式。

4. @DataScope:用于配置字段的权限控制范围。

5. @DictType:用于配置字段的字典类型,实现数据字典的功能。

四、字段控制的实例下面以一个示例来说明字段控制的实际应用。

假设有一个用户管理系统,其中包含一个用户信息表,需要对用户信息进行管理和展示。

在这个示例中,我们可以使用字段控制来实现以下功能:1. 设置用户名字段为必填项,并限制长度为6-20个字符。

jeesite 的save 方法

jeesite 的save 方法

jeesite 的save 方法【原创版6篇】篇1 目录1.jeesite 的 save 方法的概述2.save 方法的主要功能3.save 方法的使用方法4.save 方法的优点和局限性5.总结篇1正文一、jeesite 的 save 方法的概述jeesite 是一款非常实用的网站开发框架,它提供了许多高效的工具和方法,以帮助开发者快速构建高质量的网站。

在 jeesite 中,save 方法是一个非常重要的方法,它可以帮助开发者实现数据的保存和更新。

二、save 方法的主要功能save 方法的主要功能是保存和更新数据。

它可以帮助开发者将数据保存到数据库中,同时也可以更新已有的数据。

在使用 save 方法时,开发者可以根据需要指定数据的保存条件和更新策略。

三、save 方法的使用方法在使用 save 方法时,开发者需要首先创建一个数据模型,然后通过调用 save 方法来保存或更新数据。

以下是一个简单的示例:```// 创建一个数据模型class User {// 构造函数constructor(name, age) { = name;this.age = age;}}// 保存数据const user = new User("Tom", 25);user.save(); // 将数据保存到数据库中```四、save 方法的优点和局限性save 方法的优点在于它可以帮助开发者快速地保存和更新数据,同时也可以方便地管理数据的状态。

然而,save 方法也存在一些局限性,例如它只能用于保存和更新简单的数据模型,对于复杂的数据结构和业务逻辑,需要开发者自行实现。

五、总结总的来说,jeesite 的 save 方法是一个非常实用的工具,它可以帮助开发者快速地保存和更新数据。

篇2 目录1.jeesite 的 save 方法的概述2.save 方法的参数3.save 方法的使用示例4.save 方法的优点和局限性篇2正文一、jeesite 的 save 方法的概述jeesite 是一款非常实用的 Java 模板引擎,它提供了许多功能强大的 API,使得开发者能够轻松地实现各种复杂的业务逻辑。

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中的posthandle作用 -回复

jeesite中的posthandle作用 -回复

jeesite中的posthandle作用-回复jeesite中的postHandle作用是什么?在解答这个问题之前,我们先来了解一下什么是Jeesite。

Jeesite是一套基于Java语言开发的开源企业级快速开发平台,它提供了一系列的开发工具和框架,使开发者能够快速地搭建起一个企业级应用系统。

Jeesite平台具有可扩展、高效、安全、易维护等特点,因此也受到了众多开发者的青睐。

在Jeesite中,postHandle是一种拦截器(Interceptor)中定义的方法。

拦截器是一种应用于请求处理过程的组件,它允许开发者在请求被处理之前或之后执行自定义的操作。

postHandle方法是在Controller方法处理完请求之后被调用的,也就是说它是在请求处理完成后,但是在视图渲染之前执行的。

postHandle方法的作用主要有以下几个方面:1. 处理公共逻辑:开发者可以在postHandle方法中编写公共的逻辑代码,如日志记录、异常处理、结果统计等。

这样可以避免在每个Controller的方法中都重复编写这些代码,提高了代码的复用性和可维护性。

2. 操作ModelAndView对象:ModelAndView对象是Controller方法处理请求之后返回的视图模型对象,它包含了需要渲染到页面的数据和视图的名称。

在postHandle方法中,开发者可以对ModelAndView对象进行一些操作,如添加一些额外的数据、修改视图名称等。

这样可以实现一些与业务无关的通用操作,如添加菜单导航、展示广告等。

3. 设置响应字符编码:在postHandle方法中,开发者可以通过修改HttpServletResponse对象的字符编码来设置响应的字符集。

这对于处理中文乱码等问题非常有用。

4. 控制请求的跳转:如果在postHandle方法中返回false,那么请求将会被中断,不再继续执行后续的拦截器和控制器方法。

这个特性可以用于权限控制、登录验证等操作,开发者可以根据需要来决定是否允许请求继续处理。

JEESITE快速开发平台(二)环境搭建

JEESITE快速开发平台(二)环境搭建

JEESITE快速开发平台(⼆)环境搭建⼀、下载源码下载地址:这⾥使⽤Mybatis版本的进⾏演⽰。

下载之后解压:他提供的⼀些⽂档⼆、环境搭建下⾯是官⽹提供的演⽰⽅法:快速体验1.具备运⾏环境:JDK1.6+、Maven3.0+、MySql5+或Oracle10g+。

2.修改src\main\resources\jeesite.properties⽂件中的数据库设置参数。

3.根据修改参数创建对应MySql或Oracle数据库⽤户和参数。

可以⼿动新建jeesite数据库,也可以通过init-db.bat脚本⾃动创建导⼊db⽬录下的sql⽂件这⾥使⽤SQLyog客户端,选中数据库右键--->导⼊---->从SQL存储⽂件导⼊数据库然后点击执⾏,执⾏完毕后4.运⾏bin\init-db.bat脚本,即可导⼊表结构及演⽰数据(linux操作系统:在控制台中切换⾄项⽬根⽬录,运⾏命令:mvn antrun:run -Pinit-db)在bin⽬录⾥并没有发现有init-db.bat脚本⽽是在db⽬录⾥注意: 在执⾏init-db.bat之前要先创建jeesite数据库,否则会报错:创建jeesite数据库之后,执⾏init-db.bat创建成功5.运⾏bin\run-tomcat7.bat或bin\run-jetty.bat,启动Web服务器(第⼀次运⾏,需要下载依赖jar包,请耐⼼等待)。

报错: java.sql.SQLException: Access denied for user 'root'@'localhost' (using password: YES)修改jeesite.properties中的jdbc.url把localhost改为127.0.0.1然后从新运⾏run-tomcat7.bat6.输⼊最⾼管理员账号,⽤户名:thinkgem 密码:admin点击登录这就是jeesite默认的页⾯。

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.数据权限控制精密细致,对指定数据集权限进行过滤,七种数据权限可供选择。

jeesite流程

jeesite流程

Jeesite流程1.Jeesite流程2.关于shiro授权3.Orm对象关系映射4.Mybatis的总体流程是一.Jeesite流程(主要是jsp,entity,dao,dao.xml,service,controller)(1).MyBatisRegisterDao.xml(2).MyBatisRegisterDao.java(3).Register.java实体(4).RegisterService.java(5).RegisterController.java(6).Register.jsp二.关于shiro授权1.Shiro授权的三要素是:权限,角色,用户2.三要素的关联:因为通过声明权限我们仅仅能了解这个权限在项目中能做什么,而不能确定谁有这个权限,所以,我们需要在应用程序中对用户和权限建立关系。

3.在项目上: 我们一般将权限分配给某个角色,然后将这个角色分配给一个或多个用户,例如:修改的权限是只有管理员才拥护的,那么,在这个时候,管理员就相当于被设于拥有修改权限的用户,4.shiro支持三种授权方式:编码实现,注解实现,jsp Tag实现三.Orm对象关系映射1.用于实现面向对象编程语言里不同类型系统的数据之间的转换2.在jeesite框架中用到的就是mybatis四.Mybatis的总体流程是1.加载配置并初始化,其触发条件是加载配置文件将SQL 的配置信息加载成为一个个MappingStatement对象(包括传入参数映射配置,执行的sql语句,结果映射配置) 存储在内存中2.接收调用请求,其触发条件是调用mybatis中的api,将请求传递给下层的请求处理层处理3.处理操作请求,api接口层传递传递请求过来,传入sql的id和传入参数,根据sql的id查找对应的MappingStatement对象,和传入参数对象解析MappingStatement对象,得到最终要执行的sql和执行传入参数,后获取数据库连接,根据最终得到的sql语句和传入参数到数据库执行,得到最终的处理结果,最后释放资源4.将最终处理结果返回。

jeesite 解析html代码

jeesite 解析html代码

jeesite 解析html代码Jeesite: 解析HTML代码HTML (Hypertext Markup Language) 是用于构建网页的一种标记语言。

在web 开发中,解析HTML代码是一个常见的任务,开发人员经常需要从HTML中抓取数据、分析结构或进行其他操作。

Jeesite是一个基于Java的开源框架,提供了许多功能来简化web应用程序的开发和管理,包括解析HTML代码的能力。

本文将介绍如何使用Jeesite解析HTML代码。

首先,我们需要在项目中引入Jeesite框架的依赖包。

可以在项目的pom.xml文件中添加以下代码:```xml<dependency><groupId>com.jeesite</groupId><artifactId>jeesite-module</artifactId><version>1.0.0</version></dependency>```完成依赖包的添加后,我们可以开始编写代码来解析HTML代码。

```javaimport mon.utils.StringUtils;import org.jsoup.Jsoup;import org.jsoup.nodes.Document;import org.jsoup.nodes.Element;import org.jsoup.select.Elements;public class HTMLParser {public static void main(String[] args) {String html = "<html><head><title>Example</title></head><body><h1>Hello, world!</h1></body></html>";// 使用Jsoup解析HTML代码Document doc = Jsoup.parse(html);// 获取HTML的title标签内容String title = doc.title();System.out.println("Title: " + title);// 获取HTML的h1标签内容Element h1Element = doc.selectFirst("h1");String h1Text = h1Element.text();System.out.println("H1: " + h1Text);// 遍历HTML中的所有链接Elements links = doc.select("a");for (Element link : links) {String linkHref = link.attr("href");String linkText = link.text();System.out.println("Link: " + linkText + " (" + linkHref + ")");}// 获取HTML中的所有文本内容String text = doc.body().text();System.out.println("Text: " + text);}}```上述代码中,我们首先定义了一个html变量,它包含了待解析的HTML代码。

jeesite elastisearch 全文检索实践

jeesite elastisearch 全文检索实践

jeesite elastisearch 全文检索实践JeeSite Elasticsearch 全文检索实践在当今信息爆炸的时代,有效地检索和管理大量的数据变得尤为重要。

而对于开发者和系统管理员来说,如何构建一个高效的全文检索系统也是一项具有挑战性的任务。

JeeSite作为一个成熟的Java开发框架,为我们提供了一个简单且强大的解决方案,将Elasticsearch与JeeSite框架相结合,可以快速实现高效的全文检索。

一、什么是Elasticsearch?Elasticsearch是一个开源的分布式全文检索引擎,它构建在Apache Lucene之上,并实现了全文检索和分析引擎的分布式特性。

它具有快速、可扩展和易于使用的特点,并支持复杂的查询和分析。

Elasticsearch采用倒排索引的方式存储数据,并通过分片和副本的方式实现高可用性和容错性。

二、为什么选择Elasticsearch?相比于传统的关系数据库,Elasticsearch具有以下几点优势:1. 高性能:Elasticsearch利用倒排索引和分布式架构,可以快速地进行全文检索和复杂查询。

它还支持实时索引和数据更新,所以非常适合实时应用。

2. 可扩展性:Elasticsearch可以轻松地扩展到数百台服务器,通过分片和副本的方式实现负载均衡和容错性。

3. 强大的查询功能:Elasticsearch支持全文搜索、过滤、聚合等强大的查询功能,可以满足各种复杂的检索需求。

4. 多语言支持:Elasticsearch支持多种语言的分析和处理,可以处理各种语言的全文搜索和分析需求。

三、如何在JeeSite中使用Elasticsearch?在JeeSite中使用Elasticsearch,需要进行以下几个步骤:1. 安装Elasticsearch:首先需要将Elasticsearch安装在服务器上,并启动Elasticsearch服务。

2. 配置JeeSite:在JeeSite的配置文件中,需要添加Elasticsearch相关的配置,包括Elasticsearch服务器地址、索引名称等。

关于jeesite工作流使用样例说明

关于jeesite工作流使用样例说明

一、场景介绍Jeesite使用的是activiti工作流,本次我们主要用于实现简单的审批流程:1、审批环节和修改环节执行前需要动态分配调用对象2、流程变量中需要记录事项id,方便整个流程获取二、模型建立<?xml version="1.0" encoding="UTF-8"?><definitions xmlns="/spec/BPMN/20100524/MODEL" xmlns:xsi="/2001/XMLSchema-instance" xmlns:xsd="/2001/XMLSchema" xmlns:activiti="/bpmn" xmlns:bpmndi="/spec/BPMN/20100524/DI" xmlns:omgdc="/spec/DD/20100524/DC" xmlns:omgdi="/spec/DD/20100524/DI" typeLanguage="/2001/XMLSchema" expressionLanguage="/1999/XPath" targetNamespace="/processdef"><process id="approve_process" name="业务受理" isExecutable="true"><startEvent id="start" name="开始" activiti:formKey="/ywsl/auditProcess/form"></startEvent><userTask id="audit" name="审批" activiti:formKey="/ywsl/auditProcess/audit"><extensionElements><activiti:taskListener event="create" delegateExpression="${candidateListener}"></activiti:taskListener></extensionElements></userTask><sequenceFlow id="sid-8955ECAD-719A-47C1-A41F-A32EA610C5DF" sourceRef="start" targetRef="audit"></sequenceFlow> <exclusiveGateway id="sid"></exclusiveGateway><sequenceFlow id="sid-D0995983-1EB6-4648-AB81-288CB62D94DE" sourceRef="audit" targetRef="sid"></sequenceFlow><endEvent id="sid-6C375AA3-07B6-4F46-9816-BFAA99CE9BDC" name="结束"></endEvent><userTask id="update" name="修改"><extensionElements><activiti:taskListener event="create" delegateExpression="${assigneeListener}"></activiti:taskListener></extensionElements></userTask><sequenceFlow id="sid-2461127D-B47F-4361-A472-D8C565E2DB15" sourceRef="update" targetRef="audit"></sequenceFlow> <sequenceFlow id="pass" name="通过" sourceRef="sid" targetRef="sid-6C375AA3-07B6-4F46-9816-BFAA99CE9BDC"><conditionExpression xsi:type="tFormalExpression"><![CDATA[${pass == 1}]]></conditionExpression></sequenceFlow><sequenceFlow id="reject" name="驳回" sourceRef="sid" targetRef="update"><conditionExpression xsi:type="tFormalExpression"><![CDATA[${pass == 0}]]></conditionExpression></sequenceFlow></process><bpmndi:BPMNDiagram id="BPMNDiagram_approve_process"><bpmndi:BPMNPlane bpmnElement="approve_process" id="BPMNPlane_approve_process"><bpmndi:BPMNShape bpmnElement="start" id="BPMNShape_start"><omgdc:Bounds height="30.0" width="30.0" x="162.3333282470703" y="155.0"></omgdc:Bounds></bpmndi:BPMNShape><bpmndi:BPMNShape bpmnElement="audit" id="BPMNShape_audit"><omgdc:Bounds height="80.0" width="100.0" x="237.3333282470703" y="130.0"></omgdc:Bounds></bpmndi:BPMNShape><bpmndi:BPMNShape bpmnElement="sid" id="BPMNShape_sid"><omgdc:Bounds height="40.0" width="40.0" x="420.0" y="150.0"></omgdc:Bounds></bpmndi:BPMNShape><bpmndi:BPMNShape bpmnElement="sid-6C375AA3-07B6-4F46-9816-BFAA99CE9BDC" id="BPMNShape_sid-6C375AA3-07B6-4F46-9816-BFAA99CE9BDC"><omgdc:Bounds height="28.0" width="28.0" x="525.0" y="156.0"></omgdc:Bounds></bpmndi:BPMNShape><bpmndi:BPMNShape bpmnElement="update" id="BPMNShape_update"><omgdc:Bounds height="80.0" width="100.0" x="390.0" y="15.0"></omgdc:Bounds></bpmndi:BPMNShape><bpmndi:BPMNEdge bpmnElement="reject" id="BPMNEdge_reject"><omgdi:waypoint x="440.4130434782609" y="150.41304347826087"></omgdi:waypoint><omgdi:waypoint x="440.17316017316017" y="95.0"></omgdi:waypoint><bpmndi:BPMNLabel><omgdc:Bounds height="0.0" width="0.0" x="440.4130434782609" y="150.41304347826087"></omgdc:Bounds></bpmndi:BPMNLabel></bpmndi:BPMNEdge><bpmndi:BPMNEdge bpmnElement="sid-8955ECAD-719A-47C1-A41F-A32EA610C5DF" id="BPMNEdge_sid-8955ECAD-719A-47C1-A41F-A32EA610C5DF"><omgdi:waypoint x="192.3333282470703" y="170.0"></omgdi:waypoint><omgdi:waypoint x="237.3333282470703" y="170.0"></omgdi:waypoint></bpmndi:BPMNEdge><bpmndi:BPMNEdge bpmnElement="sid-2461127D-B47F-4361-A472-D8C565E2DB15" id="BPMNEdge_sid-2461127D-B47F-4361-A472-D8C565E2DB15"><omgdi:waypoint x="390.0" y="92.66375420370463"></omgdi:waypoint><omgdi:waypoint x="337.3333282470703" y="132.33624579629537"></omgdi:waypoint></bpmndi:BPMNEdge><bpmndi:BPMNEdge bpmnElement="sid-D0995983-1EB6-4648-AB81-288CB62D94DE" id="BPMNEdge_sid-D0995983-1EB6-4648-AB81-288CB62D94DE"><omgdi:waypoint x="337.3333282470703" y="170.16322088685408"></omgdi:waypoint><omgdi:waypoint x="420.43449781877615" y="170.43449781877615"></omgdi:waypoint></bpmndi:BPMNEdge><bpmndi:BPMNEdge bpmnElement="pass" id="BPMNEdge_pass"><omgdi:waypoint x="459.5969387755102" y="170.4030612244898"></omgdi:waypoint><omgdi:waypoint x="525.0001803670469" y="170.07106507427895"></omgdi:waypoint><bpmndi:BPMNLabel><omgdc:Bounds height="0.0" width="0.0" x="459.5969387755102" y="170.4030612244898"></omgdc:Bounds> </bpmndi:BPMNLabel></bpmndi:BPMNEdge></bpmndi:BPMNPlane></bpmndi:BPMNDiagram></definitions>说明:1、审批和修改任务节点增加事前监听,用于动态创建接收用户2、开始节点和审批节点增加对应需要处理的表单三、流程编写过程。

Jeesite开发手册_04、业务逻辑层、数据权限、数据事务处理、通用基类

Jeesite开发手册_04、业务逻辑层、数据权限、数据事务处理、通用基类

业务逻辑层、数据权限、数据事务处理、通用基类 - JeeSite 4.x•引言•数据权限–角色数据范围–控制业务范围–快速开始•第一步•第二步•第三步–扩展数据权限–附:API•数据库事务–注解属性–事务传播行为–事务隔离级别•基类及接口的继承关系–QueryService 查询抽象基类–CrudService 增删改抽象基类–TreeService 树结构抽象基类•其它使用技巧–分页逻辑说明–MAP参数分页–覆写内置Service引言对于业务逻辑层的开发重复代码很多,尽管有代码生成器,但从代码量总的来说还是比较多,所以就有了以下抽象类及工具,对一些常用操作进行封装。

对通用新增、删除、编辑、查询,代码操作进行封装简化。

你只需要写你的业务逻辑代码就可以了。

对特有树状结构特有字段如(所有父级编码、所有排序号编码、是否是叶子节点、当前节点层次)进行更新,比如,通过所有父级编码可快速查询到所有子级的数据;通过所有排序号,可快速对整个树结构进行排序;通过是否叶子节点快速得知是否有下级;根据当前层次快速知道当前节点在树中的级别。

对通用数据权限进行简化封装,将颗粒度降到人员身上,支持人员与数据,角色与数据权限定制(角色上的数据权限与人员身上的数据权限为或者关系)。

数据权限不仅仅支持公司、部门、角色,还可以通过配置支持你的业务字段数据信息过滤,如订单的区域、内容管理的栏目、故障单类型等等。

对事务处理使用Spring事务@Transactional注解,进行方法级别的事务控制,不用单独处理事务及回滚。

如配置传播行为,进行事务继承,子事务,事务回滚行为等,配置隔离级别读取未提交的数据等。

数据权限相对于旧版本,本次对数据权限这块进行了全面的升级,让数据权限颗粒度细化到人员身上。

支持人员与权限和角色与权限:主要是这两张表:js_sys_role_data_scope、js_sys_user_data_scope权限表中的关键字段的含义,如下:•控制类型:Office:部门;Company:公司、Role:角色;•控制数据:被控制数据权限的数据主键编号,业务表的主键编号;•控制权限:1:拥有的权限(DataScope.CTRL_PERMI_HAVE);2:管理的权限(DataScope.CTRL_PERMI_MANAGE)。

jeesite 页面 formatter 用法

jeesite 页面 formatter 用法

jeesite 页面 formatter 用法
Jeesite是一个Java快速开发平台,它的页面Formatter可以对当前列的数据进行格式化操作。

Formatter是一个函数,有三个参数:value、row和index。

下面是其用法示例:```html
<el-table-column prop="isLine" label="是否在线" :formatter="dateFormat"> </el-table-column>
```
在上面的代码中,:formatter="dateFormat"表示使用dateFormat函数对“是否在线”列的数据进行格式化。

dateFormat函数的参数包括row、column、cellValue和index,通过这些参数可以获取到当前单元格的值、所在行和所在行的下标。

然后,根据实际需求对数据进行处理和格式化,并将结果返回显示在单元格中。

你可以根据实际情况调整Formatter函数的参数和处理逻辑,以满足不同的数据格式化需求。

如果你还需要了解关于Jeesite的更多用法,可以继续向我提问。

JEESITE快速开发平台(五)用户-角色-部门-区域-菜单-权限表关系

JEESITE快速开发平台(五)用户-角色-部门-区域-菜单-权限表关系

JEESITE快速开发平台(五)⽤户-⾓⾊-部门-区域-菜单-权限表关系⼀、表关系⼀共有8张表分别⽤来实现⽤户-⾓⾊-部门-区域-菜单-权限管理,详细如下:⼆、SQL语句[java]1. /*********************⼀共⼋张表************************/2.3. select * from sys_user; //⽤户表4. select * from sys_menu; //菜单表5. select * from sys_role; //⾓⾊表6. select * from sys_user_role; //⽤户⾓⾊表7. select * from sys_role_menu; //⾓⾊与菜单表8. select * from sys_area; //区域表9. select * from sys_office; //公司和部门表10. select * from sys_role_office; //⾓⾊与部门表11.12. /*********************⽤户关联⾓⾊************************/13.14. select * from sys_user where id='11'15. select * from sys_user_role where user_id='11'16. select * from sys_role where id='3'17.18. select count(1),user_id from sys_user_role GROUP BY user_id19. select count(*) from sys_user_role where user_id='1'20.21. select , as rolename from (select * from sys_user where id='1') us22. left JOIN sys_user_role usrole on us.id=er_id23. LEFT JOIN sys_role sr on usrole.role_id = sr.id24.25. /****以⽤户表为主表(通过sys_user的ID关联sys_user_role中的user_id,然后再通过sys_user_role中的role_Id关联⾓⾊表)****/26. select as username, as rolename from sys_user su27. LEFT JOIN sys_user_role sur on su.id = er_id28. LEFT JOIN sys_role sr on sur.role_id = sr.id29.30. /****以⾓⾊表为主表(通过sys_role的id关联sys_user_role中的role_id,然后再通过sys_user_role中的user_id关联sys_ser表中的id)****/31. SELECT as uname, as rolename FROM sys_role a32. LEFT JOIN sys_user_role ur ON ur.role_id = a.id33. LEFT JOIN sys_user u ON u.id = er_id34.35. select * from sys_user_role; //⽤户⾓⾊表36. select * from sys_role; //⾓⾊表37.38.39. /*********************⾓⾊关联菜单************************/40.41. /****以⾓⾊表为主表****/42. SELECT u.id as userid, as username,a.id as roleid, as rolename, menuname FROM sys_role a43. LEFT JOIN sys_user_role ur ON ur.role_id = a.id44. LEFT JOIN sys_user u ON u.id = er_id45. LEFT JOIN sys_role_menu srm on srm.role_id = a.id46. LEFT JOIN sys_menu sm on srm.menu_id = sm.id47.48. select as menuname FROM sys_menu a49.50. select as menuname FROM sys_menu a51. LEFT JOIN sys_menu p ON p.id = a.parent_id52.53. /****以菜单表为主表****/54. select as menuname, as rolename, as username FROM sys_menu a55. LEFT JOIN sys_menu p ON p.id = a.parent_id56. JOIN sys_role_menu rm ON rm.menu_id = a.id57. JOIN sys_role r ON r.id = rm.role_id AND eable='1'58. JOIN sys_user_role ur ON ur.role_id = r.id59. JOIN sys_user u ON u.id = er_id60.61. select * from sys_user_role; //⽤户⾓⾊表62. select * from sys_role; //⾓⾊表63. select * from sys_role_menu; //⾓⾊与菜单表64.65.66. /*********************⽤户关联公司和部门************************/67.68. /****通过company_id关联机构表中的公司****/69.70. select as username, as companyname from sys_user su71. LEFT JOIN sys_office so on pany_id = so.id72.73. select of.* from sys_user us74. left JOIN sys_office of on pany_id = of.id where us.id='11'75.76. /****通过office_id关联机构表的部门****/77. select as username, as officename from sys_user su78. LEFT JOIN sys_office so on su.office_id = so.id79.80. select of.* from sys_user us81. left JOIN sys_office of on us.office_id = of.id where us.id='11'82.83. select * from sys_user; //⽤户表84. select * from sys_office; //公司和部门表85.86. /*********************⾓⾊关联公司和部门************************/87.88. /******通过sys_role中的id然后关联sys_user_role表中的role_id,然后再通过sys_user_role中的user_id关联sys_user中的id89. 然后再通过sys_role_office中的role_id关联sys_role中的id,最后通过sys_role_office中的office_id关联sys_office中的id*****/90. SELECT as uname,a.id as roleid, as rolename, as officename FROM sys_role a91. LEFT JOIN sys_user_role ur ON ur.role_id = a.id92. LEFT JOIN sys_user u ON u.id = er_id93. LEFT JOIN sys_role_office sro on a.id = sro.role_id94. LEFT JOIN sys_office so on sro.office_id = so.id95.96. select * from sys_user; //⽤户表97. select * from sys_user_role; //⽤户⾓⾊表98. select * from sys_role; //⾓⾊表99. select * from sys_office; //公司和部门表100. select * from sys_role_office; //⾓⾊与部门表101.102. /*********************公司和部关联区域表************************/103.104. /******通过sys_office中的area_id然后关联sys_area表中的id*****/105. select as officename, as areaname from sys_office of106. LEFT JOIN sys_area ar on of.area_id=ar.id107.108. select * from sys_area; //区域表109. select * from sys_office; //公司和部门表。

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

7.提供基本功能模块的源代码生成器,提高开发效率及质量。

8.提供常用工具类封装,日志、缓存、验证、字典、组织机构等,常用标签(taglib),获取
当前组织机构、字典等数据。

9.完全兼容目前最流行浏览器(IE6、IE7+、Firefox、Chrome)。

10.提供目前最流行的Activit流程引擎实例
技术选型
1、Services相关
∙Core Framework:Spring Framework 3.2。

∙Security Framework:Apache Shiro 1.2。

∙Workflow Engine:Activit 5.12。

2、Web相关
∙MVC Framework:SpringMVC 3.2。

∙Layout Decoration:SiteMesh 2.4。

∙JavaScript Library:JQuery 1.9。

∙CSS Framework:Twitter Bootstrap 2.3.1。

∙JavaScript/CSS Compressor:YUI Compressor 2.4。

∙Front Validation:JQuery Validation Plugin 1.11。

3、Database相关
∙ORM Framework:Hibernate 4.1。

∙Connection Pool:Alibaba Druid 1.0。

∙Bean Validation:Hibernate Validation 5.0。

∙Cache:Ehcache 2.6。

4、Tools 相关
∙Commons:Apache Commons
∙JSON Mapper:Jackson 2.1
∙Bean Mapper:Dozer 5.3.2
∙Office Tools:Apache POI 3.9
∙Full-text search:Hibernate Search 4.2(Apache Lucene 3.6)、IK Analyzer 2012_u6中文分词
∙Log Manager:Log4j 1.2
安全考虑
1.开发语言:系统采用Java 语言开发,具有卓越的通用性、高效性、平台移植性和安全性。

2.分层设计:(数据库层,数据访问层,业务逻辑层,展示层)层次清楚,低耦合,各层必须
通过接口才能接入并进行参数校验(如:在展示层不可直接操作数据库),保证数据操作的安全。

3.双重验证:用户表单提交双验证:包括服务器端验证及客户端验证,防止用户通过浏览器恶
意修改(如不可写文本域、隐藏变量篡改、上传非法文件等),跳过客户端验证操作数据库。

4.安全编码:用户表单提交所有数据,在服务器端都进行安全编码,防止用户提交非法脚本及
SQL注入获取敏感数据等,确保数据安全。

5.密码加密:登录用户密码进行SHA1散列加密,此加密方法是不可逆的。

保证密文泄露后
的安全问题。

6.强制访问:系统对所有管理端链接都进行用户身份权限验证,防止用户
系统部分截图。

相关文档
最新文档