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

网站组织结构图谷歌seo视频教程

网站组织结构图,谷歌seo视频教程,2022房地产行业现状及前景,chn域名注册网站文章目录 Java SQL注入防范类型转换预编译查询(PreparedStatement)使用 ORM 框架(如 MyBatis、Hibernate)白名单限制ORDER BY 语句LIKE 语句 限制数据库权限过滤和转义特殊字符 Java SQL注入防范 类型转换 Java 是强类型语言&am…

文章目录

    • Java SQL注入防范
      • 类型转换
      • 预编译查询(PreparedStatement)
      • 使用 ORM 框架(如 MyBatis、Hibernate)
      • 白名单限制
        • ORDER BY 语句
        • LIKE 语句
      • 限制数据库权限
      • 过滤和转义特殊字符

在这里插入图片描述

Java SQL注入防范

类型转换

Java 是强类型语言,因此直接的数值型 SQL 注入较少,但仍需要注意参数类型的安全性。

int id = Integer.valueOf(req.getParameter("id"));

这样可以确保 id 变量是整数,避免输入 1 OR 1=1 之类的 SQL 语句攻击。

预编译查询(PreparedStatement)

预编译(Parameterized Queries)是防止 SQL 注入的最好方法,能够确保用户输入的数据不会被解析为 SQL 代码。

例如:

public User getUserById(String id) throws SQLException {Connection connection = JDBCTOOLS.getConnection(); // 获取数据库连接String sql = "SELECT id, username FROM user WHERE id = ?";PreparedStatement preparedStatement = connection.prepareStatement(sql);preparedStatement.setString(1, id);ResultSet resultSet = preparedStatement.executeQuery();if (resultSet.next()) {return new User(resultSet.getInt("id"), resultSet.getString("username"));}return null;
}

使用 ORM 框架(如 MyBatis、Hibernate)

ORM 框架能够自动处理 SQL 预编译,减少 SQL 注入的风险。

例如:

@Mapper
public interface CategoryMapper {@Select("SELECT * FROM category_ WHERE name = #{name}")Category getByName(String name);
}

白名单限制

某些情况下,用户输入可能用于 ORDER BYINLIKE 等 SQL 语句,预编译无法有效防止注入,这时可使用白名单校验。

ORDER BY 语句
private String checkSort(String sortBy) {List<String> columns = Arrays.asList("id", "username", "email");// 若传入的字段在允许列表内,则返回原字段;否则返回默认字段 "id"return columns.contains(sortBy) ? sortBy : "id";
}

这里通过 checkSort 方法,限定 ORDER BY 只能使用 白名单中的字段(id、username、email),如果 sortBy 不是合法字段,则默认按 id 排序。

String sql = "SELECT * FROM users ORDER BY " + checkSort(sortColumn);
LIKE 语句
String sql = "SELECT * FROM users WHERE username LIKE CONCAT('%', ?, '%')";
PreparedStatement preparedStatement = connection.prepareStatement(sql);
preparedStatement.setString(1, userInput);

这里使用了预编译(PreparedStatement),将 userInput 作为参数传递,而不是直接拼接到 SQL 语句中。

限制数据库权限

数据库用户权限应遵循最小权限原则,避免 root 账户执行 SQL 语句。

CREATE USER 'app_user'@'localhost' IDENTIFIED BY 'XXXX';

1、CREATE USER:在 MySQL 数据库中创建一个新用户。
2、‘app_user’@‘localhost’:用户名是 app_user。
3、@‘localhost’ 指定该用户只能从本机(localhost)连接到数据库,不能从其他 IP 访问。
4、IDENTIFIED BY ‘XXXX’:设置该用户的密码为 ‘XXXX’。

GRANT SELECT, INSERT, UPDATE ON mydb.* TO 'app_user'@'localhost';

1、GRANT:授予数据库权限。
2、SELECT, INSERT, UPDATE:允许 app_user 在数据库 mydb 中执行 查询(SELECT)、插入(INSERT)、更新(UPDATE) 操作。
3、ON mydb.*:作用范围是 mydb 数据库中的所有表(* 代表所有表)。
4、TO ‘app_user’@‘localhost’:只将这些权限授予 本机的 app_user。

过滤和转义特殊字符

可以对用户输入进行严格的字符过滤,但不建议完全依赖此方法。

public static String sanitize(String input) {return input.replaceAll("[';--]", "");
}

replaceAll() 会将单引号 (')、分号 (;)、双减号 (–)替换为空字符串 “”,即删除这些字符。

http://www.dtcms.com/wzjs/267185.html

相关文章:

  • 长春市防疫最新消息数据网站关键词优化的步骤和过程
  • 做国外网站衣服码数要怎么写可口可乐搜索引擎营销案例
  • 站长工具seo优化建议网站大全软件下载
  • 成都响应式网站网络营销与网站推广的区别
  • 如何做网站的薪酬调查餐饮培训
  • 北京建设银行公积金提取网站高中同步测控优化设计答案
  • 在线网站地图生成器系统优化大师下载
  • 中国有什么网站做跨境零售武汉seo首页
  • WordPress的黑色框谷歌外贸seo
  • 建站工具 开源为什么打开网址都是站长工具
  • 网站设计 优帮云百度搜索风云榜电脑版
  • 网站建设公司哪家强网络优化app哪个好
  • 国外推广网站有哪些114啦网址导航官网
  • 网站建设实训总结300青柠影院免费观看电视剧高清
  • 开封 网站建设百度友情链接
  • 做网站开通手机验证功能营销公司排行
  • 青岛手机建站哪家好steam交易链接怎么用
  • 如何提升网站打开速度软件优化
  • python编程网站爱战网关键词
  • 香港主机做福彩网站做一个私人网站需要多少钱
  • 网站开发流程简述seo课程简介
  • wordpress 获取标签id网站seo诊断报告
  • 乌兰察布网站制作西安百度推广优化公司
  • 网站优化怎么操作公司网址
  • 做外贸网站怎么访问外国网站湖南网络推广排名
  • 北京住房和城乡建设委员会网站公告安卓优化大师最新版下载
  • 创业策划书网站内部seo优化包括
  • 口碑好网站建设公司电话网络营销就是
  • 网站建设交流seo收索引擎优化
  • 网站建设共享ip中文网站排行榜