当前位置: 首页 > news >正文

建设手机网站报价搜索引擎哪个好用

建设手机网站报价,搜索引擎哪个好用,wordpress标签修改,结构设计师之家官网#知识点 1、安全开发-JavaEE-身份验证-JWT&Security 2、安全开发-JavaEE-安全问题-不安全写法&版本漏洞 #开发框架-SpringBoot 参考:Spring Boot 中文文档 一、身份验证的常见技术: 1、JWT 2、Shiro 3、Spring Security 4、OAuth 2.0 5、SSO 6、…
#知识点

1、安全开发-JavaEE-身份验证-JWT&Security

2、安全开发-JavaEE-安全问题-不安全写法&版本漏洞

#开发框架-SpringBoot

参考:Spring Boot 中文文档

一、身份验证的常见技术:

1、JWT

2、Shiro

3、Spring Security

4、OAuth 2.0

5、SSO

6、JAAS等

二、身份验证-JWT技术

JWT(JSON Web Token)是由服务端用加密算法对信息签名来保证其完整性和不可伪造;Token里可以包含所有必要信息,这样服务端就无需保存任何关于用户或会话的信息;

JWT用于身份认证、会话维持等。由三部分组成,header(加密算法)、payload(要加密的内容)与signature(签名,类似于加密的密钥)

1、引入依赖

<dependency>

<groupId>com.auth0</groupId>

<artifactId>java-jwt</artifactId>

<version>3.4.0</version>

</dependency>

2、创建JWT

JWT.create()

3、配置JWT(即生成jwt加密数据)

JWT.create()

//header

.withHeader(map)

//payload

.withClaim("userid",id)

.withClaim("username",user)

.withClaim("password",pass)

//signature

.sign(Algorithm.HMAC256("xiaodisec"));

4、解析JWT(即将jwt加密数据解密)

//构建解密注册

JWTVerifier jwt = JWT.require(Algorithm.HMAC256("xiaodisec")).build();

//解密注册数据

DecodedJWT verify = jwt.verify(jwtdata);

//提取解密数据

Integer userid = verify.getClaim("userid").asInt();

5、登录校验

①在该项目首页创建表单,用来上传提交的要加密的数据到login路径

②配置路由/login,并设置参数username与password

③访问网站,往表单传入要加密的数据,实现加密

在该项目首页再创建表单,用来上传加密后的“jwt加密数据”到logincheck路径->解密并进行身份验证

配置路由/logincheck,并设置参数jwtdata进行解密及配置身份验证逻辑

注意点:

总结:在未知的算法密钥(及jwt加密的sign签名部分)下,即使修改JWT值里的内容去伪造用户,也无法达到认证成功

攻击者遇到这种问题怎样操作?

①运气好,碰到jwt加密是空加密,也就是sign签名(即加密密钥为空),如果拿到账密,就可以利用jwt.io在线平台进行加解密测试

②爆破sign签名(即加密密钥),再进行测试

6、安全问题

参考:25种JWT Token渗透测试方法

三、身份验证-Spring Security

Spring Security安全框架,是Spring Boot底层安全模块默认的技术选型,可以实现强大的Web安全控制。

WebSecurityConfigurerAdapter:自定义Security策略

AuthenticationManagerBuilder:自定义认证策略

@EnableWebSecurity:开启WebSecurity模式

"认证"和"授权"(访问控制)

"认证"(Authentication)

"授权"(Authorization)

这个概念是通用的,而不是只在 Spring Security 中存在。

参考官网:https://spring.io/projects/spring-security

1、新建Spring Security+web+thymeleaf项目

2、配置application.properties模版解析

3、添加前端页面文件到templates目录

4、创建路由控制器并指向前端页面文件

@Controller

public class RouterController {

@RequestMapping("/index")

public String index() {

return "index";

}

@RequestMapping("/toLogin")

public String toLogin() {

return "views/login";

}

@RequestMapping("/level1/{id}")

public String level1(@PathVariable("id") int id) {

return "views/level1/"+id;

}

@RequestMapping("/level2/{id}")

public String level2(@PathVariable("id") int id) {

return "views/level2/"+id;

}

@RequestMapping("/level3/{id}")

public String level3(@PathVariable("id") int id) {

return "views/level3/"+id;

}

}

5、创建Security授权文件并开启访问策略

@EnableWebSecurity

public class SecurityConfig extends WebSecurityConfigurerAdapter {

@Override

protected void configure(HttpSecurity http) throws Exception {

http.authorizeHttpRequests()

.antMatchers("/").permitAll()

.antMatchers("/level1/**").hasRole("vip1")

.antMatchers("/level2/**").hasRole("vip2")

.antMatchers("/level3/**").hasRole("vip3");

http.formLogin();

}

6、添加认证用户密码并进行密码加密操作

@Override

protected void configure(AuthenticationManagerBuilder auth) throws Exception {

auth.inMemoryAuthentication().passwordEncoder(new BCryptPasswordEncoder())

.withUser("admin").password(new BCryptPasswordEncoder().encode("123456")).roles("vip1", "vip2", "vip3")

.and()

.withUser("xiaodi").password(new BCryptPasswordEncoder().encode("123456")).roles("vip1SpringSecurity权限绕过漏洞-好玩

er("xiaodisec").password(new BCryptPasswordEncoder().encode("123456")).roles("vip2")

.and()

.withUser("gay").password(new BCryptPasswordEncoder().encode("123456")).roles("vip3");

}

7、安全问题

参考:

https://mp.weixin.qq.com/s/5tj6O4TA04QWyWnsd-EmEA

JAVA代码审计-SpringSecurity权限绕过分析

漏洞点:

1、如上本身的代码不安全写法,如不安全写法“/admin"->安全写法”/admin/**"

2、即使写法正确->还有版本漏洞导致的安全问题

演示:antMatchers 配置认证绕过

http://www.khdw.cn/news/12821.html

相关文章:

  • 网站制作软件工程师广州竞价托管
  • 龙岗网站优化培训手机seo百度点击软件
  • 公司网站应该包括哪些内容如何开发微信小程序
  • 常德天恒建设网站游戏推广怎么快速拉人
  • 网站正在建设中 敬请期待seo关键词排名优化如何
  • 做淘宝网站要多少钱网站优化排名技巧
  • 合肥网站建设网站制作网络推广的调整和优化
  • 睢县做网站哪家好seo一个月工资一般多少
  • 北京网站建设联系电话百度sem竞价托管
  • 淘宝上做网站行吗外贸seo推广招聘
  • 黑群晖可以做网站吗如何做网络推广推广
  • 用html做网站步骤优化百度百科
  • 烟台海阳市专业做网站企业网站优化
  • 移动webApp旅游网站开发代码谷歌广告优化师
  • 建站产品百度怎么发广告
  • 用jsp做的网站有哪些百度统计
  • 网站搬家教程北京百度推广优化排名
  • 商标注册 网站建设如何入账中国万网
  • 互联网行业现状分析网站seo排名优化工具
  • 手机外贸网站建设旺道seo工具
  • 网站建设网址网站制作新乡网站推广
  • wordpress培训seo优化官网
  • 成都用设计公司网站网络推广营销方案100例
  • 网站建设的参考文献英文首页关键词优化公司
  • 肇庆微网站seo网络营销
  • 焦作做网站优化seo常见的优化技术
  • 网站seo优化费用seo快速排名系统
  • 专业的外贸建站公司数据分析网
  • 晋江企业网站制作yandx引擎入口
  • 2018年网站设计公司网页设计网站建设