博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Entity Framework中的字符串插值引发担忧
阅读量:6476 次
发布时间:2019-06-23

本文共 1121 字,大约阅读时间需要 3 分钟。

将内插字符串(Interpolated Strings)自动地转化为参数化SQL语句,这是。虽然该特性从设计上是为了避免出现SQL语句编写上的问题,但是有人担心这会导致更多的SQL注入攻击。

\\

下面给出一个正确工作的字符串插值例子:

\\
\var city = \"Redmond\";\context.Customers.FromSql($\"SELECT * FROM Customers WHERE City = {city}\");\SELECT * FROM Customers WHERE City = @p0a
\\

我们对此稍作更改,下面的代码就不工作了:

\\
\var city = \"Redmond\";\var sql = $\"SELECT * FROM Customers WHERE City = {city}\";\context.Customers.FromSql(sql);\SELECT * FROM Customers WHERE City = Redmond
\\

这是因为后者将表达式存储在本地变量中,这一简单操作完全地更改了代码的行为。

\\

为推本溯源,我们需要理解C#中“$\"”表达式的事实真实行为。乍一看,表达式仅是将内插字符串转换为一个正常的String.Format调用。但事实上,它还做了一些额外的工作。

\\

本质上,“$\"”表达式是的一个子类。对象中包含字符串格式化表达式以及所有需要填充的值。对象在传递给EF Core的FromSql(FormattableString)方法后,会执行必要的替换,并得到了参数化的SQL表达式。

\\

问题在于,编译器并不愿意直接操作FormattableString。除非我们将“$\"”表达式直接指定为一个FormattableString类型的变量或参数,否则表达式将立刻被转换为字符串。在正常情况下,这是一种良性更改,因为我们希望最终能给出字符串格式。

\\

不幸的是,在EF Core中,会丢失全部有意义的信息,Entity Framework使用这些信息对SQL语句参数化。此外一旦发生错误,EF Core并不会给出任何编译器告警或是其它的指示信息。因此如果开发人员试图“清理”代码,这类软件缺陷就很容易混入到应用中。

\\

如要深入了解EF Core使用字符串插值可导致SQL注入攻击这一问题,可从GitHub下载,也可以看一下他发布在ASP.NET Monster上的一个幻灯片,名为“”(SQL Injection attacks in Entity Framework Core 2.0)。

\\

查看英文原文:

转载地址:http://zamko.baihongyu.com/

你可能感兴趣的文章
ZOJ 3777 Problem Arrangement
查看>>
虚拟机类加载机制
查看>>
Callable和Future
查看>>
installshield12如何改变默认安装目录
查看>>
少用数字来作为参数标识含义
查看>>
ScrollView中嵌套ListView
查看>>
JAVA虚拟机05--面试必问之JVM原理
查看>>
Algs4-2.3.1如何切分数组
查看>>
uva 10815 - Andy's First Dictionary(快排、字符串)
查看>>
观察者模式
查看>>
在properties.xml中定义变量,在application.xml中取值问题
查看>>
js 数组
查看>>
Linux scp命令详解
查看>>
struct和typedef struct
查看>>
cell reuse & disposebag
查看>>
【故障处理】ORA-12545: Connect failed because target host or object does not exist
查看>>
云时代,程序员将面临的分化
查看>>
js判断移动端是否安装某款app的多种方法
查看>>
学习angularjs的内置API函数
查看>>
4、输出名称 Exported names
查看>>