SpringMVC+Shiro許可權管理【轉】

来源:http://www.cnblogs.com/qiuwenshuo/archive/2016/11/02/6023922.html
-Advertisement-
Play Games

1.許可權的簡單描述 2.實例表結構及內容及POJO 3.Shiro-pom.xml 4.Shiro-web.xml 5.Shiro-MyShiro-許可權認證,登錄認證層 6.Shiro-applicationContext-shiro.xml 7.HomeController三個JSP文件 1.許可權 ...


1.許可權的簡單描述 2.實例表結構及內容及POJO 3.Shiro-pom.xml 4.Shiro-web.xml 5.Shiro-MyShiro-許可權認證,登錄認證層 6.Shiro-applicationContext-shiro.xml 7.HomeController三個JSP文件  

 什麼是許可權呢?舉個簡單的例子:
我有一個論壇,註冊的用戶分為normal用戶,manager用戶。
對論壇的帖子的操作有這些:
添加,刪除,更新,查看,回覆
我們規定:
normal用戶只能:添加,查看,回覆
manager用戶可以:刪除,更新

normal,manager對應的是角色(role)
添加,刪除,更新等對應的是許可權(permission)

我們採用下麵的邏輯創建許可權表結構(不是絕對的,根據需要修改)

一個用戶可以有多種角色(normal,manager,admin等等)
一個角色可以有多個用戶(user1,user2,user3等等)
一個角色可以有多個許可權(save,update,delete,query等等)
一個許可權只屬於一個角色(delete只屬於manager角色)



 

 我們創建四張表:
t_user用戶表:設置了3個用戶
-------------------------------
id + username   + password
---+----------------+----------
1  +   tom           +  000000
2  +   jack           +  000000
3  +   rose          +  000000
---------------------------------
t_role角色表:設置3個角色
--------------
id + rolename 
---+----------
1  + admin
2  + manager
3  + normal
--------------
t_user_role用戶角色表:tom是admin和normal角色,jack是manager和normal角色,rose是normal角色
---------------------
user_id  +  role_id
-----------+-----------
1            +     1
1            +     3
2            +     2
2            +     3
3            +     3
---------------------
t_permission許可權表:admin角色可以刪除,manager角色可以添加和更新,normal角色可以查看
-----------------------------------
id  +  permissionname  +  role_id
----+------------------------+-----------
1   +   add                     +     2
2   +   del                       +    1
3   +   update                +     2
4   +   query                   +    3
-----------------------------------

 使用SHIRO的步驟:
1,導入jar
2,配置web.xml
3,建立dbRelm
4,在Spring中配置

pom.xml中配置如下:

