-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Alessandro Catania
committed
Dec 22, 2017
1 parent
1b4c92b
commit 435860e
Showing
28 changed files
with
751 additions
and
1,131 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,78 @@ | ||
# php-login-minimal | ||
|
||
A simple, but secure PHP login script. Uses the ultra-modern & future-proof PHP 5.5 BLOWFISH hashing/salting functions (includes the official PHP 5.3 & PHP 5.4 compatibility pack, which makes those functions available in these versions too). | ||
|
||
## Why does this script exist ? | ||
|
||
In the PHP world every beginner tries to build login systems from scratch, doing all the typical mistakes, usually going from saving plain text passwords to using (horribly wrong) MD5 hashing. This script tries to give beginners a usable code base with a fully implemented user authentication ("login") system, preventing less-experienced developers at least from the worst security issues. | ||
|
||
This script was originally part of the "php-login project", a collection of 4 different login scripts made in the 2012-2013 PHP era to give especially beginners and security-inexperienced users a set of basic auth functions that fitted the most modern password hashing standards possible. You know, this was the time when even major companies like SONY and LinkedIn used horrible outdated MD5-hashing for their passwords (or even saved everything in plain text) and when the big PHP frameworks didn't have proper user auth solution out-of-the-box. | ||
|
||
[data:image/s3,"s3://crabby-images/9ed89/9ed89264f023ef1944c89ac1f514b43b28623766" alt="Support the project"](https://affiliates.host1plus.com/ref/devmetal/36f4d828.html) | ||
|
||
Find the other versions here: | ||
|
||
**One-file version** (not maintained anymore) | ||
Full login script in one file. Uses a one-file SQLite database (no MySQL needed) and PDO: Register, login, logout. | ||
https://github.com/panique/php-login-one-file | ||
|
||
**Minimal version** (not maintained anymore) | ||
All the basic functions in a clean file structure, uses MySQL and mysqli. Register, login, logout. | ||
https://github.com/panique/php-login-minimal | ||
|
||
**Advanced version** (not maintained anymore) | ||
Similar to the minimal version, but full of features. Uses PDO, Captchas, mail sending via SMTP and much more. | ||
https://github.com/panique/php-login-advanced | ||
|
||
**HUGE (professional version)** | ||
Quite professional MVC framework structure, useful for real applications. Additional features like: URL rewriting, mail sending via PHPMailer (SMTP or PHP's mail() function/linux sendmail), user profile pages, public user profiles, gravatars and local avatars, account upgrade/downgrade etc., OAuth2, Composer integration, etc. | ||
https://github.com/panique/huge | ||
|
||
## Requirements | ||
|
||
- PHP 5.3.7+ | ||
- MySQL 5 database (please use a modern version of MySQL (5.5, 5.6, 5.7) as very old versions have a exotic bug that | ||
[makes PDO injections possible](http://stackoverflow.com/q/134099/1114320). | ||
- activated mysqli (last letter is an "i") extension (activated by default on most server setups) | ||
|
||
## Installation (quick setup) | ||
|
||
Create a database *login* and the table *users* via the SQL statements in the `_install` folder. | ||
Change mySQL database user and password in `config/db.php` (*DB_USER* and *DB_PASS*). | ||
|
||
## Installation (detailed setup tutorials) | ||
|
||
- [Detailed tutorial for installation on Ubuntu 12.04 LTS](http://www.dev-metal.com/install-php-login-nets-1-minimal-login-script-ubuntu/) | ||
- [Detailed tutorial for installation on Windows 7 and 8 (useful for development)](http://www.dev-metal.com/how-to-install-php-login-minimal-on-windows-7-8/) | ||
|
||
## Security notice | ||
|
||
This script comes with a handy .htaccess in the views folder that denies direct access to the files within the folder | ||
(so that people cannot render the views directly). However, these .htaccess files only work if you have set | ||
`AllowOverride` to `All` in your apache vhost configs. There are lots of tutorials on the web on how to do this. | ||
|
||
## Useful links | ||
|
||
- [A little guideline on how to use the PHP 5.5 password hashing functions and its "library plugin" based PHP 5.3 & 5.4 implementation](http://www.dev-metal.com/use-php-5-5-password-hashing-functions/) | ||
- [How to setup latest version of PHP 5.5 on Ubuntu 12.04 LTS](http://www.dev-metal.com/how-to-setup-latest-version-of-php-5-5-on-ubuntu-12-04-lts/). Same for Debian 7.0 / 7.1: | ||
- [How to setup latest version of PHP 5.5 on Debian Wheezy 7.0/7.1 (and how to fix the GPG key error)](http://www.dev-metal.com/setup-latest-version-php-5-5-debian-wheezy-7-07-1-fix-gpg-key-error/) | ||
- [Notes on password & hashing salting in upcoming PHP versions (PHP 5.5.x & 5.6 etc.)](https://github.com/panique/php-login/wiki/Notes-on-password-&-hashing-salting-in-upcoming-PHP-versions-%28PHP-5.5.x-&-5.6-etc.%29) | ||
- [Some basic "benchmarks" of all PHP hash/salt algorithms](https://github.com/panique/php-login/wiki/Which-hashing-&-salting-algorithm-should-be-used-%3F) | ||
|
||
## License | ||
|
||
Licensed under [MIT](http://www.opensource.org/licenses/mit-license.php). You can use this script for free for any | ||
private or commercial projects. | ||
|
||
## Contribute | ||
|
||
Please create a feature-branch if possible when committing to the project, if not then simply commit to master branch. | ||
|
||
## Support | ||
|
||
If you think this script is useful and saves you a lot of work, then think about supporting the project by renting | ||
a server at [HOST1PLUS](https://affiliates.host1plus.com/ref/devmetal/36f4d828.html). | ||
|
||
## I'm blogging... | ||
|
||
at **[DEV METAL](http://www.dev-metal.com)**, mostly about PHP and IT-related stuff. Have a look if you like. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
CREATE DATABASE IF NOT EXISTS `vippalac_main`; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,9 @@ | ||
CREATE TABLE IF NOT EXISTS `vippalac_main`.`users` ( | ||
`user_id` int(11) NOT NULL AUTO_INCREMENT COMMENT 'auto incrementing user_id of each user, unique index', | ||
`user_name` varchar(64) COLLATE utf8_unicode_ci NOT NULL COMMENT 'user''s name, unique', | ||
`user_password_hash` varchar(255) COLLATE utf8_unicode_ci NOT NULL COMMENT 'user''s password in salted and hashed format', | ||
`user_email` varchar(64) COLLATE utf8_unicode_ci NOT NULL COMMENT 'user''s email, unique', | ||
PRIMARY KEY (`user_id`), | ||
UNIQUE KEY `user_name` (`user_name`), | ||
UNIQUE KEY `user_email` (`user_email`) | ||
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci COMMENT='user data'; |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file was deleted.
Oops, something went wrong.
Oops, something went wrong.