4.6 KiB
id, title, challengeType, forumTopicId, dashedName
id | title | challengeType | forumTopicId | dashedName |
---|---|---|---|---|
589fc830f9fc0f352b528e74 | 設置環境 | 2 | 301566 | set-up-the-environment |
--description--
在接下來的挑戰中,我們將會用到 chat.pug
文件。 首先,在你的 routes.js
文件中爲 /chat
添加一個處理 GET 請求的路由,並給它傳入 ensureAuthenticated
。在回調函數中,我們需要讓它渲染 chat.pug
文件,並在響應中包含 { user: req.user }
信息。 現在,請修改 /auth/github/callback
路由,讓它可以像這樣設置 user_id:req.session.user_id = req.user.id
,並在設置完成後重定向至 /chat
。
添加 socket.io@~2.3.0
作爲依賴項,並且在你的服務器中和 http
(內置在 Nodejs 中)一起導入/實例化。具體如下:
const http = require('http').createServer(app);
const io = require('socket.io')(http);
現在我們的 express 應用已經包含了 http 服務,接下來我們需要監聽 http 服務的事件。 爲此,我們需要把 app.listen
更新爲 http.listen
。
需要處理的第一件事是監聽客戶端的新連接。 on 關鍵字就是監聽這個特定事件。 它需要 2 個參數:一個包含所發出事件標題的字符串,以及一個用於傳遞數據的函數。 在連接監聽器中,我們用 socket 來代表它所包含的數據。 socket 就是指已連接到服務器的客戶端。
爲了可以監聽服務器的連接事件,我們在數據庫連接的部分加入如下代碼:
io.on('connection', socket => {
console.log('A user has connected');
});
對於發出連接事件的客戶端,只需要在認證後頁面加載出的 client.js
中添加以下內容:
/*global io*/
let socket = io();
在這個文件中,我們沒有定義 “io” 變量,但第一行的註釋會阻止運行時產生的報錯。 不過,我們在 chat.pug 的頁面上已經爲你添加好了 Socket.IO 庫的 CDN。
現在你可以重啓一下你的 app,嘗試一下驗證用戶,然後你應該會看到服務器的 console 裏輸出了 “A user has connected”。
**注意:**只有在連接到處於同一個 url/server 上的 socket 時,io()
纔可以正常執行。 如果需要連接到外部的 socket,就需要這樣調用:io.connect('URL');
。
完成上述要求後,請提交你的頁面鏈接。 如果你遇到了問題,可以參考這裏的答案。
--hints--
應添加 socket.io
作爲依賴。
(getUserInput) =>
$.get(getUserInput('url') + '/_api/package.json').then(
(data) => {
var packJson = JSON.parse(data);
assert.property(
packJson.dependencies,
'socket.io',
'Your project should list "socket.io" as a dependency'
);
},
(xhr) => {
throw new Error(xhr.statusText);
}
);
應正確引入 http
,並實例化爲 http
。
(getUserInput) =>
$.get(getUserInput('url') + '/_api/server.js').then(
(data) => {
assert.match(
data,
/http.*=.*require.*('|")http\1/gi,
'Your project should list "http" as a dependency'
);
},
(xhr) => {
throw new Error(xhr.statusText);
}
);
應正確引入 socket.io
,並實例化爲 io
。
(getUserInput) =>
$.get(getUserInput('url') + '/_api/server.js').then(
(data) => {
assert.match(
data,
/io.*=.*require.*('|")socket.io\1.*http/gi,
'You should correctly require and instantiate socket.io as io.'
);
},
(xhr) => {
throw new Error(xhr.statusText);
}
);
Socket.IO 應監聽連接。
(getUserInput) =>
$.get(getUserInput('url') + '/_api/server.js').then(
(data) => {
assert.match(
data,
/io.on.*('|")connection\1.*socket/gi,
'io should listen for "connection" and socket should be the 2nd arguments variable'
);
},
(xhr) => {
throw new Error(xhr.statusText);
}
);
客戶端應連接到服務器。
(getUserInput) =>
$.get(getUserInput('url') + '/public/client.js').then(
(data) => {
assert.match(
data,
/socket.*=.*io/gi,
'Your client should be connection to server with the connection defined as socket'
);
},
(xhr) => {
throw new Error(xhr.statusText);
}
);
--solutions--
/**
Backend challenges don't need solutions,
because they would need to be tested against a full working project.
Please check our contributing guidelines to learn more.
*/