This repository is proof of concept that implement proof of work system in PHP and javascript.
Drop the files contained in this repository in server (example /var/www) and configure your server web with new virtual host with document root is the htdocs directory of this repository. It notice that want settings.php be locate outside document root.
Pass the values (in order) to SHA256 twice, like bitcoin
- hostname - the hostname of your server
$_SERVER['HTTP_HOST'] - timestamp - a current iso-8601 timestamp in UTC
- rand - the random string put by the server and stored to
$_SESSION['pow']['rand'] - counter - a nonce that is incremented until the hash satisfies the difficulty
Cheater customer prevent by
- Store difficulty in server variable of session PHP
- Check customer specific random number in server variable of session PHP
- Check solution use timestamp less than 1 old hour
Javascript very slow. Cheater customer write C program and solve and submit solution server web many many fast than use javascript in this repository.
Wasm better. See https://github.com/shenzhu2/pow-php-wasm-demo
If demo help you please make donation at monero address
4ATt62EMG6KGW6EnehvnJJABd75RavSxZY367JCb3QWzKZJzbjHexkuYQA3TwJznz1F8NgqzrgPKQ6vnxuYEpSYVMfuLEo9
Thank you!
- Shen Zhu [email protected] - 54BE 8C1D 9BC3 CD9A 554E DD69 DA4C CB93 9EB8 AAD4 - https://github.com/shenzhu2
- Chris Veness - https://github.com/chrisveness/crypto
This project is license with AGPL License. See LICENSE



