提交 #802561: opensourcepos Open Source Point of Sale 3.4.1 Weak Encoding for Password信息

标题opensourcepos Open Source Point of Sale 3.4.1 Weak Encoding for Password
描述The system still accepts MD5 hashes for password verification, supporting legacy accounts. MD5 is cryptographically broken and unsuitable for password hashing. Attackers with rainbow tables can crack these passwords. public function login(string $username, string $password): bool { $builder = $this->db->table('employees'); $query = $builder->getWhere(['username' => $username, 'deleted' => 0], 1); if ($query->getNumRows() === 1) { $row = $query->getRow(); // Compare passwords depending on the hash version if ($row->hash_version === '1' && $row->password === md5($password)) { // VULNERABLE $builder->where('person_id', $row->person_id); $this->session->set('person_id', $row->person_id); $password_hash = password_hash($password, PASSWORD_DEFAULT); return $builder->update(['hash_version' => 2, 'password' => $password_hash]); } elseif ($row->hash_version === '2' && password_verify($password, $row->password)) { $this->session->set('person_id', $row->person_id); return true; } } It is recommended to migrate to SHA-256 or a stronger encryption algorithm. Also, recommended to use forced password resets for the already created accounts to ensure the credentals are rotated and latest eencryption is applied to the new credentials.
用户
 Kamran Saifullah (UID 4218)
提交2026-04-11 00時20分 (2 月前)
管理2026-05-18 06時38分 (1 month later)
状态已接受
VulDB条目364436 [opensourcepos Open Source Point of Sale 直到 3.4.2 Employee Login app/Models/Employee.php login 弱加密]
积分17

Do you know our Splunk app?

Download it now for free!