Node.js的面试题内容总结(附答案)

本篇文章给大家带来的内容是关于node.js的面试题内容总结(附答案),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

译者按:ECMAScript标准Node.js语法以及NPM模块角度来看,Node.js的发展让人目不暇接,那么面试题也得与时俱进。

原文: Node.js Interview Questions and Answers (2017 Edition)

译者: Fundebug

为了保证可读性,本文采用意译而非直译。

问题

什么是错误优先的回调函数?

如何避免回调地狱?

什么是Promise?

用什么工具保证一致的代码风格?为什么要这样?

什么是Stub?举例说明

什么是测试金字塔?举例说明

最喜欢哪个HTTP框架?为什么?

Cookies如何防范XSS攻击?

如何保证依赖的安全性?

答案

1. 什么是错误优先的回调函数?

错误优先的回调函数(Error-First Callback)用于同时返回错误和数据。第一个参数返回错误,并且验证它是否出错;其他参数用于返回数据。

fs.readFile(filePath, function(err, data){    if (err)    {        // 处理错误        return console.log(err);    }    console.log(data);});

登录后复制

2. 如何避免回调地狱?

以下方式可以避免回调地狱:

模块化: 将回调函数转换为独立的函数

使用流程控制库,例如aync

使用Promise

使用aync/await(参考Async/Await替代Promise的6个理由)

3. 什么是Promise?

Promise可以帮助我们更好地处理异步操作。下面的示例中,100ms后会打印result字符串。catch用于错误处理。多个Promise可以链接起来。

new Promise((resolve, reject) =>    {        setTimeout(() =>        {            resolve('result');        }, 100)    })    .then(console.log)    .catch(console.error);

登录后复制

4. 用什么工具保证一致的代码风格?为什么要这样?

团队协作时,保证一致的代码风格是非常重要的,这样团队成员才可以更快地修改代码,而不需要每次去适应新的风格。这些工具可以帮助我们:

ESLint

Standard

感兴趣的话,可以参考JavaScript Clean Coding

5. 什么是Stub?举例说明

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();

登录后复制

6. 什么是测试金字塔?举例说明

测试金字塔反映了需要写的单元测试集成测试以及端到端测试的比例:

325841298-58eb2c47c247b_articlex.png

测试HTTP接口时应该是这样的:

很多单元测试,分别测试各个模块(依赖需要stub)

较少的集成测试,测试各个模块之间的交互(依赖不能stub)

少量端到端测试,去调用真正地接口(依赖不能stub)

7. 最喜欢哪个HTTP框架?为什么?

这个问题标准答案。需要描述框架的优缺点,这样可以反映开发者对框架的熟悉程度。

8. Cookies如何防范XSS攻击?

XSS(Cross-Site Scripting,跨站脚本攻击)是指攻击者在返回的HTML中插入JavaScript脚本。为了减轻这些攻击,需要在HTTP头部配置set-cookie:

HttpOnly – 这个属性可以防止cross-site scripting,因为它会禁止Javascript脚本访问cookie。

secure – 这个属性告诉浏览器仅在请求为HTTPS时发送cookie。

结果应该是这样的: Set-Cookie: sid=; HttpOnly. 使用Express的话,cookie-session默认配置好了。

9. 如何保证依赖的安全性?

编写Node.js应用时,很可能依赖成百上千的模块。例如,使用了Express的话,会直接依赖27个模块。因此,手动检查所有依赖是不现实的。唯一的办法是对依赖进行自动化的安全检查,有这些工具可供选择:

npm outdated

Trace by RisingStack

NSP

GreenKeeper

Snyk

附加题

1. 这段代码有什么问题?

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)})

登录后复制2. 这段代码有什么问题?

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)}

登录后复制

3. 这段代码的输出是什么?

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,逐行解释如下:

创建新的Promise,resolve值为1。

x为1,加1之后返回2。

x为2,但是没有用到。抛出一个错误。

捕获错误,但是没有处理。返回1。

x为1,加1之后返回2。

x为2,打印2。

不会执行,因为没有错误抛出。

以上就是Node.js的面试题内容总结(附答案)的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2738083.html

(0)
上一篇 2025年3月8日 01:44:51
下一篇 2025年2月24日 16:00:37

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • vue使用原生js实现滚动页面跟踪导航高亮

    本篇文章给大家带来的内容是关于vue使用原生js实现滚动页面跟踪导航高亮,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 需要使用vue做一个专题页面。 滚动页面指定区域导航高亮。 监听滚动页面事件,对比当前页面的位置与元素…

    编程技术 2025年3月8日
    200
  • es6中Set和Map的对比介绍(附代码)

    本篇文章给大家带来的内容是关于es6中set和map的对比介绍(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 Set 1、add()方法和size属性 { let list = new Set(); // add…

    编程技术 2025年3月8日
    200
  • ES6的Symbol的用法详解(附代码)

    本篇文章给大家带来的内容是关于es6的symbol的用法详解(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 1、Symbol是ES6新增的数据类型,它提供独一无二的值 { // 声明,Symbol声明的变量是唯一…

    编程技术 2025年3月8日
    200
  • ECMAScript 6中类继承解析(附示例)

    本篇文章给大家带来的内容是关于ecmascript 6中类继承解析(附示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 类继承 看类继承前,先回顾构造函数怎么实现对象的继承的 function F() { this.a…

    编程技术 2025年3月8日
    200
  • javascript函数表达式的特征以及递归的理解(附示例)

    本篇文章给大家带来的内容是关于javascript函数表达式的特征以及递归的理解(附示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 函数表达式是javascript中的一个既强大又容易令人困惑的特性。 定义函数的方式…

    编程技术 2025年3月8日
    200
  • 对es6中类的简单理解(附示例)

    本篇文章给大家带来的内容是关于对es6中类的简单理解(附示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 类class 基本概念,记录以便自己后面加深理解 了解类是什么 class是什么?不妨写一个看看 class D…

    编程技术 2025年3月8日
    200
  • ES6下异步处理的实例讲解

    本篇文章给大家带来的内容是关于es6下异步处理的实例讲解,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 前言 我们以查找指定目录下的最大文件为例,感受从 回调函数 -> Promise -> Generator…

    编程技术 2025年3月8日
    200
  • nodejs垃圾回收的详细介绍

    本篇文章给大家带来的内容是关于nodejs垃圾回收的详细介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 nodejs的垃圾回收机制是由v8引擎自动管理的。 nodejs的内存限制 在一般的后端语言(php)来说,内存的…

    编程技术 2025年3月8日
    200
  • ajax-plus的使用方法介绍(代码)

    本篇文章给大家带来的内容是关于ajax-plus的使用方法介绍(代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 ajax-plus 基于axios 的 Vue 插件 如何使用 npm 模块引入 首先通过 npm 安装…

    编程技术 2025年3月8日
    200
  • CommonJS规范是什么?了解CommonJS规范

    本篇文章给大家带来的内容是关于commonjs规范是什么?了解commonjs规范,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 写在前面:  一个文件就是一个模块。   另外本文中的示例代码需要在node.js环境中方可…

    编程技术 2025年3月8日
    200

发表回复

登录后才能评论