2024-08-23



// 安装node-sass-middleware
// npm install --save node-sass-middleware
 
// 引入node-sass-middleware
var sassMiddleware = require('node-sass-middleware');
var express = require('express');
var app = express();
 
// 使用sassMiddleware中间件来处理样式
app.use(sassMiddleware({
  src: __dirname + '/public', // 原始Sass文件目录
  dest: __dirname + '/public', // 编译后CSS文件存放目录
  prefix: '/styles', // 在URL中的前缀
  debug: true, // 是否开启debug模式
  outputStyle: 'compressed' // 编译后的CSS文件压缩方式
}));
 
// 其余的Express配置...
 
app.listen(3000, function () {
  console.log('Server is running on port 3000');
});

这段代码演示了如何在Express应用中使用node-sass-middleware来处理Sass文件,自动编译成CSS并添加到应用中。在实际应用中,你需要确保已经安装了node-sass-middlewareexpress

2024-08-23



const express = require('express');
const app = express();
 
// 解析JSON请求体
app.use(express.json());
 
// 解析URL编码的请求体
app.use(express.urlencoded({ extended: true }));
 
// 路由:获取所有用户
app.get('/users', (req, res) => {
  res.send('获取所有用户信息的接口');
});
 
// 路由:创建新用户
app.post('/users', (req, res) => {
  // 假设我们已经从请求体中获取了数据
  const userData = req.body;
  // 创建用户逻辑...
  res.send('创建新用户成功');
});
 
// 监听3000端口
app.listen(3000, () => {
  console.log('服务器运行在 http://localhost:3000/');
});

这段代码演示了如何在Express框架中使用中间件来处理JSON和URL编码的请求体,并定义了两个简单的RESTful API接口。这是开发Node.js后端服务的一个常见模式。

2024-08-23

在Node.js的Express框架中,中间件是一种组织和执行HTTP请求处理逻辑的方法。它们可以拦截请求,处理请求,并根据需要将请求委托给下一个中间件。

中间件的概念:

中间件函数是可以访问请求对象(req)、响应对象(res)和出错时的next函数的函数,在Express应用中,可以使用多个中间件函数来处理请求,它们按照注册的顺序执行。

Express中间件的初体验:




const express = require('express');
const app = express();
 
// 一个简单的中间件函数,记录请求路径
app.use((req, res, next) => {
  console.log(req.path);
  next();
});
 
app.listen(3000, () => {
  console.log('Server is running on port 3000');
});

中间件的分类:

  1. 应用级中间件:使用app.use()或app.get()、app.post()等方法注册的中间件,适用于所有的HTTP请求。
  2. 路由级中间件:使用router.use()或router.get()、router.post()等方法注册的中间件,只适用于匹配特定路由的请求。
  3. 错误处理中间件:用于处理错误的中间件,可以捕获在其之后的中间件中抛出的异常。

错误处理中间件的例子:




app.use((err, req, res, next) => {
  console.error(err.stack);
  res.status(500).send('Something broke!');
});

以上是Express中间件的基本概念和使用示例,它们是Node.js和Express框架开发中不可或缺的一部分。

2024-08-23

以下是使用Node.js, Vue.js和Multer中间件实现图片上传和预览的示例代码:

Node.js (Express) 端:




const express = require('express');
const multer = require('multer');
const path = require('path');
 
const app = express();
 
const storage = multer.diskStorage({
  destination: function (req, file, cb) {
    cb(null, 'uploads/') // 确保这个文件夹已经存在
  },
  filename: function (req, file, cb) {
    cb(null, file.fieldname + '-' + Date.now())
  }
})
 
const upload = multer({ storage: storage })
 
app.post('/upload', upload.single('image'), (req, res) => {
  const file = req.file;
  if (!file) {
    return res.status(400).send('No file uploaded.');
  }
  res.send(file.path); // 返回上传文件的路径
});
 
app.listen(3000, () => {
  console.log('Server is running on port 3000');
});

Vue.js 端:




<template>
  <div>
    <input type="file" @change="previewImage" />
    <img v-if="imageUrl" :src="imageUrl" alt="Image preview" />
  </div>
</template>
 
