SRP PHP Client

PHP Client for Login over Secure Remote Password Protocol

1. registrate

generate s (salt) and v (verifier). generated by client, stored by server

$username = "falk";
$password = "test123";
$s = $srp->getRandomSeed();
$x = $srp->generateX($s, $username, $password);
$v = $srp->generateV($x);
$send = array("phase" => 0, "I" => $username, "v" => $v, "s" => $s);

Send

Array ( [phase] => 0 [I] => falk [v] => d4b6feed6ba0c4276c33aaf44e9fcc75a7b1fa02978cec11e60cb68e875cdbea04cd1c90a1f48b7ba42e636318ec5c93aacd8c78e050558c4b6301a09f863622 [s] => 6c25b0e86787d23c2260c45070825edd66100823a55497411f721b72c1165ca4438fdd42570bd78431a00fa770349fc2d8cff7914d6982b631f82f94f68367c4 )

Recive

Array ( [success] => 1 )

2. Login - Phase 1

client generate a (private random key), A (public generated key) and send A, I (username) to server.

$a = $srp->getRandomSeed();
$A = $srp->generateA($a);
$send = array("phase" => 1, "I" => $username, "A" => $A);

Send

Array ( [phase] => 1 [I] => falk [A] => 371077421636848326e5c21ec1e696245d0cf6e7d4869c310e0ccb186eecc90bdc0e895da5bd44a0304ec83e69f664eeccd3d03458c0e31f704084625bc25362 )

Recive

Array ( [success] => )

3. Login - Phase 2

Client receive s (salt) und B (public key of Server) in Phase 1. Client build M1 and send it sto Server.


Warning: Undefined array key "B" in /html/code.falk-m.de/srp/client.php on line 128

Warning: Undefined array key "s" in /html/code.falk-m.de/srp/client.php on line 129

Deprecated: strtolower(): Passing null to parameter #1 ($string) of type string is deprecated in /html/code.falk-m.de/srp/php/lib/srp.php on line 222

Deprecated: strtolower(): Passing null to parameter #1 ($string) of type string is deprecated in /html/code.falk-m.de/srp/php/lib/srp.php on line 222

Warning: Uninitialized string offset -9223372036854775808 in /html/code.falk-m.de/srp/php/lib/srp.php on line 209
$B = $res1["B"];
$s = $res1["s"];
$x = $srp->generateX($s, $username, $password);
$S = $srp->generateS_Client($A, $B, $a, $x);
$M1 = $srp->generateM1($A, $B, $S);
$send = array("phase" => 2, "M1" => $M1);

Send

Array ( [phase] => 2 [M1] => 2fa570f83dc8278e1c058bbdac405f269026532be90747a51dbdc9a1249a6f1e )

Recive

4. Server verification

Client receive M2 from Server, rebiuld and compare them and build session key

$res2 = json_decode($res["body"], true);
$M2 = $res2["M2"];
$M2_check = $srp->generateM2($A, $M1, $S);

if($M2 == $M2_check){
echo "SUCCESS;";
$K = $srp->generateK($S);
echo "SESSION KEY: ".$K;
}

Output


Warning: Trying to access array offset on value of type null in /html/code.falk-m.de/srp/client.php on line 180