- 时间:2021-02-11 23:51 编辑:元博 来源:蚂蚁资源 阅读:227
- 扫一扫,手机访问
摘要:大家好,今天给大家介绍关于shiro源码(shiro中文官方文档)的相关内容,详细讲解shiro,eclipse怎么添加shiro源码,shiro怎么实现免账号密码,通过验证身份码登陆并授权等,希望可以帮助到您。
shiro,首先在Apache官方网站上下载文件,最后一个下载页面页面链接,进入页面后,首先查看链接(蓝色),点击下载,这是压缩包,其中包含在解压缩压缩后的Shiro源代码包,逐步一步,直到出现多个文件夹,您可以看到有一个文件夹核心,其中包含源代码,将此文件夹压缩为.zip或.jar文件,打开Eclipse选择您要查看的Shiro方法,单击右键单击,打开声明(从上到第四项右键单击菜单),如果未添加源代码,将出现“打开的接口”,单击“会话”框,在相应的条目中,您刚刚压缩的包那么,你会出来!
eclipse怎么添加shiro源码,使用Eclipse代码格式化工具:使用Eclipse格式化工具重新格式化反编译结果的排版,在编译整个jar包时,此操作将消耗一段时间。按Eclipse排序:使用Eclipse成员重新格式化排版,重构转换为反编译结果,这将在编译整个JAR包时消耗大量时间。
shiro怎么实现免账号密码,通过验证身份码登陆并授权,可以看看别人说的话。
责任编辑(
元博)
以上就是关于**shiro源码,shiro中文官方文档**的全部内容,了解更多请关注蚂蚁资源网。
- bibila
- shiro unauthorizedurl 怎么不是当前页面而是父页面的,解决方法:1、mvcnone_authority2、web.xml 500 /error.jsp 原因:shiro的源代码ShiroFilterFactoryBean.java[java] view plaincopyprivate void applyUnauthorizedUrlIfNecessary(Filter filter) { String unauthorizedUrl = getUnauthorizedUrl(); if (StringUtils.hasText(unauthorizedUrl) && (filter instanceof AuthorizationFilter)) { AuthorizationFilter authzFilter = (AuthorizationFilter) filter; //only apply the unauthorizedUrl if they haven't explicitly configured one already: String existingUnauthorizedUrl = authzFilter.getUnauthorizedUrl(); if (existingUnauthorizedUrl == null) { authzFilter.setUnauthorizedUrl(unauthorizedUrl); } } } 定义的filter必须满足filter instanceof AuthorizationFilter,只有perms,roles,ssl,rest,port才是属于AuthorizationFilter,而anon,authcBasic,auchc,user是AuthenticationFilter,所以unauthorizedUrl设置后页面不跳转
- 2021-02-11 23:51:13
- 网站模板素材下载
- 要抛出账号锁定异常?这个得看你到底是抛出到控制台还是前端了,希望下次能问详细一点。要是是在控制台抛出就是try{你的doGetAuthenticationInfo()方法}catch(Exception e){e.printStackTrace();System.out.println("账户锁定异常");}要是丢到前端那边,你得根据前端的代码修改
- 2021-02-11 23:51:13
- 至深科技
- JSP中直接引用Shiro标签比较简单可以参考JSP / GSP 标签库-Shiro权限学习1:http://blog.csdn.net/ahou2468/article/details/71130582JS中引用Shiro的标签不起作用的问题解决方法:1.第一种情况假如js中生成标签代码是固定死的解决起来比较容易,直接在需要权限判断标签前和后加上权限控制标签,即可以起作用<divid="leftnav"class="site-text"lay-filter="left"></div><scripttype="text/javascript">var ulHtml;ulHtml += '<shiro:hasRole name="999999">'ulHtml += '<i class="layui-icon" data-icon="' + data[i].children[j].icon +'">' + data[i].children[j].icon +'</i>';ulHtml +='</shiro:hasRole>'$('#leftnav').html(ulHtml);</script>,但是假如Shiro标签name参数使动态传进去的则Shiro标签作用失效了,会导致是Shiro标签中所的html标签不管有没有权限都不显示,事例:<div id="leftnav" class="site-text" lay-filter="left"></div><script type="text/javascript">var ulHtml;var name = "999999";ulHtml += '<shiro:hasRole name="'+name+'">'ulHtml += '<i class="layui-icon" data-icon="' + data[i].children[j].icon + '">' + data[i].children[j].icon + '</i>';ulHtml +='</shiro:hasRole>'$('#leftnav').html(ulHtml);</script>这种情况我的解决方案是,在后台查询到用户的权限数据时直接放到Session中,js中不通过Shiro标签判断而是自己通过获取权限的url动态判断/*** Shiro身份认证+授权 重写**/public class SampleRealm extends AuthorizingRealm{/*** 授权处理*/@Overrideprotected AuthorizationInfo doGetAuthorizationInfo(PrincipalCollectionprincipals) {Long userId = TokenManager.getUserId();SimpleAuthorizationInfoinfo =new SimpleAuthorizationInfo();//根据用户ID查询角色和权限,放入到Authorization里。Set<String> roles = roleService.findRoleByUserId(userId);info.setRoles(roles);//根据用户ID查询权限(permission),放入到Authorization里Set<String> permissions = permissionService.findPermissionByUserId(userId);info.setStringPermissions(permissions);//权限数据时直接放到Session中TokenManager.setVal2Session("permissions", permissions);returninfo;}JS中可以通过Session中获取权限数据var pers = '<%=session.getAttribute("permissions")%>';//将权限数据数组进行分割转为字符串数组,然后循环判断是否你访问的url元素在授权中,若在授权中动态生成html标签则显示,否则则隐藏掉var resultpers = pers.replace('[','').replace(']','').split(',');
- 2021-02-24 09:45:01