前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Symfony/Doctrine中的SQL注入

Symfony/Doctrine中的SQL注入

作者头像
很酷的站长
发布2023-12-05 08:37:42
1530
发布2023-12-05 08:37:42
举报
Symfony/Doctrine中的SQL注入
Symfony/Doctrine中的SQL注入

使用参数,而不是直接在查询字符串将值做是为了防止SQL注入攻击,应始终做到:

?

... WHERE p.name > :name ...->setParameter('name', 'edouardo')

这是否意味着如果我们使用这样的参数,我们将始终受到SQL注入的保护?在使用表单(FOS的注册表单)时,我eduardo改为使用标签将其保存到数据库中.我真的不明白为什么使用参数可以防止SQL注入......

为什么标签会像这样持久存储到数据库中?有没有办法通过使用Symfony的验证组件删除标签?

在Symfony中保存数据库之前,我们应该使用一般的提示或方法吗?

1> Jakub Zalas..:


首先阅读什么是SQL注入.

当SQL中的值改变查询时,会发生SQL注入攻击.结果,查询执行了它打算执行的其他操作.

示例将使用edouardo'OR'1'='1作为将导致以下结果的值:

?

WHERE p.name > 'edouardo' OR '1'='1'

(所以情况总是如此).

" eduardo "是一个完全有效的值.在某些情况下,您需要将其另存为提交(例如内容管理系统).当然,当你从数据库中取出并直接输出时,它可能会破坏你的HTML.这应该通过你的模板引擎来解决(树枝会自动逃脱它).

如果在将表单从表单传递到实体之前需要流程数据,请使用数据转换器.

2> greg0ire..:


如果在创建请求时使用参数而不是连接,则程序可以分别告诉SQL关键字和值.因此,它可以安全地转义可能包含恶意SQL代码的值,以便此恶意程序不会被执行,而是存储在字段中,就像它应该的那样.

HTML代码注入是另一个问题,与数据库无关.通过使用自动输出转义显示值时,此问题得以解决,而自动输出转义将显示eduardo而不是eduardo.这样,任何恶意的js/html代码都不会被解释:它将被显示.

收藏 | 0点赞 | 0打赏

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档