.htpasswd ファイルの例:
user1:{SHA}kGPaD671VNU0OU5lqLiN/h6Q6ac=
user2:{SHA}npMqPEX3kPQTo+x/+ZckHDrIcQI=
user3:{SHA}q1Fh2LTUjjkncp11m0M9WUH5Zrw=
- class Htpasswd {
-
- private $file = '';
- private $salt = 'AynlJ2H.74VEfI^BZElc-Vb6G0ezE9a55-Wj';
-
- private function write($pairs = array()) {
- $str = '';
- foreach ($pairs as $username => $password) {
- $str .= "$username:{SHA}$passwordn";
- }
- file_put_contents($this -> file, $str) ;
- }
-
- プライベート関数 read() {
- $pairs = array();
- $fh = fopen($this -> file, 'r');
- while (!feof($fh)) {
- $ par_str = str_replace("n", '', fgets($fh));
- $pair_array =explode(':{SHA}', $pair_str);
- if (count($pair_array) == 2) {
- $ペア[$pair_array[0]] = $pair_array[1];
- }
- }
- return $pairs;
- }
-
- プライベート関数 getHash($clear_password = '') {
- if (!empty($clear_password)) {
- returnbase64_encode(sha1($clear_password, true));
- } else {
- return false;
- }
- }
-
- public function __construct($file) {
- if (file_exists($file)) {
- $this -> ; file = $file;
- } else {
- die($file." は存在しません。");
- return false;
- }
- }
-
- public function addUser($username = '', $clear_password = '') {
- if (!empty($username) && !empty($clear_password)) {
- $all = $this -> read();
- if (!array_key_exists($username, $all)) {
- $all[$username] = $this -> getHash($clear_password);
- $this -> write($all);
- }
- } else {
- return false;
- }
- }
-
- public function deleteUser($username = '') {
- $all = $this -> read();
- if (array_key_exists($username, $all)) {
- unset($all[$username]);
- $this -> write($all);
- } else {
- return false;
- }
- }
-
- public function dosUserExist($username = '') {
- $all = $this -> read();
- if (array_key_exists($username, $all)) {
- return true;
- } else {
- return false;
- }
- }
-
- public function getClearPassword($username) {
- return strto lower(substr(sha1) ($username.$this -> Salt), 4, 12));
- }
-
- }
复制代
- $passwdHandler = new Htpasswd('/home/myuser/.htpasswd');
-
- // 名前「user1」とパスワード「パスワードではなくパスフレーズを使用することを好みます。」を持つユーザーを追加します。 .htpasswd.
- $passwdHandler に存在しない場合 -> addUser('user1', 'パスワードではなくパスフレーズを使用することを好みます。');
- // ユーザー 'user1' が .htpasswd に存在する場合は削除します。
- $passwdHandler -> deleteUser('user1');
-
- // ユーザー 'user1' が .htpasswd に存在するか確認します
- if ($passwdHandler -> dosUserExist('user1')) {
- // ユーザー 'user1' が存在します。
- }
复制代
|