Xml代碼  收藏代碼
  1. <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  2.   xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">  
  3.   <modelVersion>4.0.0</modelVersion>  
  4.   <groupId>com.hyx</groupId>  
  5.   <artifactId>springmvc</artifactId>  
  6.   <packaging>war</packaging>  
  7.   <version>0.0.1-SNAPSHOT</version>  
  8.   <name>springmvc Maven Webapp</name>  
  9.   <url>http://maven.apache.org</url>  
  10.   <dependencies>  
  11.     <dependency>  
  12.       <groupId>junit</groupId>  
  13.       <artifactId>junit</artifactId>  
  14.       <version>3.8.1</version>  
  15.       <scope>test</scope>  
  16.     </dependency>  
  17.     <!-- SpringMVC核心jar -->  
  18.     <dependency>  
  19.         <groupId>org.springframework</groupId>  
  20.         <artifactId>spring-webmvc</artifactId>  
  21.         <version>3.2.4.RELEASE</version>  
  22.     </dependency>  
  23.     <!-- springmvc連接資料庫需要的jar -->  
  24.     <dependency>  
  25.         <groupId>org.springframework</groupId>  
  26.         <artifactId>spring-jdbc</artifactId>  
  27.         <version>3.2.4.RELEASE</version>  
  28.     </dependency>  
  29.     <dependency>  
  30.         <groupId>org.springframework</groupId>  
  31.         <artifactId>spring-orm</artifactId>  
  32.         <version>3.2.4.RELEASE</version>  
  33.     </dependency>  
  34.     <!-- ************************************ -->  
  35.     <!-- Hibernate相關jar -->  
  36.     <dependency>  
  37.         <groupId>org.hibernate</groupId>  
  38.         <artifactId>hibernate-core</artifactId>  
  39.         <version>4.2.5.Final</version>  
  40.     </dependency>  
  41.     <dependency>  
  42.         <groupId>org.hibernate</groupId>  
  43.         <artifactId>hibernate-ehcache</artifactId>  
  44.         <version>4.2.5.Final</version>  
  45.     </dependency>  
  46.     <dependency>  
  47.         <groupId>net.sf.ehcache</groupId>  
  48.         <artifactId>ehcache</artifactId>  
  49.         <version>2.7.2</version>  
  50.     </dependency>  
  51.     <dependency>  
  52.         <groupId>commons-dbcp</groupId>  
  53.         <artifactId>commons-dbcp</artifactId>  
  54.         <version>1.4</version>  
  55.     </dependency>  
  56.     <dependency>  
  57.         <groupId>mysql</groupId>  
  58.         <artifactId>mysql-connector-java</artifactId>  
  59.         <version>5.1.26</version>  
  60.     </dependency>  
  61.     <!-- javax提供的annotation -->  
  62.     <dependency>  
  63.         <groupId>javax.inject</groupId>  
  64.         <artifactId>javax.inject</artifactId>  
  65.         <version>1</version>  
  66.     </dependency>          
  67.     <!-- **************************** -->  
  68.       
  69.     <!-- hibernate驗證 -->  
  70.     <dependency>  
  71.         <groupId>org.hibernate</groupId>  
  72.         <artifactId>hibernate-validator</artifactId>  
  73.         <version>5.0.1.Final</version>  
  74.     </dependency>  
  75.     <!-- 用於對@ResponseBody註解的支持 -->  
  76.     <dependency>  
  77.         <groupId>org.codehaus.jackson</groupId>  
  78.         <artifactId>jackson-mapper-asl</artifactId>  
  79.         <version>1.9.13</version>  
  80.     </dependency>          
  81.     <!-- 提供對c標簽的支持 -->  
  82.     <dependency>  
  83.         <groupId>javax.servlet</groupId>  
  84.         <artifactId>jstl</artifactId>  
  85.         <version>1.2</version>  
  86.     </dependency>  
  87.     <!-- servlet api -->  
  88.     <dependency>  
  89.       <groupId>javax.servlet</groupId>  
  90.       <artifactId>servlet-api</artifactId>  
  91.       <version>2.5</version>  
  92.     </dependency>  
  93.       
  94.     <!--Apache Shiro所需的jar包-->    
  95.     <dependency>    
  96.       <groupId>org.apache.shiro</groupId>    
  97.       <artifactId>shiro-core</artifactId>    
  98.       <version>1.2.2</version>    
  99.     </dependency>    
  100.     <dependency>    
  101.       <groupId>org.apache.shiro</groupId>    
  102.       <artifactId>shiro-web</artifactId>    
  103.       <version>1.2.2</version>    
  104.     </dependency>    
  105.     <dependency>    
  106.       <groupId>org.apache.shiro</groupId>    
  107.       <artifactId>shiro-spring</artifactId>    
  108.       <version>1.2.2</version>    
  109.     </dependency>   
  110.   </dependencies>  
  111.     
  112.   <build>  
  113.     <finalName>springmvc</finalName>  
  114.     <!-- maven的jetty伺服器插件 -->  
  115.     <plugins>  
  116.         <plugin>  
  117.           <groupId>org.mortbay.jetty</groupId>  
  118.           <artifactId>jetty-maven-plugin</artifactId>  
  119.           <configuration>  
  120.             <scanIntervalSeconds>10</scanIntervalSeconds>  
  121.             <webApp>  
  122.               <contextPath>/</contextPath>  
  123.             </webApp>  
  124.             <!-- 修改jetty的預設埠 -->  
  125.             <connectors>  
  126.                <connector implementation="org.eclipse.jetty.server.nio.SelectChannelConnector">  
  127.                   <port>80</port>  
  128.                   <maxIdleTime>60000</maxIdleTime>  
  129.                </connector>  
  130.             </connectors>  
  131.           </configuration>  
  132.         </plugin>  
  133.     </plugins>  
  134.   </build>  
  135. </project>  

 

 web.xml中的配置:

