前端面试基础知识整理【Day-5】

目录

前言

web安全篇

1.如何防范XSS攻击

2.如何防范CSRF攻击

代码手写篇

1.函数柯里化

2.手写带并发限制的调度器


前言

前端面试基础知识整理【Day-1】-CSDN博客

前端面试基础知识整理【Day-2】-CSDN博客

前端面试基础知识整理【Day-3】-CSDN博客

前端面试基础知识整理【Day-4】-CSDN博客

web安全篇

1.如何防范XSS攻击

XSS攻击原理:

  • 攻击者在网页中插入恶意的<script>代码,当用户浏览器时,脚本将用户的Cookie/Token发给攻击者

XXS一般有两种类型:

  1. 存储型:恶意脚本存到数据库中(评论区),所有看评论的人都会被攻击
  2. URL型:脚本嵌入在URL参数里,只有点击了链接的人才会被攻击

防御措施:

  1. 转义(前端做) :把"< "变成"&lt ",把"> "变成"&gt"
  2. CSP策略(后端做):在HTTP Header中设置白名单,只允许加载那个域名的JS,其它域名的JS不执行
  3. HttpOnly Cookie(后端做):禁止JS读取Cookie

2.如何防范CSRF攻击

CSRF攻击原理:

  • 用户登录了A网站(浏览器存储了A网站的Cookie),攻击者诱导用户点击B网站(钓鱼网站),B网站偷偷向A网站发送一个请求,此时这个请求会带上A网站的Cookie,那么攻击者就会获取到A网站的Cookie

防御措施:

  1. SameSIte Cookie:设置SameSite=true或Lax(Chrom浏览器默认开启Lax)
  2. CSRF Token:登陆后服务器发给前端一个Token,前端每次发送POST请求都要在Header里带上这个Token,攻击者拿不到这个Token,伪造的请求就会失败
  3. 验证Referer/Origin:后端检查请求是从哪里发出来的

代码手写篇

1.函数柯里化

柯里化就像是bind()返回一个函数,这个函数会检查此时传入的参数,如果传入的参数不够则返回带有已传参数的函数,否则执行函数

javascript 复制代码
function curry(fn) {
  return function curried(...args) {
    if(args.length >= fn.length) {
      return fn.apply(this, args);
    }
    else {
      return function (...args2) {
        return curried.apply(this, [...args, ...args2]);
      }
    }
  }
}

function sum(a, b, c) {
  return a + b + c;
}

const curriedSum = curry(sum);

console.log("标准柯里化调用形式(1个1个的调用):",curriedSum(1)(2)(3)); 

console.log("一次调用多个参数的柯里化形式:",curriedSum(1, 2)(3)); 
console.log("一次调用多个参数的柯里化形式:",curriedSum(1)(2, 3)); 

console.log("一次调用所有参数的柯里化形式:",curriedSum(1, 2, 3)); 

结果:

2.手写带并发限制的调度器

场景:

有 100 个请求,但我只允许同时发送 2 个。发完一个,立马补进来一个。保持"池子"里始终有 2 个在跑

javascript 复制代码
class Scheduler {
  constructor(limit) {
    this.limit = limit;
    this.count = 0;
    this.queue = [];
  }
  add(promiseCreator) {
    return new Promise((resolve, reject) => {
      this.queue.push({
        creator: promiseCreator,
        resolve,
        reject
      });
      this.run();
    })
  }
  run() {
    if (this.queue.length === 0 || this.count >= this.limit) {
      return;
    }
    const { creator, resolve, reject } = this.queue.shift();
    this.count++;
    creator()
      .then(res => {
        resolve(res);
      })
      .catch(err => {
        reject(err);
      })
      .finally(() => {
        this.count--;
        this.run();
      })
  }
}

const timeout = (time) => new Promise(resolve => {
  setTimeout(resolve, time);
});

const scheduler = new Scheduler(2); 

const addTask = (time, order) => {
  scheduler.add(() => timeout(time))
    .then(() => console.log(`任务 ${order} 完成`));
};

addTask(1000, '1');
addTask(500, '2');
addTask(300, '3');
addTask(400, '4');

结果:

相关推荐
Bigger8 分钟前
从 Grunt 到 Vite:前端构建工具十几年的演化
前端·vite·前端工程化
IT_陈寒9 分钟前
Python 性能提升50%的5个魔法技巧,90%的人还不知道!
前端·人工智能·后端
前端Hardy9 分钟前
别再乱写正则了!一行 regex 可能让你的网站瘫痪 10 分钟
前端·javascript·面试
前端Hardy10 分钟前
Tauri 1.0 正式发布:用 Rust 写前端,体积比 Electron 小 90%!
面试
gyx_这个杀手不太冷静26 分钟前
OpenCode 进阶使用指南(第二章:Skills 系统)
前端·ai编程
牛奶29 分钟前
浏览器到底在偷偷帮你做什么?——HTTP缓存与刷新机制
前端·http·浏览器
CodeSheep1 小时前
“渐渐能理解为何不愿意雇佣35岁以上程序猿。去年换了份工作,组里4位组员其中3位40+,发现其实最大的问题并不是说精力不济卷不动”
前端·后端·程序员
摸鱼的春哥1 小时前
【实战】吃透龙虾🦞,你写的Agent也能支持Skills渐进式披露
前端·javascript·后端
恋猫de小郭1 小时前
你还用 IDE 吗? AI 狂欢时代下 Cursor 慌了, JetBrains 等 IDE 的未来是什么?
前端·flutter·ai编程
明月_清风1 小时前
拒绝盲目 Git:VS Code 神级插件 GitLens 的 9 个进效杀手锏
前端·git