neto737 / googleauthenticator
Google Authenticator 2-factor authentication
Fund package maintenance!
Liberapay
Requires
- php: >=8.1
Requires (Dev)
- phpunit/phpunit: ^11.2
README
- Copyright (c) 2012-2016, http://www.phpgangsta.de
- Author: Michael Kliewe, @PHPGangsta and contributors
- Licensed under the BSD License.
This PHP class can be used to interact with the Google Authenticator mobile app for 2-factor-authentication. This class can generate secrets, generate codes, validate codes and present a QR-Code for scanning the secret. It implements TOTP according to RFC 6238
For a secure installation you have to make sure that used codes cannot be reused (replay-attack). You also need to limit the number of verifications, to fight against brute-force attacks. For example you could limit the amount of verifications to 10 tries within 10 minutes for one IP address (or IPv6 block). It depends on your environment.
Installation
-
Use Composer to install the package
-
From project root directory execute following
$ composer require neto737/GoogleAuthenticator
Or if put the following in your composer.json
:
"require": { "neto737/GoogleAuthenticator": "~2.0" }
Usage
See following example:
require 'vendor/autoload.php'; $ga = new \neto737\GoogleAuthenticator; $secret = $ga->createSecret(); echo "Secret is: " . $secret . PHP_EOL . PHP_EOL; $qrCodeUrl = $ga->getQRCodeGoogleUrl('Blog', $secret); echo "Google Charts URL for the QR-Code: ".$qrCodeUrl . PHP_EOL . PHP_EOL; $oneCode = $ga->getCode($secret); echo "Checking Code '$oneCode' and Secret '$secret': "; $checkResult = $ga->verifyCode($secret, $oneCode, 2); // 2 = 2*30sec clock tolerance if ($checkResult) { echo 'OK'; } else { echo 'FAILED'; }
Running the script provides the following output:
Secret is: OQB6ZZGYHCPSX4AK
Google Charts URL for the QR-Code: https://www.google.com/chart?chs=200x200&chld=M|0&cht=qr&chl=otpauth://totp/infoATphpgangsta.de%3Fsecret%3DOQB6ZZGYHCPSX4AK
Checking Code '848634' and Secret 'OQB6ZZGYHCPSX4AK': OK
Notes
If you like this script or have some features to add: contact me, visit my blog, fork this project, send pull requests, you know how it works.