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

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

ただいまの
回答率

90.12%

Ionic 4のバックエンドのExpress.jsに出現するエラーが解決できない

受付中

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 177

dauto

score 17

techiediaries様のIonic 4のログイン処理の記事を参考にしながらIonic 4のログイン処理を設定していたのですが、Express.jsの認証サーバーでMySQLの設定中に以下のエラーが発生しました。
自分ではエラーの原因が分からなかったので、お手数ですがご助言を頂けると助かります。

"use strict";
const  express  =  require('express');
const  bodyParser  =  require('body-parser');
const cors = require('cors')
const  mysql  =  require('mysql');
const connection = mysql.createConnection({
    host: '133.18.201.159',
    port: 3306,
    user: 'Replication',
    password: 'Hnnk$6084',
    database: 'eccube_db_2'
});
const  jwt  =  require('jsonwebtoken');
const  bcrypt  =  require('bcryptjs');
const  crypto = require("crypto");

const SECRET_KEY = "secretkey23456";

const  app  =  express();
const  router  =  express.Router();
app.use(cors())

connection.connect()

router.use(bodyParser.urlencoded({ extended:  false }));
router.use(bodyParser.json());
}
const findUserByEmail  =  connection.query('SELECT * FROM 'dtb_customer' WHERE 'email' = ?', [email], function (err, row, fields) {
});

router.get('/', (req, res) => {
    res.status(200).send('This is an authentication server');
});

router.post('/login', (req, res) => {
    const  email  =  req.body.email;
    const  default_password  =  req.body.password;
    const hmac = crypto.createHmac('sha256', 'NFXwzxb5o9hfELny04AaoY0SgLRHrJlc');
    hmac.update(default_password . ':' . req.body.hash)
    findUserByEmail(email, (err, user)=>{
        if (err) return  res.status(500).send('Server error!');
        if (!user) return  res.status(404).send('User not found!');
        const  result  =  bcrypt.compareSync(password, user.password);
        if(!result) return  res.status(401).send('Password not valid!');

        const  expiresIn  =  24  *  60  *  60;
        const  accessToken  =  jwt.sign({ id:  user.id }, SECRET_KEY, {
            expiresIn:  expiresIn
        });
        res.status(200).send({ "user":  user, "access_token":  accessToken, "expires_in":  expiresIn});
    });
});

app.use(router);
const  port  =  process.env.PORT  ||  3000;
const  server  =  app.listen(port, () => {
    console.log('Server listening at http:fuwarun.net');
});

connection.end()
const findUserByEmail = connection.query('SELECT * FROM 'dtb_customer' WHERE 'email' = ?', [email], function (err, row, fields) {
^^^^^

SyntaxError: Unexpected token const
    at createScript (vm.js:56:10)
    at Object.runInThisContext (vm.js:97:10)
    at Module._compile (module.js:549:28)
    at Object.Module._extensions..js (module.js:586:10)
    at Module.load (module.js:494:32)
    at tryModuleLoad (module.js:453:12)
    at Function.Module._load (module.js:445:3)
    at Module.runMain (module.js:611:10)
    at run (bootstrap_node.js:394:7)
    at startup (bootstrap_node.js:160:9)
  • 気になる質問をクリップする

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

0

router.use(bodyParser.urlencoded({ extended:  false }));
router.use(bodyParser.json());
}

ここに余計な }が入っているのが原因かもしれないです。

ご確認お願いします。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

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

  • ただいまの回答率 90.12%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる