shiro使用注解式和jsp标签的方式进行开发

原先的时候可以使用url的shiro配置方式进行拦截,但是发现url地址过多会配置繁琐,解决的方式就是使用aop注解式和jsp标签进行开发

原来的方式

	
	
		
		
			
				${adminPath}/sysindex.html = anon
				/static/** = anon
				
				${adminPath}/login = authc
				
				${adminPath}/logout = logout
				${adminPath}/** = user
			
		
	
变成注解式

@RequiresPermissions("sys:menu:save")
	@RequestMapping(value = "save")
	public void save(Menu menu, Model model, HttpServletRequest request, HttpServletResponse response) throws UnsupportedEncodingException {

那么这个Permission是怎么进行设置的呢

答案在授权方法中

@Override
	protected AuthorizationInfo doGetAuthorizationInfo(PrincipalCollection principals) {
		//返回什么值是必须要和doGetAuthenticationInfo的第一个参数有关的
		Principal principal = (Principal) getAvailablePrincipal(principals);
		// 获取当前已登录的用户
/*		if (!PublicConstant.TRUE.equals(Global.getConfig("user.multiAccountLogin"))){
			Collection sessions = cachingShiroSessionDao.getActiveSessions(true, principal, SysUtils.getSession());
			if (sessions.size() > 0){
				// 如果是登录进来的,则踢出已在线用户
				if (SysUtils.getSubject().isAuthenticated()){
					for (Session session : sessions){
						cachingShiroSessionDao.delete(session);
					}
				}
				// 记住我进来的,并且当前用户已登录,则退出当前用户提示信息。
				else{
					SysUtils.getSubject().logout();
					throw new AuthenticationException("msg:账号已在其它地方登录,请重新登录。");
				}
			}
		}*/
		try{
			User user = userService.get(new User(principal.getLoginName()));
			if (user != null) {
				SimpleAuthorizationInfo info = new SimpleAuthorizationInfo();
				//加入权限即可以在jsp和java类中调用
//				List list = SysUtils.getRoleMenu();
//				for (Menu menu : list){
//					if (StringUtils.isNotBlank(menu.getPermission())){
//						// 添加基于Permission的权限信息
//						for (String permission : StringUtils.split(menu.getPermission(),",")){
//							info.addStringPermission(permission);
//						}
//					}
//				}
				// 添加用户权限
				info.addStringPermission("user");
				// 更新登录IP和时间
//				iUserApi.updateUserLoginInfo(user);
				// 记录登录日志
	//			LogUtils.saveLog(Servlets.getRequest(), "系统登录");
				return info;
			}
		}catch(Exception e){
			logger.error("DEMO 报错-位置:[SystemAuthorizingRealm->doGetAuthorizationInfo]",e);
		}
		return null;
	}

info.addStringPermission(permission);
这样就完成了对应

spring开启aop 两种配置方式

	
	
		
	
	
    	
	

	
	
	
		
	

用一种即可

jsp标签

Jsp页面添加:

<%@ tagliburi="http://shiro.apache.org/tags" prefix="shiro" %>或者自定义shiro标签

 

标签名称

标签条件(均是显示标签内容)

登录之后

不在登录状态时

用户在没有RememberMe时

用户在RememberMe时

在有abc或者123角色时

拥有角色abc

没有角色abc

拥有权限资源abc

没有abc权限资源

显示用户身份名称

      显示用户身份中的属性值


注意:无论是jsp还是aop都会每次都调用realm进行访问数据库获取权限信息

你可能感兴趣的:(shiro)