Xml代碼  收藏代碼
  1. <?xml version="1.0" encoding="UTF-8" ?>  
  2. <web-app version="2.5"   
  3.     xmlns="http://java.sun.com/xml/ns/javaee"   
  4.     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"   
  5.     xsi:schemaLocation="http://java.sun.com/xml/ns/javaee   
  6.     http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">  
  7.   <display-name>Archetype Created Web Application</display-name>  
  8.     
  9.   <!-- spring-orm-hibernate4的OpenSessionInViewFilter -->  
  10.   <filter>  
  11.     <filter-name>opensessioninview</filter-name>  
  12.     <filter-class>org.springframework.orm.hibernate4.support.OpenSessionInViewFilter</filter-class>  
  13.   </filter>  
  14.   <filter-mapping>  
  15.     <filter-name>opensessioninview</filter-name>  
  16.     <url-pattern>/*</url-pattern>  
  17.   </filter-mapping>  
  18.     
  19.   <!-- 配置springmvc servlet -->  
  20.   <servlet>  
  21.     <servlet-name>springmvc</servlet-name>  
  22.     <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>  
  23.     <load-on-startup>1</load-on-startup>  
  24.   </servlet>  
  25.   <servlet-mapping>  
  26.     <servlet-name>springmvc</servlet-name>  
  27.     <!-- / 表示所有的請求都要經過此serlvet -->  
  28.     <url-pattern>/</url-pattern>  
  29.   </servlet-mapping>  
  30.     
  31.   <!-- spring的監聽器 -->  
  32.   <context-param>  
  33.     <param-name>contextConfigLocation</param-name>  
  34.     <param-value>classpath:applicationContext*.xml</param-value>  
  35.   </context-param>  
  36.   <listener>  
  37.     <listener-class>  
  38.         org.springframework.web.context.ContextLoaderListener  
  39.     </listener-class>  
  40.   </listener>  
  41.     
  42.   <!-- Shiro配置 -->    
  43.   <filter>    
  44.     <filter-name>shiroFilter</filter-name>    
  45.     <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>    
  46.   </filter>    
  47.   <filter-mapping>    
  48.     <filter-name>shiroFilter</filter-name>    
  49.     <url-pattern>/*</url-pattern>    
  50.   </filter-mapping>  
  51.     
  52. </web-app>  

 

 

Java代碼  收藏代碼
  1. package com.cn.service;  
  2.   
  3. import java.util.List;  
  4.   
  5. import javax.inject.Inject;  
  6.   
  7. import org.apache.shiro.authc.AuthenticationException;  
  8. import org.apache.shiro.authc.AuthenticationInfo;  
  9. import org.apache.shiro.authc.AuthenticationToken;  
  10. import org.apache.shiro.authc.SimpleAuthenticationInfo;  
  11. import org.apache.shiro.authc.UsernamePasswordToken;  
  12. import org.apache.shiro.authz.AuthorizationInfo;  
  13. import org.apache.shiro.authz.SimpleAuthorizationInfo;  
  14. import org.apache.shiro.realm.AuthorizingRealm;  
  15. import org.apache.shiro.subject.PrincipalCollection;  
  16. import org.springframework.stereotype.Service;  
  17. import org.springframework.transaction.annotation.Transactional;  
  18.   
  19. import com.cn.pojo.Role;  
  20. import com.cn.pojo.User;  
  21.   
  22. @Service  
  23. @Transactional  
  24. public class MyShiro extends AuthorizingRealm{  
  25.   
  26.     @Inject  
  27.     private UserService userService;  
  28.     /** 
  29.      * 許可權認證 
  30.      */  
  31.     @Override  
  32.     protected AuthorizationInfo doGetAuthorizationInfo(PrincipalCollection principalCollection) {  
  33.         //獲取登錄時輸入的用戶名  
  34.         String loginName=(String) principalCollection.fromRealm(getName()).iterator().next();  
  35.         //到資料庫查是否有此對象  
  36.         User user=userService.findByName(loginName);  
  37.         if(user!=null){  
  38.             //許可權信息對象info,用來存放查出的用戶的所有的角色(role)及許可權(permission)  
  39.             SimpleAuthorizationInfo info=new SimpleAuthorizationInfo();  
  40.             //用戶的角色集合  
  41.             info.setRoles(user.getRolesName());  
  42.             //用戶的角色對應的所有許可權,如果只使用角色定義訪問許可權,下麵的四行可以不要  
  43.             List<Role> roleList=user.getRoleList();  
  44.             for (Role role : roleList) {  
  45.                 info.addStringPermissions(role.getPermissionsName());  
  46.             }  
  47.             return info;  
  48.         }  
  49.         return null;  
  50.     }  
  51.   
  52.     /** 
  53.      * 登錄認證; 
  54.      */  
  55.     @Override  
  56.     protected AuthenticationInfo doGetAuthenticationInfo(  
  57.             AuthenticationToken authenticationToken) throws AuthenticationException {  
  58.         //UsernamePasswordToken對象用來存放提交的登錄信息  
  59.         UsernamePasswordToken token=(UsernamePasswordToken) authenticationToken;  
  60.         //查出是否有此用戶  
  61.         User user=userService.findByName(token.getUsername());  
  62.         if(user!=null){  
  63.             //若存在,將此用戶存放到登錄認證info中  
  64.             return new SimpleAuthenticationInfo(user.getUsername(), user.getPassword(), getName());  
  65.         }  
  66.         return null;  
  67.     }  
  68.   
  69. }  

 

 在spring的配置文件中配置,為了區別spring原配置和shiro我們將shiro的配置獨立出來。

