質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Node.js

Node.jsとはGoogleのV8 JavaScriptエンジンを使用しているサーバーサイドのイベント駆動型プログラムです。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Express

ExpressはNode.jsのWebアプリケーションフレームワークです。 マルチページを構築するための機能セットおよびハイブリッドのWebアプリケーションを提供します。

Q&A

解決済

1回答

1528閲覧

bcryptでパスワードをhash化する際のsqlのエラーが直せない。

josikikusokurae

総合スコア27

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Node.js

Node.jsとはGoogleのV8 JavaScriptエンジンを使用しているサーバーサイドのイベント駆動型プログラムです。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Express

ExpressはNode.jsのWebアプリケーションフレームワークです。 マルチページを構築するための機能セットおよびハイブリッドのWebアプリケーションを提供します。

1グッド

0クリップ

投稿2022/01/06 08:54

現在、新規登録機能を作っており、パスワードのhash化をするためにプログラムを書いたら

throw err; // Rethrow non-MySQL errors ^ TypeError: Cannot read properties of undefined (reading 'insertId')

というエラーが出て、先に進めなくなってしまっています。
おそらく対象のコードは以下になります。

js

1app.post("/signup", 2 3 (req, res, next) => { 4 console.log("入力値の空チェック"); 5 6 const username = req.body.username; 7 const email = req.body.email; 8 const password = req.body.password; 9 10 const errors = []; 11 12 if(username === ""){ 13 errors.push("ユーザー名が空です"); 14 } 15 if(email === ""){ 16 errors.push("メールアドレスが空です"); 17 } 18 if(password === ""){ 19 errors.push("パスワードが空です"); 20 } 21 22 console.log(errors); 23 24 if(errors.length > 0){ 25 res.render("signup.ejs", {errors:errors}); 26 }else{ 27 next(); 28 } 29 }, 30 (req, res, next) => { 31 console.log("メールアドレスの重複チェック"); 32 const email = req.body.email; 33 const errors = []; 34 connection.query( 35 'SELECT * FROM users WHERE email = ?', 36 [email], 37 (error, results) => { 38 if (results.length > 0) { 39 errors.push("ユーザー登録に失敗しました"); 40 res.render("signup.ejs", {errors:errors}); 41 } else { 42 next(); 43 } 44 } 45 ); 46 }, 47 (req, res) => { 48 console.log('ユーザー登録'); 49 const username = req.body.username; 50 const email = req.body.email; 51 const password = req.body.password; 52 bcrypt.hash(password, 10, (error, hash) => { 53 connection.query( 54 'INSERT INTO users (username, email, password) VALUES (?, ?, ?)', 55 [username, email, hash], 56 (error, results) => { 57 req.session.userId = results.insertId; 58 req.session.username = username; 59 res.redirect('/'); 60 } 61 ); 62 }) 63 } 64 );

どなたか教えていただけませんでしょうか?

wasd0109👍を押しています

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

wasd0109

2022/01/06 12:07

req.session.userId = results.insertId;のところでresultsがundefinedになってることによるエラーですね errorのところでなんかエラーメッセージとか出てたりしてますか?
josikikusokurae

2022/01/06 12:39

at Query.<anonymous> (/Users/.../Desktop/list-app/app.js:114:39) at Query.<anonymous> (/Users/.../Desktop/list-app/node_modules/mysql/lib/Connection.js:526:10) at Query._callback (/Users/.../Desktop/list-app/node_modules/mysql/lib/Connection.js:488:16) at Query.Sequence.end (/Users/.../Desktop/list-app/node_modules/mysql/lib/protocol/sequences/Sequence.js:83:24) at Query.ErrorPacket (/Users/.../Desktop/list-app/node_modules/mysql/lib/protocol/sequences/Query.js:92:8) at Protocol._parsePacket (/Users/.../Desktop/list-app/node_modules/mysql/lib/protocol/Protocol.js:291:23) at Parser._parsePacket (/Users/.../Desktop/list-app/node_modules/mysql/lib/protocol/Parser.js:433:10) at Parser.write (/Users/.../Desktop/list-app/node_modules/mysql/lib/protocol/Parser.js:43:10) at Protocol.write (/Users/.../Desktop/list-app/node_modules/mysql/lib/protocol/Protocol.js:38:16) at Socket.<anonymous> (/Users/.../Desktop/list-app/node_modules/mysql/lib/Connection.js:88:28) こんな感じのが出てきました。
wasd0109

2022/01/06 12:43

(error, results) => { req.session.userId = results.insertId; req.session.username = username; res.redirect('/'); } のところにconsole.log(error)の出力も見せてもらえますか?
josikikusokurae

2022/01/06 12:47

すみません。知識が浅いもので、何をすればよいでしょうか?
wasd0109

2022/01/06 12:51

ちょっとわかりずらくて申し訳ないです。最後ユーザーをデーてベースに保存するときのコールバック関数 req.session.userId = results.insertId;の一行上にconsole.log(error);を入れて一回プログラム執行した後そのconsole.logの出力見たいです
josikikusokurae

2022/01/06 12:55

Error: ER_DATA_TOO_LONG: Data too long for column 'password' at row 1 code: 'ER_DATA_TOO_LONG', errno: 1406, sqlMessage: "Data too long for column 'password' at row 1", sqlState: '22001', index: 0, sql: "INSERT INTO users (username, email, password) VALUES ('daisuke', 'daisuke@example', '$2b$10$LQ3Nies8etOpZ62PQ9HlzOUyaUx2KipVoKQb5hJ3or5d4GUn1sqmO')" と出てきました!
wasd0109

2022/01/06 13:03

なるほど Hash化された後のパスワードが長すぎてデータベースのpasswordフィールドに設定されたデータタイプの上限を超えたようですね ネットで調べてみたらbcryptで生成されるhashのながさは60文字なので、今passwordフィールドに設定したデータタイプを60文字入れるように設定してみてください
josikikusokurae

2022/01/06 13:15

できました。ありがとうございました!
guest

回答1

0

自己解決

passwordフィールドの上限を再設定すると解決できました。

投稿2022/01/16 14:23

josikikusokurae

総合スコア27

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問