【问题标题】:Change Filezilla user passwords with PHP SHA512 and Salt使用 PHP SHA512 和 Salt 更改 Filezilla 用户密码
【发布时间】:2019-09-28 12:23:58
【问题描述】:

我们正在尝试将 Filezilla Server 0.9.6 用户密码与用户选择用于登录我们网站的密码相匹配。所有谷歌搜索都指向实现 MD5 的旧解决方案,但新版本使用 SHA512 和 Salt。以下代码成功更新了 Server XML 文件,但重启 Filezilla 后新密码无效。

有没有人有这方面的经验,能指出这段代码哪里不对?

我的代码 来自https://forum.filezilla-project.org/viewtopic.php?t=39934

<?php
$password = "myNewPassword";

$seed = str_split("!\"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_`abcdefghijklmnopqrstuvwxyz{|}~");
shuffle($seed);
$rand = '';
foreach (array_rand($seed, 64) as $k) {
    $rand .= $seed[$k];
}
$salt_raw = utf8_encode($rand);
$salt_html = htmlentities($salt_raw);
$password = utf8_encode($password);
$salted_password = $password . $salt_raw;
$encoded_password = strtoupper(hash('SHA512', $salted_password));

// For Filezilla
$FzPass = $encoded_password;
$FzSalt = $salt_html;

$xmlFile = 'C:\path-to\FileZilla Server.xml';
$xml = simplexml_load_file($xmlFile);
$Pass = $xml->xpath("//User[@Name='TheUserName']//Option[@Name='Pass']");
$Salt = $xml->xpath("//User[@Name='TheUserName']//Option[@Name='Salt']");

$Pass[0][0] = $FzPass;
$Salt[0][0] = $FzSalt;

$xml->formatOutput = true;
$saved = $xml->asXML($xmlFile);
chdir( 'C:\FileZilla Server' );
exec( '"C:\FileZilla Server\FileZilla Server.exe" /reload-config' );

PHP执行前Filezilla Server.xml

<?xml version="1.0" ?>
<FileZillaServer>
    <Users>
        <User Name="TheUserName">
            <Option Name="Pass">1ED89AFBA4FD8EF177EAAF21E6641C33FC870860D5F399CD9B0A79632B0F2B08B235DB7258DB2B6EB58402AF29A4C8491CC8F82ED9D2E74EABA8F7B240D0615F</Option>
            <Option Name="Salt">-Z5c@tci:e?E4E@H@(cq)/W1zDMs#F&gt;XsYd$M)0t#{/s,tc@]GJYf@{@T.&amp;O*5sF</Option>
            <Option Name="Group"></Option>
            <Option Name="Bypass server userlimit">1</Option>
            <Option Name="User Limit">0</Option>
            <Option Name="IP Limit">0</Option>
            <Option Name="Enabled">1</Option>
            <Option Name="ForceSsl">0</Option>
        </User>
    </Users>
</FileZillaServer>

PHP 执行后

<?xml version="1.0" ?>
<FileZillaServer>
        <User Name="producer">
            <Option Name="Pass">57AECC6BBCCC8EE5A73F0E362E2434DBF617EC2C85404205D881B1B7A2D303405789F8B42DFE61EDD7CF197700B66307E998054615C8A9A1CA5A9988029F0EAD</Option>
            <Option Name="Salt">P,]mk&amp;amp;4N;v3`#&amp;lt;e8S?oj[U=Ja$}Q6~:\Z1{HuB&amp;gt;bnI/&amp;quot;M-pDh.qFylKfd0|LgT*G</Option>
            <Option Name="Group"/>
            <Option Name="Bypass server userlimit">1</Option>
            <Option Name="User Limit">0</Option>
            <Option Name="IP Limit">0</Option>
            <Option Name="Enabled">1</Option>
            <Option Name="ForceSsl">0</Option>
        </User>
</FileZillaServer>

【问题讨论】:

  • shuffle()array_rand() 不安全。这些都是 ASCII 字符,所以不需要utf8_encode()。而且您应该再次使用htmlspecialchars() 而不是htmlentities(),但这与所有ASCII 无关。这些都不会回答你关于为什么它不起作用的问题!
  • 也许对 Node.js 或 Go 之类的东西使用 FTP 服务器库并在其上实现自定义身份验证是一个更好的主意?
  • Filezilla 是这里的事实标准,所以没有改变。
  • @miken32 根据该代码的原始作者的说法,它“有效”,所以我在质疑我不知道的前提和其他因素我的驾驶室
  • 好吧,看看密码散列代码here,和盐生成代码here,它似乎应该可以工作。您可以将 FZ 服务器生成的用户帐户附加到您的 XML sn-p 吗?

标签: php xml simplexml sha filezilla


【解决方案1】:

SimpleXML 将自动编码* XML 实体,因此无需在您的 PHP 代码中使用htmlentities() 进行编码。此外,我已经更新了您的代码以包含适当的随机盐生成器。试试看!

<?php
$password = "myNewPassword";
$salt = "";
while (strlen($salt) !== 64) {
    $byte = ord(openssl_random_pseudo_bytes(1));
    if ($byte > 31 && $byte < 127) {
        $salt .= chr($byte);
    }
}

$hashed_password = strtoupper(hash('SHA512', $password . $salt));

$xmlFile = 'server.xml';
$xml = simplexml_load_file($xmlFile);
$Pass = $xml->xpath("//User[@Name='TheUserName']//Option[@Name='Pass']");
$Salt = $xml->xpath("//User[@Name='TheUserName']//Option[@Name='Salt']");

$Pass[0][0] = $hashed_password;
$Salt[0][0] = $salt;

$xml->formatOutput = true;
$saved = $xml->asXML($xmlFile);

*有特殊字符(&amp;amp;&amp;amp;lt;&amp;gt;")需要编码,以免与部分标记混淆(并非总是如此,但总是对它们进行编码更容易。)它们分别被编码为&amp;amp;&amp;amp;lt;&amp;gt;&amp;quot;。由于编码值中有一个特殊字符,因此您可以通过查找 &amp;amp;lt; 之类的内容来查看发生了双重编码,正如我们在您的示例 XML 中看到的那样。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2020-07-04
    • 2013-02-10
    • 2014-01-26
    • 2014-02-03
    • 1970-01-01
    • 2018-07-29
    • 2019-06-27
    相关资源
    最近更新 更多