<script>
export default {
  data() {
    return {
      imageUrl: null
    };
  },
  methods: {
    async previewImage(event) {
      const image = event.target.files[0];
      const formData = new FormData();
      formData.append('image', image);
 
      try {
        const response = await fetch('http://localhost:3000/upload', {
          method: 'POST',
          body: formData
        });
        const imagePath = await response.text();
        this.imageUrl = URL.createObjectURL(image);
        console.log('Image uploaded and path received:', imagePath);
      } catch (error) {
        console.error('Error uploading image:', error);
      }
    }
  }
};
</script>

确保您已经安装了express和multer。




npm install express multer

此代码实现了图片的上传和预览功能。用户在Vue.js前端选择图片后,会通过FormData发送到Node.js服务器。服务器端使用multer中间件处理上传的文件,并返回文件的保存路径。Vue.js前端获取到这个路径后,可以用URL.createObjectURL方法创建一个可以在<img>标签中使用的URL,实现图片的预览。

2024-08-23

proxy-middleware 是一个 Node.js 中间件,用于简化代理服务器的配置和实现。以下是一个使用 http-proxy-middleware 创建代理服务器的示例代码:




const express = require('express');
const { createProxyMiddleware } = require('http-proxy-middleware');
 
const app = express();
 
// 创建代理服务器配置
const proxy = createProxyMiddleware('/api', {
    target: 'http://backend:3000', // 目标服务器地址
    changeOrigin: true, // 改变源地址,使目标服务器看到请求来自于代理服务器而不是直接来自客户端
    pathRewrite: {
        '^/api': '', // 重写请求路径
    },
    // 可以添加更多配置选项,如 onProxyReq, onProxyRes, secure, cookieDomainRewrite 等
});
 
// 使用代理服务器中间件
app.use(proxy);
 
// 其他中间件或路由配置...
 
app.listen(3000, () => {
    console.log('Proxy server is running on port 3000');
});

在这个示例中,我们创建了一个代理服务器,将所有到达 /api 路径的请求转发到 http://backend:3000changeOrigin 选项允许目标服务器看到请求是由代理服务器发起的,而不是直接由客户端发起的。pathRewrite 选项用于重写请求路径,去除 /api 前缀。这样配置后,发送到 /api/some/path 的请求将被代理到 http://backend:3000/some/path

2024-08-23

在Node.js中,Express是一个非常流行的web开发框架,它提供了一种简单的方法来创建web服务器,并处理HTTP请求。

在第七章中,我们主要讨论了Express的路由和中间件。

路由:

路由是指确定应用程序如何响应客户端请求的过程。在Express中,我们可以使用app.get(), app.post(), app.use()等方法来定义路由。




const express = require('express');
const app = express();
 
app.get('/', (req, res) => {
  res.send('Hello World!');
});
 
app.listen(3000, () => {
  console.log('Server is running on port 3000');
});

在上述代码中,我们定义了一个路由处理器,当客户端向根URL('/')发送GET请求时,服务器将响应'Hello World!'。

中间件:

中间件是一个函数,它可以访问请求对象(req)、响应对象(res)和next函数。在中间件函数内部,可以执行任何代码,并在必要时继续执行下一个中间件或路由处理器。




const express = require('express');
const app = express();
 
app.use((req, res, next) => {
  console.log('Incoming request');
  next();
});
 
app.get('/', (req, res) => {
  res.send('Hello World!');
});
 
app.listen(3000, () => {
  console.log('Server is running on port 3000');
});

在上述代码中,我们定义了一个中间件,它会在控制台输出'Incoming request',然后继续执行下一个中间件或路由处理器。

错误处理中间件:

错误处理中间件是一种特殊的中间件,它用于处理在应用程序中发生的错误。




const express = require('express');
const app = express();
 
app.get('/', (req, res) => {
  // 制造一个错误
  throw new Error('Something went wrong');
});
 
app.use((err, req, res, next) => {
  console.error(err.message);
  res.status(500).send('Internal Server Error');
});
 
app.listen(3000, () => {
  console.log('Server is running on port 3000');
});

在上述代码中,我们定义了一个错误处理中间件,它会捕获应用程序中发生的任何错误,并将错误的消息打印到控制台,同时向客户端返回500响应码和'Internal Server Error'。

以上就是Node.js中Express框架的路由和中间件的基本使用方法。

2024-08-23

