はじめに
今回は”Server Side Support for Clean URLs”をやっていきたいと思います。
セットアップ
いつも通りに前回の続きを使っていきたいと思います。
カスタムサーバーを作成する
前回のルートマスキングではリロードするとエラーを吐き出してしまいました。
それの対策として、今回のカスタムサーバーを用います。
まずはじめにExpressをアプリに追加する必要があります。
コマンドプロンプトで以下のコードを打ち込みましょう。
npm install --save express
その後、server.jsを作成します。

また中身を以下のコードに書き換えましょう。
const express = require('express')
const next = require('next')
const dev = process.env.NODE_ENV !== 'production'
const app = next({ dev })
const handle = app.getRequestHandler()
app.prepare()
.then(() => {
const server = express()
server.get('*', (req, res) => {
return handle(req, res)
})
server.listen(3000, (err) => {
if (err) throw err
console.log('> Ready on http://localhost:3000')
})
})
.catch((ex) => {
console.error(ex.stack)
process.exit(1)
})また、package.jsonの中身も書き換えます。
before
{
"scripts": {
"dev": "next",
"build": "next build",
"start": "next start"
},
"dependencies": {
"express": "^4.16.4",
"next": "^7.0.2",
"react": "^16.7.0",
"react-dom": "^16.7.0"
}
}
after
{
"scripts": {
"dev": "node server.js",
"build": "next build",
"start": "NODE_ENV=production node server.js"
},
"dependencies": {
"express": "^4.16.4",
"next": "^7.0.2",
"react": "^16.7.0",
"react-dom": "^16.7.0"
}
}まだOKというわけではありません。
もうひと踏ん張りしましょう。
ブログ投稿のURLに合わせてカスタムルートを追加します。
server.jsの中身を書き換えましょう。
const express = require('express')
const next = require('next')
const dev = process.env.NODE_ENV !== 'production'
const app = next({ dev })
const handle = app.getRequestHandler()
app.prepare()
.then(() => {
const server = express()
server.get('/p/:id', (req, res) => {
const actualPage = '/post'
const queryParams = { title: req.params.id }
app.render(req, res, actualPage, queryParams)
})
server.get('*', (req, res) => {
return handle(req, res)
})
server.listen(3000, (err) => {
if (err) throw err
console.log('> Ready on http://localhost:3000')
})
})
.catch((ex) => {
console.error(ex.stack)
process.exit(1)
})ローカルホストを立ち上げます。

上にリロードボタンを押してみると・・・

エラーにはなりませんでした!
さいごに
これで”Server Side Support for Clean URLs”は終わりです。
だんだん難しくなってきましたがもう少しお互い頑張りましょう!