译者: Fundebug
错误优先的回调函数 (Error-First Callback) 用于同时返回错误和数据。第一个参数返回错误,并且验证它是否出错;其他参数用于返回数据。
- fs.readFile(filePath, function(err, data)
- {
- if (err)
- {
- // 处理错误
- return console.log(err);
- }
- console.log(data);
- });
以下方式可以避免回调地狱:
Promise 可以帮助我们更好地处理异步操作。下面的示例中,100ms 后会打印 result 字符串。 catch 用于错误处理。多个 Promise 可以链接起来。
- new Promise((resolve, reject) =>
- {
- setTimeout(() =>
- {
- resolve('result');
- }, 100)
- })
- .then(console.log)
- .catch(console.error);
团队协作时,保证一致的代码风格是非常重要的,这样团队成员才可以更快地修改代码,而不需要每次去适应新的风格。这些工具可以帮助我们:
感兴趣的话,可以参考 JavaScript Clean Coding
Stub 用于模拟模块的行为。测试时,Stub 可以为函数调用返回模拟的结果。比如说,当我们写文件时,实际上并不需要真正去写。
- var fs = require('fs');
- var writeFileStub = sinon.stub(fs, 'writeFile', function(path, data, cb)
- {
- return cb(null);
- });
- expect(writeFileStub).to.be.called;
- writeFileStub.restore();
测试金字塔反映了需要写的 单元测试 、 集成测试 以及 端到端测试 的比例:
测试 HTTP 接口时应该是这样的:
这个问题标准答案。需要描述框架的优缺点,这样可以反映开发者对框架的熟悉程度。
XSS(Cross-Site Scripting,跨站脚本攻击) 是指攻击者在返回的 html 中插入 JavaScript 脚本。为了减轻这些攻击,需要在 HTTP 头部配置 set-cookie :
结果应该是这样的: Set-Cookie: sid=
编写 Node.js 应用时,很可能依赖成百上千的模块。例如,使用了 Express 的话,会直接依赖 27 个模块 。因此,手动检查所有依赖是不现实的。唯一的办法是对依赖进行自动化的安全检查,有这些工具可供选择:
- new Promise((resolve, reject) =>
- {
- throw new Error('error')
- })
- .then(console.log)
then 之后没有 catch 。这样的话,错误会被忽略。可以这样解决问题:
- new Promise((resolve, reject) =>
- {
- throw new Error('error')
- })
- .then(console.log).catch(console.error)
调试一个大型的项目时,可以使用监控 unhandledRejection 事件来捕获所有未处理的 Promise 错误:
- process.on('unhandledRejection', (err) =>
- {
- console.log(err)
- })
- function checkApiKey(apiKeyFromDb, apiKeyReceived)
- {
- if (apiKeyFromDb === apiKeyReceived)
- {
- return true
- }
- return false
- }
比较密码时,不能泄露任何信息,因此比较必须在固定时间完成。否则,可以使用 timing attacks 来攻击你的应用。 为什么会这样呢 ?Node.js 使用 V8 引擎,它会从性能角度优化代码。它会逐个比较字符串的字母,一旦发现不匹配时就停止比较。当攻击者的密码更准确时,比较的时间越长。因此,攻击者可以通过比较的时间长短来判断密码的正确性。使用 cryptiles 可以解决这个问题:
- function checkApiKey(apiKeyFromDb, apiKeyReceived)
- {
- return cryptiles.fixedTimeComparison(apiKeyFromDb, apiKeyReceived)
- }
- Promise.resolve(1)
- .then((x) => x + 1)
- .then((x) => { throw new Error('My Error') })
- .catch(() => 1)
- .then((x) => x + 1)
- .then((x) => console.log(x))
- .catch(console.error)
答案是 2,逐行解释如下:
来源: http://www.tuicool.com/articles/NJzAvaf