applicationContext-shiro.xml

Xml代碼  收藏代碼
  1. <?xml version="1.0" encoding="UTF-8" ?>  
  2. <beans xmlns="http://www.springframework.org/schema/beans"  
  3.        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  4.        xmlns:aop="http://www.springframework.org/schema/aop"  
  5.        xmlns:tx="http://www.springframework.org/schema/tx"  
  6.        xmlns:context="http://www.springframework.org/schema/context"  
  7.        xsi:schemaLocation="  
  8. http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd  
  9. http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd  
  10. http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd  
  11. http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd">  
  12.   
  13.     <!-- 配置許可權管理器 -->  
  14.     <bean id="securityManager" class="org.apache.shiro.web.mgt.DefaultWebSecurityManager">    
  15.         <!-- ref對應我們寫的realm  MyShiro -->  
  16.         <property name="realm" ref="myShiro"/>    
  17.         <!-- 使用下麵配置的緩存管理器 -->  
  18.         <property name="cacheManager" ref="cacheManager"/>    
  19.     </bean>  
  20.       
  21.     <!-- 配置shiro的過濾器工廠類,id- shiroFilter要和我們在web.xml中配置的過濾器一致 -->  
  22.     <bean id="shiroFilter" class="org.apache.shiro.spring.web.ShiroFilterFactoryBean">   
  23.         <!-- 調用我們配置的許可權管理器 -->   
  24.         <property name="securityManager" ref="securityManager"/>   
  25.         <!-- 配置我們的登錄請求地址 -->   
  26.         <property name="loginUrl" value="/login"/>    
  27.         <!-- 配置我們在登錄頁登錄成功後的跳轉地址,如果你訪問的是非/login地址,則跳到您訪問的地址 -->  
  28.         <property name="successUrl" value="/user"/>    
  29.         <!-- 如果您請求的資源不再您的許可權範圍,則跳轉到/403請求地址 -->  
  30.         <property name="unauthorizedUrl" value="/403"/>    
  31.         <!-- 許可權配置 -->  
  32.         <property name="filterChainDefinitions">    
  33.             <value>    
  34.                 <!-- anon表示此地址不需要任何許可權即可訪問 -->  
  35.                 /static/**=anon  
  36.                 <!-- perms[user:query]表示訪問此連接需要許可權為user:query的用戶 -->  
  37.                 /user=perms[user:query]  
  38.                 <!-- roles[manager]表示訪問此連接需要用戶的角色為manager -->  
  39.                 /user/add=roles[manager]  
  40.                 /user/del/**=roles[admin]  
  41.                 /user/edit/**=roles[manager]  
  42.                 <!--所有的請求(除去配置的靜態資源請求或請求地址為anon的請求)都要通過登錄驗證,如果未登錄則跳到/login-->    
  43.                 /** = authc  
  44.             </value>    
  45.         </property>    
  46.     </bean>  
  47.       
  48.       
  49.     <bean id="cacheManager" class="org.apache.shiro.cache.MemoryConstrainedCacheManager" />    
  50.     <bean id="lifecycleBeanPostProcessor" class="org.apache.shiro.spring.LifecycleBeanPostProcessor" />   
  51.       
  52. </beans>  

 

 用於登錄,登出,許可權跳轉的控制:

Java代碼  收藏代碼
  1. package com.cn.controller;  
  2.   
  3. import javax.validation.Valid;  
  4.   
  5. import org.apache.shiro.SecurityUtils;  
  6. import org.apache.shiro.authc.AuthenticationException;  
  7. import org.apache.shiro.authc.UsernamePasswordToken;  
  8. import org.springframework.stereotype.Controller;  
  9. import org.springframework.ui.Model;  
  10. import org.springframework.validation.BindingResult;  
  11. import org.springframework.web.bind.annotation.RequestMapping;  
  12. import org.springframework.web.bind.annotation.RequestMethod;  
  13. import org.springframework.web.servlet.mvc.support.RedirectAttributes;  
  14.   
  15. import com.cn.pojo.User;  
  16.   
  17. @Controller  
  18. public class HomeController {  
  19.   
  20.     @RequestMapping(value="/login",method=RequestMethod.GET)  
  21.     public String loginForm(Model model){  
  22.         model.addAttribute("user", new User());  
  23.         return "/login";  
  24.     }  
  25.       
  26.     @RequestMapping(value="/login",method=RequestMethod.POST)  
  27.     public String login(@Valid User user,BindingResult bindingResult,RedirectAttributes redirectAttributes){  
  28.         try {  
  29.             if(bindingResult.hasErrors()){  
  30.                 return "/login";  
  31.             }  
  32.             //使用許可權工具進行用戶登錄,登錄成功後跳到shiro配置的successUrl中,與下麵的return沒什麼關係!  
  33.             SecurityUtils.getSubject().login(new UsernamePasswordToken(user.getUsername(), user.getPassword()));  
  34.             return "redirect:/user";  
  35.         } catch (AuthenticationException e) {  
  36.             redirectAttributes.addFlashAttribute("message","用戶名或密碼錯誤");  
  37.             return "redirect:/login";  
  38.         }  
  39.     }  
  40.       
  41.     @RequestMapping(value="/logout",method=RequestMethod.GET)    
  42.     public String logout(RedirectAttributes redirectAttributes ){   
  43.         //使用許可權管理工具進行用戶的退出,跳出登錄,給出提示信息  
  44.         SecurityUtils.getSubject().logout();    
  45.         redirectAttributes.addFlashAttribute("message", "您已安全退出");    
  46.         return "redirect:/login";  
  47.     }   
  48.       
  49.     @RequestMapping("/403")  
  50.     public String unauthorizedRole(){  
  51.         return "/403";  
  52.     }  
  53. }  

 

 三個主要的JSP:
login.jsp:

Html代碼  收藏代碼
  1. <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>  
  2. <%@ taglib prefix="form" uri="http://www.springframework.org/tags/form" %>  
  3. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">  
  4. <html>  
  5.   <head>  
  6.     <title>My JSP 'MyJsp.jsp' starting page</title>  
  7.   </head>  
  8.     
  9.   <body>  
  10.     <h1>登錄頁面----${message }</h1>  
  11.     <img alt="" src="/static/img/1.jpg">  
  12.     <form:form action="/login" commandName="user" method="post">  
  13.         用戶名:<form:input path="username"/> <form:errors path="username" cssClass="error"/> <br/>  
  14.         密 &nbsp;&nbsp;碼:<form:password path="password"/> <form:errors path="password" cssClass="error" /> <br/>  
  15.         <form:button name="button">submit</form:button>  
  16.     </form:form>  
  17.   </body>  
  18. </html>  

 

 user.jsp:

Html代碼  收藏代碼
  1. <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>  
  2. <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>  
  3. <%@ taglib prefix="shiro" uri="http://shiro.apache.org/tags" %>  
  4. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">  
  5. <html>  
  6.   <head>  
  7.     <title>用戶列表</title>  
  8.   </head>  
  9.   <body>  
  10.     <h1>${message }</h1>  
  11.     <h1>用戶列表--<a href="/user/add">添加用戶</a>---<a href="/logout">退出登錄</a>    </h1>  
  12.     <h2>許可權列表</h2>  
  13.     <shiro:authenticated>用戶已經登錄顯示此內容</shiro:authenticated>  
  14.     <shiro:hasRole name="manager">manager角色登錄顯示此內容</shiro:hasRole>  
  15.     <shiro:hasRole name="admin">admin角色登錄顯示此內容</shiro:hasRole>  
  16.     <shiro:hasRole name="normal">normal角色登錄顯示此內容</shiro:hasRole>  
  17.       
  18.     <shiro:hasAnyRoles name="manager,admin">**manager or admin 角色用戶登錄顯示此內容**</shiro:hasAnyRoles>  
  19.     <shiro:principal/>-顯示當前登錄用戶名  
  20.     <shiro:hasPermission name="add">add許可權用戶顯示此內容</shiro:hasPermission>  
  21.     <shiro:hasPermission name="user:query">query許可權用戶顯示此內容<shiro:principal/></shiro:hasPermission>  
  22.     <shiro:lacksPermission name="user:del"> 不具有user:del許可權的用戶顯示此內容 </shiro:lacksPermission>  
  23.     <ul>  
  24.         <c:forEach items="${userList }" var="user">  
  25.             <li>用戶名:${user.username }----密碼:${user.password }----<a href="/user/edit/${user.id}">修改用戶</a>----<a href="javascript:;" class="del" ref="${user.id }">刪除用戶</a></li>  
  26.         </c:forEach>  
  27.     </ul>  
  28.     <img alt="" src="/static/img/1.jpg">  
  29.     <script type="text/javascript" src="http://cdn.staticfile.org/jquery/1.9.1/jquery.min.js"></script>  
  30.     <script>  
  31.         $(function(){  
  32.             $(".del").click(function(){  
  33.                 var id=$(this).attr("ref");  
  34.                 $.ajax({  
  35.                     type:"delete",  
  36.                     url:"/user/del/"+id,  
  37.                     success:function(e){  
  38.                           
  39.                     }  
  40.                 });  
  41.             });  
  42.         });  
  43.     </script>  
  44.   </body>  
  45. </html>  

 

 

 403.jsp:

Html代碼  收藏代碼
    1. <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>  
    2. <%@ taglib prefix="form" uri="http://www.springframework.org/tags/form" %>  
    3. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">  
    4. <html>  
    5.   <head>  
    6.     <title>許可權錯誤</title>  
    7.   </head>  
    8.     
    9.   <body>  
    10.     <h1>對不起,您沒有許可權請求此連接!</h1>  
    11.     <img alt="" src="/static/img/1.jpg">  
    12.       
    13.   </body>  
    14. </html> 
    15. 框架/平臺構成:
      Maven+Springmvc + Mybatis + Shiro(許可權)+ Tiles(模板) +ActiveMQ(消息隊列) + Rest(服務) + WebService(服務)+ EHcache(緩存) + Quartz(定時調度)+ Html5(支持PC、IOS、Android)

      用戶許可權系統:
      組織結構:角色、用戶、用戶組、組織機構;許可權點:頁面、方法、按鈕、數據許可權、分級授權

      項目管理新體驗:
      快速出原型系統、組件樹、版本控制、模塊移植、協同開發、實時監控、發佈管理

      可持續集成:
      所有組件可移植、可定製、可擴充,開發成果不斷積累,形成可持續發展的良性迴圈

      支持平臺平臺: 
      Windows XP、Windows 7 、Windows 10 、 Linux 、 Unix

      伺服器容器:
      Tomcat 5/6/7 、Jetty、JBoss、WebSphere 8.5 

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

       

      JEESZ通用版本分散式模塊化開發平臺 - zookeeperflume - zookeeperflume的博客

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1.1概述 保證一個類僅有一個實例,並提供一個訪問它的全局訪問點。這就是單件模式的定義。 在某些情況下,我們可能需要某個類只能創建一個對象,即不讓用戶用該類實例化出多於兩個的實例。 例如,在一個公文管理系統中,公文類的實例“公文文件”,需要將公章類的實例作為自己的一個成員,以表明自己是一個有效的公文 ...
  • 1.1概述 用原型實例指定創建對象的種類,並且通過複製這些原型創建新的對象。這就是原型模式的定義。 在某些情況下,可能不希望反覆使用類的構造方法創建許多對象,而是希望使用該類創建一個對象後,以該對象為原型得到該對象的若幹個複製品。也就是說,將一個對象定義為原型對象,要求改原型對象提供一個方法,使該原 ...
  • 本文將介紹自定義Model過程中資料庫數據源的獲取方法,我使用過以下三種方式獲取資料庫數據源: 創建 存儲對應資料庫所有欄位的 結構體,將結構體置於容器中返回,然後根據索引值(QModelIndex)取出最終的欄位值; 創建 存儲對應資料庫所有欄位的 類,將類對象置於容器中返回,然後利用內省機制獲取 ...
  • 相當於jsp里 ...
  • nginx在工作中已經有好幾個環境在使用了,每次都是重新去網上扒博客,各種編譯配置,今天自己也整理一份安裝文檔和nginx.conf配置選項的說明,留作以後參考。像負載均衡配置(包括健康檢查)、緩存(包括清空緩存)配置實例,請參考http://seanlook.com/2015/05/17/ngin ...
  • A集成代碼生成器 [正反雙向(單表、主表、明細表、樹形表,開發利器)+快速構建表單 下載地址 ; freemaker模版技術 ,0個代碼不用寫,生成完整的一個模塊,帶頁面、建表sql腳本,處理類,service等完整模塊B 集成阿裡巴巴資料庫連接池druid; 資料庫連接池 阿裡巴巴的 druid。 ...
  • 邏輯層職責: 負責整個系統 中業務邏輯的處理。 邏輯層架構特點: 邏輯層業務複雜; 設計方式: 1、All In ONE方式:所有業務一個整體、一個文件、一個類里。 特點:簡單,適合業務量小; 問題:耦合性嚴重;文件內容複雜、開發維護代價高、牽一發動全身; 適合場景:創業期、業務不複雜; 2、業務垂... ...
  • 1.1概述 將一個複雜對象的構建與它的表示分離,使同樣的構建過程可以創建不同的表示。這就是生產器模式的定義。 如果一個類中有若幹個成員變數是其他類聲明的對象,那麼該類創建的對象就可以包含若幹個其他對象作為其成員。習慣上把一個對象中的成員對象稱作它的組件,例如,幾何(Geometry)類含有三角形(T ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...