全部文档
当前文档

暂无内容

如果没有找到您期望的内容,请尝试其他搜索词

文档中心

请求处理程序开发方法

最近更新时间:2022-12-13 10:49:28

本文介绍在云函数KCF中使用Node.js语言开发请求处理程序的相关概念和方法。

请求处理程序分为事件请求处理程序(Event Handler)和HTTP请求处理程序(HTTP Handler);其中事件请求由各种事件源触发生成,HTTP请求则由HTTP触发器触发生成。
请求处理程序的具体配置示例如下:

事件请求处理程序(Event Handler)

介绍Node.js事件请求处理程序的结构和特点。

在Node.js语言的代码中,使用npm引入Express Web框架时,同时引入cloudevents官方的SDK库 :

npm install express -t .
npm install cloudevents -t .

express框架 + cloudevents 代码示例

const app = require("express")();
const { HTTP } = require("cloudevents");

app.get("/health", (req, res) => {
  console.log("health check message received");
  res.json("health");
});

app.post("/event-invoke", (req, res) => {
  const receivedEvent = HTTP.toEvent({ headers: req.headers, body: req.body });
  console.log("event received:", receivedEvent);
  res.json("event received");
});

app.use("/", (req, res, err, next) => {
  if (err) {
    console.log("err", err);
  }
});

const port = process.env.PORT || 8080;

const http = require("http");
const server = http.createServer(app);

server.on("error", (err) => {
  console.error("error", err);
});

server.listen(port, () => {
  console.log(`listening on ${port}`);
});


Event Handler的示例解析如下:

  • req:HTTP请求结构体。
  • res:HTTP返回结构体。
  • HTTP.toEvent: 将http请求内容转换成cloudevents结构体。

cloudevents详细介绍:

HTTP请求处理程序(HTTP Handler)

介绍Node.js HTTP请求处理程序的结构和特点。

在Node.js语言的代码中,使用npm引入Express Web框架时, 将express库安装到当前目录下 :

npm install express -t .

express框架代码示例

const app = require("express")();

app.all("/http-invoke", (req, res) => {
  const message = `${req.method} message received`;
  console.log(message);
  res.json(message);
});

app.use("/", (req, res, err, next) => {
  if (err) {
    console.log("err", err);
  }
});

const port = process.env.PORT || 8080;

const http = require("http");
const server = http.createServer(app);

server.on("error", (err) => {
  console.error("error", err);
});

server.listen(port, () => {
  console.log(`listening on ${port}`);
});

HTTP Handler的示例解析如下:

  • req:HTTP请求结构体。
  • res:HTTP返回结构体
文档导读
纯净模式常规模式

纯净模式

点击可全屏预览文档内容
文档反馈