Minimal and Clean blog theme for Hugo

RestAPI面试题


面试题:RestAPI 设计与开发经验

1. 基础概念

  • Q1: 什么是 RESTful API?
    • 请解释 RESTful API 的核心概念,例如资源、URI、HTTP 方法等。
  • Q2: RESTful API 有哪些优点?
    • 请列举 RESTful API 相较于其他 API 架构(例如 SOAP)的优势。
  • Q3: 如何设计一个良好的 RESTful API?
    • 请分享您在设计 RESTful API 时的经验和原则,例如 URI 设计、状态码使用、版本控制等。

2. 设计实践

  • Q4: 如何设计一个资源 URI?
    • 请举例说明如何为不同类型的资源设计合理的 URI,并解释设计思路。
  • Q5: 如何选择合适的 HTTP 方法?
    • 请解释 GET、POST、PUT、PATCH、DELETE 等 HTTP 方法的适用场景,并举例说明。
  • Q6: 如何处理 API 版本控制?
    • 请分享您在处理 API 版本控制时的经验和方法,例如 URI 版本控制、请求头版本控制等。
  • Q7: 如何设计 API 的安全机制?
    • 请解释您在设计 API 时如何保证安全性,例如身份验证、授权、数据加密等。

3. 开发经验

  • Q8: 您使用过哪些工具和技术开发 RESTful API?
    • 请列举您在开发 RESTful API 时使用过的编程语言、框架、库等工具和技术。
  • Q9: 您如何进行 API 测试?
    • 请分享您在测试 RESTful API 时的经验和方法,例如单元测试、集成测试、API 测试工具等。
  • Q10: 您如何处理 API 性能优化?
    • 请解释您在开发 RESTful API 时如何进行性能优化,例如缓存、负载均衡、数据库优化等。

4. 开放性问题

Read more ⟶

express框架的面试题


以下是一些关于 Express 框架 的常见面试题,涵盖基础知识到进阶使用:


