2024年最新shiro安全框架的使用(1),剖析网络安全开发未来的出路在哪里

还有兄弟不知道网络安全面试可以提前刷题吗?费时一周整理的160+网络安全面试题,金九银十,做网络安全面试里的显眼包!

王岚嵚工程师面试题(附答案),只能帮兄弟们到这儿了!如果你能答对70%,找一个安全工作,问题不大。

对于有1-3年工作经验,想要跳槽的朋友来说,也是很好的温习资料!

【完整版领取方式在文末!!】

93道网络安全面试题

内容实在太多,不一一截图了

黑客学习资源推荐

最后给大家分享一份全套的网络安全学习资料,给那些想学习 网络安全的小伙伴们一点帮助!

对于从来没有接触过网络安全的同学,我们帮你准备了详细的学习成长路线图。可以说是最科学最系统的学习路线,大家跟着这个大的方向学习准没问题。

1️⃣零基础入门
① 学习路线

对于从来没有接触过网络安全的同学,我们帮你准备了详细的学习成长路线图。可以说是最科学最系统的学习路线,大家跟着这个大的方向学习准没问题。

image

② 路线对应学习视频

同时每个成长路线对应的板块都有配套的视频提供:

image-20231025112050764

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化资料的朋友,可以点击这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

<property name=“loginUrl"value=”/index.jsp"></property>

     

<property name=“successUrl"value=”/home.action"></property>

<property name=“filterChainDefinitions”>

<value>

/index.jsp* = anon

/home* = anon

/sysadmin/login/login.jsp* = anon

/sysadmin/login/logout.jsp* = anon

/login* = anon

/logout* = anon

/components/** = anon

/css/** = anon

/images/** = anon

/js/** = anon

/make/** = anon

/skin/** = anon

/stat/** = anon

/ufiles/** = anon

/validator/** = anon

/resource/** = anon

/** = authc

/*.* = authc

</value>

</property>

</bean>

<bean id="shiroEhcacheManager"class=“org.apache.shiro.cache.ehcache.EhCacheManager”>

<property name="cacheManagerConfigFile"value="classpath:ehcache-shiro.xml[a3] "/>

</bean>

<bean id="lifecycleBeanPostProcessor"class=“org.apache.shiro.spring.LifecycleBeanPostProcessor”/>

<bean class=“org.springframework.aop.framework.autoproxy.DefaultAdvisorAutoProxyCreator”

depends-on=“lifecycleBeanPostProcessor”>

<property name="proxyTargetClass"value=“true”/>

</bean>

<bean class=“org.apache.shiro.spring.security.interceptor.AuthorizationAttributeSourceAdvisor”>

<property name="securityManager"ref=“securityManager”/>

</bean>

授权&管理 类

public class AuthRealm extends AuthorizingRealm{

private UserService userService;

public voidsetUserService(UserService userService) {

this.userService = userService;

}

/**

* 授权

*/

@Override

protectedAuthorizationInfo doGetAuthorizationInfo(PrincipalCollection pc) {

User user = (User)pc.fromRealm(this.getName()).iterator().next();[a4]

//获取对象导航

Set roles = user.getRoles();

List permissions = newArrayList();

for(Role role:roles){

//遍历角色得到每个角色下的模块列表

Set modules = role.getModules();

//将模块名放入permissions中

for (Module module : modules) {

permissions.add(module.getName());

}

SimpleAuthorizationInfo info = newSimpleAuthorizationInfo();

info.addStringPermissions(permissions);

return info;

}

return null;

}

/**

* 认证

*/

@Override

protectedAuthenticationInfo doGetAuthenticationInfo(AuthenticationToken token[a5] ) throwsAuthenticationException {

UsernamePasswordToken upToken = (UsernamePasswordToken)token;[a6]

//查询用户

String hql = “fromUser where userName=?”;

List list = userService.find(hql, User.class, new String[]{upToken.getUsername()});

//判断用户是否存在

if(list!=null && list.size()>0){

//获取用户名

User user = list.get(0);

//核心API

SimpleAuthenticationInfo info = newSimpleAuthenticationInfo(user, user.getPassword(),

this.getName()[a7] );[a8]

return info;//进入密码比较器

}

return null;

}

密码比较器:

public classCustomCredentialsMatcher extendsSimpleCredentialsMatcher{

//密码比较

public booleandoCredentialsMatch(AuthenticationTokentoken, AuthenticationInfo info[a9] [a10] ){

UsernamePasswordToken upToken =(UsernamePasswordToken)token;

//将用户在界面输入的原始密码加密

Object pwd = Encrypt.md5(new String(upToken.getPassword())[a11] , upToken.getUsername()[a12] );[a13]

//获取数据库中加密的密码

Object dbPwd = info.getCredentials();

return this.equals(pwd,dbPwd);//进行密码比较

}

}

Action中的方法:

给大家的福利

零基础入门

对于从来没有接触过网络安全的同学,我们帮你准备了详细的学习成长路线图。可以说是最科学最系统的学习路线,大家跟着这个大的方向学习准没问题。

同时每个成长路线对应的板块都有配套的视频提供:

在这里插入图片描述

因篇幅有限,仅展示部分资料

网络安全面试题

绿盟护网行动

还有大家最喜欢的黑客技术

网络安全源码合集+工具包

所有资料共282G,朋友们如果有需要全套《网络安全入门+黑客进阶学习资源包》,可以扫描下方二维码领取(如遇扫码问题,可以在评论区留言领取哦)~

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化资料的朋友,可以点击这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 5
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值