質問編集履歴
3
誤字
title
CHANGED
File without changes
|
body
CHANGED
@@ -47,14 +47,15 @@
|
|
47
47
|
|
48
48
|
|
49
49
|
# パスワードを持っていないユーザーを取得してパスワード発行
|
50
|
-
$
|
50
|
+
$sql = '
|
51
|
-
|
51
|
+
UPDATE users
|
52
|
-
|
52
|
+
SET pass = :pass
|
53
|
-
|
53
|
+
WHERE user_id = :user_id
|
54
|
-
|
54
|
+
';
|
55
|
+
$prepare = $dbn->prepare($sql);
|
55
|
-
$
|
56
|
+
$prepare->bindValue(':pass', $pass);
|
56
|
-
$
|
57
|
+
$prepare->bindValue(':user_id', '');
|
57
|
-
$
|
58
|
+
$prepare->execute();
|
58
59
|
```
|
59
60
|
# 追記
|
60
61
|
これでランダム文字列をhash化して初期値の設定はできました。
|
2
内容の追記
title
CHANGED
File without changes
|
body
CHANGED
@@ -10,34 +10,34 @@
|
|
10
10
|
※下記のusersテーブルでパスワードを持っていないuser_id毎に違うパスワードを発行したい
|
11
11
|
|user_id|user_pw|user_name|
|
12
12
|
|:--|:--|:--|
|
13
|
-
|1||
|
13
|
+
|1||ユーザー1|
|
14
|
-
|2||
|
14
|
+
|2||ユーザー2|
|
15
|
-
|3||
|
15
|
+
|3||ユーザー3|
|
16
|
-
|4||
|
16
|
+
|4||ユーザー4|
|
17
|
-
|5||
|
17
|
+
|5||ユーザー5|
|
18
18
|
|
19
19
|
⬇現在の状態
|
20
20
|
|user_id|user_pw|user_name|
|
21
21
|
|:--|:--|:--|
|
22
|
-
|1|
|
22
|
+
|1|12345678|ユーザー1|
|
23
|
-
|2|
|
23
|
+
|2|12345678|ユーザー2|
|
24
|
-
|3|
|
24
|
+
|3|12345678|ユーザー3|
|
25
|
-
|4|
|
25
|
+
|4|12345678|ユーザー4|
|
26
|
-
|5|
|
26
|
+
|5|12345678|ユーザー5|
|
27
27
|
|
28
28
|
⬇理想の形
|
29
29
|
|user_id|user_pw|user_name|
|
30
30
|
|:--|:--|:--|
|
31
|
+
|1|12345678|ユーザー1|
|
31
|
-
|
|
32
|
+
|2|1234abcd|ユーザー2|
|
32
|
-
|2|1234xz|鈴木二郎|
|
33
|
-
|3|
|
33
|
+
|3|abcd1234|ユーザー3|
|
34
|
-
|4|
|
34
|
+
|4|5678abcd|ユーザー4|
|
35
|
-
|5|
|
35
|
+
|5|abcdefgh|ユーザー5|
|
36
36
|
|
37
37
|
# 該当のソースコード
|
38
38
|
```php
|
39
39
|
# パスワード発行用
|
40
|
-
$num =
|
40
|
+
$num = 8;
|
41
41
|
$ar1 = range('a','z');
|
42
42
|
$ar2 = range('A','Z');
|
43
43
|
$ar3 = range('0','9');
|
@@ -55,4 +55,21 @@
|
|
55
55
|
$stmt->bindValue(':pass', $pass);
|
56
56
|
$stmt->bindValue(':user_pw', '');
|
57
57
|
$stmt->execute();
|
58
|
+
```
|
59
|
+
# 追記
|
60
|
+
これでランダム文字列をhash化して初期値の設定はできました。
|
61
|
+
```php
|
62
|
+
foreach($user as $user_id) {
|
63
|
+
$pass = substr(bin2hex(random_bytes($num)), 0, $num);
|
64
|
+
$hash = password_hash($pass, PASSWORD_BCRYPT);
|
65
|
+
$sql = '
|
66
|
+
UPDATE users
|
67
|
+
SET user_pw = :user_pw
|
68
|
+
WHERE user_id = :user_id
|
69
|
+
';
|
70
|
+
$prepare = $dbn->prepare($sql);
|
71
|
+
$prepare->bindValue(':user_pw', $hash);
|
72
|
+
$prepare->bindValue(':user_id', $user_id);
|
73
|
+
$prepare->execute();
|
74
|
+
}
|
58
75
|
```
|
1
誤字
title
CHANGED
File without changes
|
body
CHANGED
@@ -50,9 +50,9 @@
|
|
50
50
|
$stmt = $this->pdo->prepare('
|
51
51
|
UPDATE `users`
|
52
52
|
SET `user_pw` = :pass
|
53
|
-
WHERE `
|
53
|
+
WHERE `user_pw` = :user_pw
|
54
54
|
');
|
55
|
-
$stmt->
|
55
|
+
$stmt->bindValue(':pass', $pass);
|
56
|
-
$stmt->
|
56
|
+
$stmt->bindValue(':user_pw', '');
|
57
57
|
$stmt->execute();
|
58
58
|
```
|