基础知识

  1. 什么是 Express?它的主要特点是什么?

    • 解答要点:Express 是一个基于 Node.js 的轻量级 Web 应用框架,主要特点是简洁、灵活、可扩展,提供了中间件和路由系统。
  2. Express 中间件是什么?有哪些类型的中间件?

    • 解答要点:
      • 中间件是函数,可以对请求和响应对象进行处理。
      • 类型包括:
        • 内置中间件(如 express.static
        • 应用级中间件
        • 路由级中间件
        • 第三方中间件(如 body-parser, cors 等)
        • 错误处理中间件
  3. 如何处理静态资源?

    • 解答要点:使用 express.static 中间件,例如:
      app.use(express.static('public'));
      
  4. Express 中的路由是什么?如何定义一个路由?

    • 解答要点:
      • 路由是定义如何响应客户端请求的规则。
      • 示例:
        app.get('/user', (req, res) => {
          res.send('User Page');
        });
        
  5. 如何解析 JSON 和 URL 编码数据?

    • 解答要点:使用 express.json()express.urlencoded() 中间件。
      app.use(express.json());
      app.use(express.urlencoded({ extended: true }));
      

进阶问题

  1. 如何实现一个全局错误处理器?

    • 解答要点:
      • 错误处理中间件有 4 个参数:err, req, res, next
      • 示例:
        app.use((err, req, res, next) => {
          console.error(err.stack);
          res.status(500).send('Something broke!');
        });
        
  2. 如何实现自定义中间件?

Read more ⟶

免费https证书及续签


免费https证书及续签

1. 安装Certbot

首先,确保系统已更新:

sudo yum update -y

然后安装EPEL仓库:

sudo yum install epel-release -y

接着安装Certbot:

sudo yum install certbot -y

2. 生成证书脚本

假设你使用的是Nginx或Apache作为Web服务器,以下是生成证书的脚本示例。这里以Nginx为例:

#!/bin/bash

# 设置域名
DOMAIN1="51wurenji.com"
DOMAIN2="admin.51wurenji.com"
EMAIL="your-email@example.com"  # 替换为你的电子邮件地址

# 停止Nginx服务
sudo systemctl stop nginx

# 生成证书
sudo certbot certonly --standalone --expand -d $DOMAIN1 -d $DOMAIN2 --email $EMAIL --agree-tos --non-interactive

# 启动Nginx服务
sudo systemctl start nginx

echo "SSL证书已生成并保存在 /etc/letsencrypt/live/$DOMAIN1/"

将上述脚本保存为 generate_cert.sh,并赋予执行权限:

chmod +x generate_cert.sh

3. 配置自动续约

使用cron作业来定期检查和续约证书。编辑cron作业:

Read more ⟶

内网穿透之SSH反向隧道


DNS

将一个域名(aaa.bbb.com)用A记录解析到你的服务器ip(123.456.789)

服务器设置

安装SSH服务器软件

sudo apt-get install openssh-server // ubuntu
sudo yum install openssh-server // centos

配置SSH服务器

编辑SSH服务器的配置文件。在Ubuntu或CentOS中,配置文件通常位于/etc/ssh/sshd_config。在配置文件中,请确保以下选项设置为“yes” sudo nano /etc/ssh/sshd_config

GatewayPorts yes AllowTcpForwarding yes

重启ssh sudo systemctl restart ssh

配置NGINX

编辑Nginx配置文件(例如/etc/nginx/sites-available/default):

vim /etc/nginx/sites-available/default

server {
    listen 80;
    server_name aa.bbb.com;

    location / {
        proxy_pass http://localhost:8080;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;
    }
}

重启

Read more ⟶

对react的理解


对react的理解

跨浏览器事件统一

事件代理节省内容

并发渲染提高性能

常用hook

state

effect

memo

callback

context

reducer

react闭包问题

useState和useEffect

  • setState用回调
  • useEffect加依赖

hook原理

  • hook是按执行顺序存在组件的一个数组中的
  • 再次执行按顺序取对应的状态

父子通讯

Read more ⟶

整理一下


博客里的东西很多都只是随手记了一下。

本地的项目,github的项目,gitee的项目,cloudflare的项目,vercel的项目。都要整理下。

博客、博客园、小米笔记、语雀记的东西

博客中随手记的东西,应该叫草稿,不应该叫文章。所以默认应该是草稿,然后真正写好了,能说明白什么问题了,才发布。

todo 反向隧道原理及实战 安卓手机部署服务器 strapi的使用 tanstack-table实现自适应table

地图看片项目

分类: idea project public demo business note 网站收藏夹 有用的开源项目 post——能讲明白一件事,或者能做到什么事。

https://apis.map.qq.com/uri/v1/marker?marker=coord:39.892326,116.342763;title:超好吃冰激凌;addr:手帕口桥北铁路道口&referer=myapp

Read more ⟶

strapi


ubuntu服务器

安装nodejs

curl -fsSL https://deb.nodesource.com/setup_20.x | sudo -E bash -D sudo apt-get install -y nodejs

centos sudo dnf install -y nodejs

开启yarn

corepack enable

nginx

如何使用这两个文件夹

创建虚拟主机配置文件: 在 sites-available 文件夹中创建配置文件,例如 example.com:

sudo nano /etc/nginx/sites-available/example.com

编写配置文件: 在这个文件中编写虚拟主机的配置,例如:

server {
  listen 80;
  server_name example.com www.example.com;

  root /var/www/example.com/html;
  index index.html index.htm index.nginx-debian.html;

  location / {
    try_files $uri $uri/ =404;
  }
}

启用虚拟主机: 通过创建符号链接将配置文件从 sites-available 链接到 sites-enabled:

sudo ln -s /etc/nginx/sites-available/strapi.conf /etc/nginx/sites-enabled/

Read more ⟶

userland


启动ubuntu后运行ssh

修改 /support/startSSHServer.sh 文件,在最下面加两行

#! /bin/bash

if [ ! -f /support/.ssh_setup_complete ]; then
    rm -rf /etc/dropbear
    mkdir /etc/dropbear
    dropbearkey -t dss -s 1024 -f /etc/dropbear/dropbear_dss_host_key
    dropbearkey -t rsa -s 2048 -f /etc/dropbear/dropbear_rsa_host_key
    dropbearkey -t ecdsa -s 521 -f /etc/dropbear/dropbear_ecdsa_host_key
    touch /support/.ssh_setup_complete
fi

dropbear -E -p 2022

# Start OpenSSH Server
service ssh start

下载并修改ssh配置

sudo apt-get update sudo apt-get install openssh-server

启动回话是运行脚本

先修改默认登录用户的 .bashrc 文件,在最后加一行 su 来切换用户的 root, 然后修改root用户的 .bashrc 文件

Read more ⟶

Array的方法


Array的方法

  • 1.遍历foreach
  • 2.转换map、reduce
  • 3.扁平化flat
  • 4.过滤filter
  • 5.查找indexOf、includes、some、every、
  • 6.排序sort
  • 7.添加删除push、pop、shift、unshift
  • 8.拼接join、concat

includes适合比较基本类型,对象适合用some判断是否包含在数组中

Read more ⟶

nextjs缓存


nextjs缓存

遇到了一个缓存问题。

有一个列表页面和一个新建页面,新增一条数据后会返回到列表页,但是列表页中不显示新数据,怎么刷新不显示。

查了一下好像nextjs的全路由缓存机制(full-route-cache)1,下面是列表也的代码。

export default async function Page() {
   const notes = await prisma.markdownNote.findMany()
   return (
     <ClientList initData={notes} />
   )
}

先查到了用重新验证刷新缓存,revalidatePath方法,代码如下

export const POST = async (
   request: any,
   context: { params: { id: string } }
) => auth(async (req) => {
   const body = await req.json();
   const user: MarkdownNote = await prisma.markdownNote.create({data: body});
   revalidatePath('/markdown/list')
   return Response.json(user)
})(request, context)

但是用了之后不但没解决问题,反而出现了另一个问题——水合。不过我没有仔细研究这个问题,可能是因为服务端刷新了缓存,但是客户端缓存没刷新,两边对不上了导致的。

然后又加了 prefetch 解决了水合问题,但是缓存还是没刷新。

router.prefetch('/markdown/list')
router.push('/markdown/list')

最后找到了动态渲染(dynamic-rendering)2,大概意思是当页面中有动态函数3时,页面就不是全路由缓存了,而是有效载荷和数据缓存。

在列表页加了读取 session 就好了,感觉应该是它内部使用了动态函数。

export default async function Page() {
  const session = await auth();
  const userId = session?.user?.id
  const notes = await prisma.markdown_note.findMany({
    where: {
      userId: Number(userId)
    }
  })
  return (
    <ClientList initData={notes}/>
  )
}

现在问题就解决了。

后续要研究一下这部分的原理。

  • 缓存机制
  • 水合
  • 有效负载
Read more ⟶