2017-10-14 48 views
3

我正在更新旧的经典ASP网站,我需要存储密码,所以很自然地,我正在对经典ASP的局限性如何去解决这个问题稍微谨慎。散列前加密sal密码。好主意?

我正在使用盐和胡椒(胡椒是一个常数存储在服务器上,而不是在数据库中),我只是想知道,是否有任何洗牌/扰乱字符的任何好处哈希之前的“胡椒+密码+盐”字符串?

我写了一个函数,可以基于预定义(秘密)数字序列(序列也存储在服务器上,而不是数据库中)来打乱任何长度的字符串。所以函数总是会返回相同的扰码值,而不是随机的扰码值(这当然是没有用的)。

我一直在阅读很多关于密码salting的内容,但是我从来没有见过任何人提出过在哈希之前加密的密码。但对我来说,这似乎是一个很大的额外安全级别。

想知道别人怎么看?

这里的加扰功能(它是用VBScript):

Function ScrambleSalt(the_str) 

    '// Once you've joined the pepper + password + salt, you pass it through the "ScrambleSalt" function before 
    '// hashing. The "ScrambleSalt" function will scramble any string based on a pre-set sequence of numbers. 
    '// The sequence is imported from a txt file (kept in an offline folder, just like the pepper). 

    '// The sequence needs to be an incremental collection of numbers (starting from 1) but in a random order 
    '// and comma delimited. Here's and example with 1 to 50, although the actual sequence uses 1 - 500: 

    '// 22,8,21,45,49,42,3,36,11,47,19,9,15,23,40,16,29,31,43,38,44,4,41,13,35,26,17,14,10,28,6,5,34,12,39,1, 
    '// 30,46,32,7,27,48,33,25,18,2,50,20,24,37 

    '// (^ the numbers 1 to 50 in a random order) 

    '// How the scrambling process works (using the above example sequence) is by rearranging the characters in 
    '// the string so that characters 22 appears first, followed by character 8, then character 21 etc, etc... 
    '// the function cycles through the sequence ignoring any numbers that are larger than the length of the 
    '// string until the characters in the string have all been rearranged (scrambled). 

    '// If a string is more than 50 characters long, it will be split into individual strings, each containing 
    '// 50 characters (or a remainder in the case of the last string). 

    '// So if the length of the string is 120 characters long, it will be split into 3 string: 

    '// String 1 = 50 chars (chars 1 - 50) 
    '// String 2 = 50 chars (chars 51 - 100) 
    '// String 3 = 20 chars (chars 101 - 120) 

    '// Each string will be scrambled, then joined back together before being returned by the function. 
    '// Using this method means the function can scramble strings of any length and without limit. 

    Dim scramble_sequence, sequence_array, scramble_loop, in_loop_str, scrambled_str 
    scramble_sequence = file_get_contents(request.ServerVariables("APPL_PHYSICAL_PATH") & "/../keys/scramble_sequence.txt") 
    sequence_array = split(scramble_sequence,",") 
    scramble_loop = Ceil(len(the_str),uBound(sequence_array)+1) '// round up 
    for fx = 0 to scramble_loop-1 
     in_loop_str = mid(the_str,fx*(uBound(sequence_array)+1)+1,uBound(sequence_array)+1) 
     for fy = 0 to uBound(sequence_array) 
      if int(sequence_array(fy)) =< len(in_loop_str) then 
       scrambled_str = scrambled_str & mid(in_loop_str,int(sequence_array(fy)),1) 
      end if 
     next 
    next 
    ScrambleSalt = scrambled_str 

End Function 

function Ceil(dividend, divider) ' for rounding up a number 
    if (dividend mod divider) = 0 Then 
     Ceil = dividend/divider 
    else 
     Ceil = Int(dividend/divider) + 1 
    end if 
End function 

function file_get_contents(file_path) 
    Set fs = Server.CreateObject("Scripting.FileSystemObject") 
    Set f = fs.OpenTextFile(file_path,1) 
     file_get_contents = f.ReadAll 
    f.Close : Set f = Nothing : Set fs = Nothing 
end function 

在动作上面的函数的一个例子

pepper value used for this example = "XC3Qpm7CNXauwAbX" 
scramble sequence used for this example = "9,39,50,43,18,11,36,7,29,41,27,34,12,45,1,14,42,13,6,4,25,19,24,33,30,20,23,10,46,16,49,38,15,5,17,8,47,28,26,3,2,40,37,44,35,32,48,22,31,21" 

password = "[email protected]" 
salt = "G1sWNd0andiIhOYA" 

concatenated pepper+password+salt: 
[email protected] 

scrambled using the example sequence: 
[email protected] 

SHA512 Hash: 
9d5a7781eeb815250c55c1a1f172c569b3b6167a48951c819e4982bea9b84bd8ecad6a417ff8f110541a1039ddf1fd8daa61a52a7c401fccae71dda77c607540 
+0

盐的目的是渲染彩虹桌无用(因为攻击者必须重新计算每个散列他们想要破解的散列)。盐是否为攻击者所知是无关紧要的。你的方法对你有什​​么好处? –

+0

我了解盐的用途(它将存储在哈希密码旁边)。如果数据库遭到破坏,黑客可能会针对一个帐户并重建彩虹表来执行盐分。我的想法是,加密密码+盐而不是仅仅连接两者会使这几乎不可能,除非他们能够访问网站源代码以及数据库......我也意识到这是过度的,但它似乎就像一个很好的附加安全级别。 – Adam

+0

重建彩虹表本质上与强制散列相同。无论如何,攻击者可以做什么。 –

回答

0

如果有人获得了访问数据库,他们也可以得到如果它们位于同一台服务器上,则可以访问您的脚本。