思路:分别在web.xml配置过滤器以及在applicationContext.xml去配置

实现步骤:1、在pom.xml里引入shiro的坐标

2、在web.xml里配置shiro过滤器

3、在applicationContext.xml里配置安全管理器以及校验过滤器

4、自定义realm对象(认证/授权)

5、将realm注入到manager中注册

一、 使用shiro的方法注解方式进行权限控制

思路:在applicationContext.xml里使用aop去实现

 

实现步骤:1、在spring文件中配置开启shiro注解支持

2、修改事务注解

3、在Service方法上使用shiro注解

一、 使用shiro的标签进行权限控制

思路:这些标签用于JSP页面,控制一些元素是否可见

实现步骤:

1、 在页面引入shiro标签库

2、 通过shiro自带标签控制按钮是否显示

一、 总结shiro提供的权限控制方式

思路:1、URL级别粗粒度权限控制 2、方法级别细粒度权限控制(基于代理技术实现)

1、 通过shiro自定义标签,实现页面元素显示控制(基于标签技术实现)

第一种:URL级别粗粒度权限控制(基于过滤器实现)

配置web.xml 的shiroFilter 拦截 /*

在spring的applicationContext*.xml 配置文件中配置同名bean,配置filterChainDefinitions拦截控制规则

xxx.html* = anon (未登录可以访问)

xxx.html* =authc (必须登录才能访问)

xxx.html* = perms[权限] (需要特定权限才能访问)

xxx.html* = roles[角色] (需要特定角色才能访问)

第二种:方法级别细粒度权限控制(基于代理技术实现)

在spring的applicationContext*.xml 配置 spring aop 对spring管理bean对象开启shiro注解支持

@RequiresPermissions(权限)  需要特定权限才能访问

@RequiresRoles(角色)  需要特定角色才能访问

@RequiresAuthentication 需要认证才能访问

第三种:通过shiro自定义标签,实现页面元素显示控制(基于标签技术实现)

<shiro:authenticated>登录后才能访问

<shiro:hasPermission name="abc">需要特定权限才能访问

<shiro:hasRole name="abc">需要特定角色才能访问

一、 用户认证、授权功能的实现

思路:在UserAction的login方法里使用Subject完成

实现步骤:

1、 在UserAction的login方法里得到Subject对象

2、 封装表单提交的用户名和密码

3、 调用subject的login方法

4、 自定义realm对象(认证|授权)

二、 完成菜单列表的显示功能

思路:菜单存在上下级关系(树形结构),通过easyUI提供的treegrid控件完成

实现步骤:

1、 将需要的数据导入到数据库

2、 修改menu.html 的treegird的url属性

3、 编写MenuAction 提供list 查询所有菜单的方法

4、 编写Service和DAO

一、 完成菜单数据的添加功能

思路:在列表显示的前提下完成添加

实现步骤:

1、 检查页面表单元素 name是否与实体类匹配

2、 父菜单项使用combotree展示

3、 为保存按钮绑定事件,提交表单

4、 在MenuAction 添加 save保存方法

5、 编写MenuService

业务逻辑:shiro框架的功能实现的更多相关文章

  1. 一步一步实现web程序信息管理系统之三----登陆业务逻辑实现(验证码功能+参数获取)

    本篇紧接着上一篇文章[一步一步实现web程序信息管理系统之二----后台框架实现跳转登陆页面] 验证码功能 一般验证码功能实现方式为,前端界面访问一个url请求,后端服务代码生成一个图片流返回至浏览器 ...

  2. ASP.NET MVC5 网站开发实践(一) - 框架(续) 模型、数据存储、业务逻辑

    上次搭建好了项目框架,但还是觉得不太对劲,后来才想起来没有对开发目标进行定位,这个小demo虽然不用做需求分析,但是要实现什么效果还得明确.后来想了一下就做个最简单的网站,目标定为小公司进行展示用的网 ...

  3. ASP.NET MVC+EF框架+EasyUI实现权限管理系列(4)-业务逻辑层的封装

    原文:ASP.NET MVC+EF框架+EasyUI实现权限管理系列(4)-业务逻辑层的封装 ASP.NET MVC+EF框架+EasyUI实现权限管系列 (开篇)   (1):框架搭建    (2) ...

  4. MVC5 网站开发之四 业务逻辑层的架构和基本功能

    业务逻辑层在Ninesky.Core中实现,主要功能封装一些方法通过调用数据存储层,向界面层提供服务.   目录 奔跑吧,代码小哥! MVC5网站开发之一 总体概述 MVC5 网站开发之二 创建项目 ...

  5. 分享一个UI与业务逻辑分层的框架(三)

    序言 前两篇讲解了UIMediator框架的使用及具体原理代码.本篇讲述MediatorManager的实现代码及展望. MediatorManager MediatorManager的作用有两点: ...

  6. 分享一个UI与业务逻辑分层的框架(二)

    序言 第一篇讲解了UI与业务逻辑分层的框架(UIMediator)的使用.本篇将说明该框架的原理及代码实现. 整体结构 UI与后台类绑定主要分为UI输入->后台属性,后台属性-UI更新两部分,为 ...

  7. 分享一个UI与业务逻辑分层的框架(一)

    序言 .NET(C#)的WinForm如何简单易行地进行UI与业务逻辑分层?本系列文章介绍一个WinForm分层框架,该框架针对WinForm中的TextBox,CheckBox,RadioButto ...

  8. 从零开始,搭建博客系统MVC5+EF6搭建框架(1),EF Code frist、实现泛型数据仓储以及业务逻辑

    前言      从上篇30岁找份程序员的工作(伪程序员的独白),文章开始,我说过我要用我自学的技术,来搭建一个博客系统,也希望大家给点意见,另外我很感谢博客园的各位朋友们,对我那篇算是自我阶段总结文章 ...

  9. Flask--(项目准备)--框架搭建,配置文件抽取,业务逻辑抽取

    抽取配置文件: import logging from redis import StrictRedis class Config(object): """项目的配置&q ...

随机推荐

  1. BW 转换字符空格问题

    早上忙了我一早上,以前写的一个季度判断的问题, 首先是调试,不断的调试DTP.让我头晕眼花. 首先关于空格问题,我自我批评,愚蠢的定义成STRING 类型,然后相互加减出现问题.应该定义成内部的日期格 ...

  2. JavaWeb学习总结(二) Servlet

    本文目录 一.Servlet概述 二.Servlet接口 三.GenericServlet 四.HttpServlet 五.Servlet细节 六.ServletContext 回到顶部 一.Serv ...

  3. Java 接口与继承 道至简第六章发表阅读笔记

    一.继承条件下的构造方法调用 class Grandparent { public Grandparent() { System.out.println("GrandParent Creat ...

  4. 第六次scrum meeting记录

    文章负责:刘斯盾 日期:2017年10月30日 会议地点:新主楼F座二楼 各组员工作情况 团队成员 昨日完成任务 明日要完成任务 赵晓宇 评分界面搭建 issue17 课程列表页面搭建 issue20 ...

  5. Project://Meeting_Room

    models from django.db import models from django.contrib.auth.models import AbstractUser class UserIn ...

  6. js改变select的选中项不触发select的change事件

    // test var selectEl = document.querySelector('select') var buttonEl = document.querySelector('butto ...

  7. UVA 11605 Lights inside a 3d Grid

    #include <iostream> #include <stdio.h> #include <cstring> #include <math.h> ...

  8. CodeForces - 682E: Alyona and Triangles(旋转卡壳求最大三角形)

    You are given n points with integer coordinates on the plane. Points are given in a way such that th ...

  9. NET Core 2.0利用MassTransit集成RabbitMQ

    NET Core 2.0利用MassTransit集成RabbitMQ https://www.cnblogs.com/Andre/p/9579764.html 在ASP.NET Core上利用Mas ...

  10. LeetCode 480. Sliding Window Median

    原题链接在这里:https://leetcode.com/problems/sliding-window-median/?tab=Description 题目: Median is the middl ...