这个方法的c# – MethodImpl(NoOptimization),它做什么?是真的nessecary吗

嗯,我想哈希密码,我看看ASP.NET Identity在Microsoft.AspNet.Identity.Crypto类中的作用,我来了这个函数(用于比较2密码哈希):
[MethodImpl(MethodImplOptions.NoOptimization)]
private static bool ByteArraysEqual(byte[] a,byte[] b)
{
    if (object.ReferenceEquals(a,b))
    {
        return true;
    }
    if (((a == null) || (b == null)) || (a.Length != b.Length))
    {
        return false;
    }
    bool flag = true;
    for (int i = 0; i < a.Length; i++)
    {
        flag &= a[i] == b[i];
    }
    return flag;
}

这是从反射器输出的直接复制…

现在我的问题是,NoOptimization属性是什么好的,为什么它应该在那里(如果我删除会发生什么)?对我来说,它似乎是一个认的Equals()实现,直到for循环.

我试图看看IL,但对我来说都是废话:/

解决方法

如果一个“智能”编译器将该函数转换为一旦发现不匹配就返回false的东西,那么它可能会使使用此函数代码容易受到“定时攻击”的攻击.攻击者可以想像出第一个不匹配的位置一个字符串是基于函数需要返回多长时间的.

这不仅仅是科幻小说,实际上,尽管它似乎是这样的.即使使用互联网,您可以采取一大堆样本,并使用一些统计数据来确定如果您猜测实现短路,会发生什么.

相关文章

在要实现单例模式的类当中添加如下代码:实例化的时候:frmC...
1、如果制作圆角窗体,窗体先继承DOTNETBAR的:public parti...
根据网上资料,自己很粗略的实现了一个winform搜索提示,但是...
近期在做DSOFramer这个控件,打算自己弄一个自定义控件来封装...
今天玩了一把WMI,查询了一下电脑的硬件信息,感觉很多代码都...
最近在研究WinWordControl这个控件,因为上级要求在系统里,...