在Node.js中,中间件是一种用于处理HTTP请求和响应的函数,它可以访问请求对象(request)、响应对象(response)以及应用程序的请求-响应循环内的next函数。中间件的一个常见用途是日志记录、身份验证、会话处理、错误处理等。

以下是一个简单的中间件示例,它记录每个请求的路径,并调用next()函数以继续执行下一个中间件或路由处理程序:




function logRequestPath(req, res, next) {
    console.log('Requested path:', req.path);
    next(); // 调用下一个中间件或路由处理程序
}
 
// 使用中间件的示例
const express = require('express');
const app = express();
 
app.use(logRequestPath); // 注册中间件
 
app.get('/', (req, res) => {
    res.send('Hello World!');
});
 
app.listen(3000, () => {
    console.log('Server is running on port 3000');
});

在这个例子中,当你访问 http://localhost:3000/ 时,你会在控制台看到输出 "Requested path: /",然后你会看到 "Hello World!" 响应。这是因为注册的中间件在请求到达路由处理程序之前执行,并且通过调用next()函数,请求-响应循环继续进行。

2024-08-23

Express是Node.js的一个非常流行的web开发框架,它提供了一系列的功能来帮助创建web服务器,例如路由、中间件、模板渲染等。

以下是一个简单的Express应用程序的例子:




const express = require('express');
const app = express();
 
app.get('/', (req, res) => {
  res.send('Hello World!');
});
 
app.listen(3000, () => {
  console.log('Server is running on port 3000');
});

在这个例子中,我们首先引入了Express模块,并创建了一个Express应用。然后,我们使用app.get()方法定义了一个路由处理函数,当访问根路径'/'时,它会向浏览器发送'Hello World!'消息。最后,我们使用app.listen()方法让应用监听3000端口。

这个例子展示了如何创建一个简单的Express服务器,并对外提供一个可访问的路由。这是学习Express的一个很好的起点。

2024-08-23



const express = require('express');
const app = express();
 
// 中间件,用于解析URL编码的请求体
app.use(express.urlencoded({ extended: true }));
 
// 中间件,用于解析JSON格式的请求体
app.use(express.json());
 
// 主页路由
app.get('/', (req, res) => {
  res.send('主页');
});
 
// API路由
app.get('/api/items', (req, res) => {
  res.json([{ id: 1, name: 'Item 1' }, { id: 2, name: 'Item 2' }]);
});
 
// 监听3000端口
app.listen(3000, () => {
  console.log('服务器运行在 http://localhost:3000/');
});

这段代码创建了一个简单的Express服务器,使用了Express的中间件来处理请求体的解析,并定义了两个路由:一个用于主页,一个用于API端点。服务器监听3000端口,并在控制台输出服务器运行的地址。这是一个典型的Node.js和Express框架的使用例子。

2024-08-23

Helmet 是一个 Express.js 中间件,它可以帮助你设置一些安全相关的HTTP头部,这些头部可以有助于提高Node.js应用的安全性。

以下是如何在一个基本的Express.js应用程序中使用Helmet的示例:

首先,你需要安装Helmet。在你的命令行中,运行以下命令:




npm install helmet

然后,你可以在你的Express.js应用程序中使用Helmet。以下是一个简单的例子:




const express = require('express');
const helmet = require('helmet');
 
const app = express();
 
// Use helmet
app.use(helmet());
 
app.get('/', (req, res) => {
  res.send('Hello World!');
});
 
app.listen(3000, () => {
  console.log('Server is running on port 3000');
});

在这个例子中,helmet()中间件被添加到了Express应用程序中。这将自动地给你的应用添加一些安全的HTTP头部,例如Content-Security-Policy, X-XSS-Protection, X-Frame-Options, X-DNS-Prefetch-Control, Strict-Transport-Security, 和 X-Download-Options

Helmet 提供的这些安全特性可以帮助减少你的应用遭受各种网页应用攻击(例如点击劫持、跨站脚本攻击等)的风险。

如果你想要自定义Helmet添加的头部,你可以传递一些选项给helmet()。例如,如果你想要自定义Content-Security-Policy头部,你可以这样做:




app.use(helmet({
  contentSecurityPolicy: {
    directives: {
      defaultSrc: ["'self'"]
    }
  }
}));

在这个例子中,我们只自定义了Content-Security-Policy头部的defaultSrc指令。Helmet的官方文档中提供了更多关于如何自定义Helmet中间件的信息。