express接口请求的几种方式分析总结

news2024/11/28 4:48:44

导语

在用express做接口开发的时候,我们要处理post,get,put,delete等请求,以及jsonp的方式,这篇文章记录下结合ajax,实现处理这些请求方式的过程

实现过程

上代码,主要演示post,get及jsonp的请求

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.0/jquery.min.js"></script>
</head>
<body>
   <button id="getBtn">GET</button>
   <button id="postBtn">POST</button>
   <button id="delBtn">DELETE</button>
   <button id="jsonpBtn">JSONP</button>

  <script>
       $(function(){
           const btnGet = $('#getBtn');
           const btnPost = $('#postBtn');
           const delBtn = $('#delBtn');
           const jsonpBtn = $('#jsonpBtn');
           btnGet.click(function(){
              console.log('哈哈哈')
              $.ajax({
                type:"GET",
                url:"http://127.0.0.1:4444/api/get",
                data:{
                  name:'sa',
                  age:20
                },
                success(res){
                  console.log("🚀 ~ success ~ res:", res)
                }
              })
           })
           btnPost.click(function(){
              console.log('哈哈哈')
              $.ajax({
                type:"POST",
                url:"http://127.0.0.1:4444/api/post",
                data:{
                  name:'lulu',
                  age:18
                },
                success(res){
                  console.log("🚀 ~ success ~ res:", res)
                }
              })
           })
           delBtn.click(function(){
            $.ajax({
              type:'DELETE',
              url:'http://127.0.0.1:4444/api/delete',
              success(res){
                  console.log("🚀 ~ success ~ res:", res)
                }
            })
           })
           //jsonp的请求需要加上datatype字段属性,其他的不用
           jsonpBtn.click(function(){
            $.ajax({
              url:'http://127.0.0.1:4444/api/jsonp?cabllbacb=cb',
              dataType:'jsonp',
              success(res){
                  console.log("🚀 ~ success ~ res:", res)
                }
            })
           })
       })
  </script>
</body>
</html>

在这里插入图片描述

jsonp的请求需要加上datatype字段属性,其他的不用,?callback=cb可以自己自定义,取名不限制,要注意的时候后端接口会获取这个名字,会用上,要保持一致

服务器接口代码

const express = require("express");
const userRouter = require("./router/user");
const bodyParser = require("body-parser");
const path = require("path");
const cors = require("cors");
const app = express();

app.use(express.static("public"));
//ejs模版的必须配置
// app.set("view engine", "ejs");
// app.set("views", path.join(__dirname, "views"));
//解析请求体参数
app.use(bodyParser.json());
app.use(express.urlencoded({ extended: false }));

//jsonp接口,必须在cors配置之前
app.use("/api/jsonp", (req, res) => {
  // TODO
  const fnName = req.query.callback;
  const data = {
    name: "李世明",
    age: 150,
    gender: "男",
  };
  const sData = `${fnName}(${JSON.stringify(data)})`;
  res.send(sData);
});

//跨域资源共享
app.use(cors());
app.use("/api", userRouter);

//错误级别的中间件
app.use((err, req, res, next) => {
  res.send("Error! " + err.message);
});

app.listen(4444, () => {
  console.log("app is running on port 4444");
});

**注意点:jsonp接口要写在配置cors配置之前,否则会当做普通的接口请求处理。**

get请求的结果

在这里插入图片描述

post请求的结果

在这里插入图片描述
delete请求的结果

关于预检请求也就是options接口:

客户端向服务端发起的询问是否支持该接口请求,服务端允许则发起真是的请求,否则会拒绝当前的请求
1.除get,post,head三个简单请求方式外的其他请求方式都会触发预检请求
2.请求头添加了自定义的信息,不是常见的请求头字段,也会触发预检请求

在这里插入图片描述
JSONP请求结果
在这里插入图片描述

严格来说,
jsonp不属于真正的ajax请求,因为它没有使用xmlhttprequest这个对象
JSONP只支持get方式,不支持其他请求方式

在这里插入图片描述
表头里面其他两个参数是浏览器自动生成的,不需要我们处理

const express = require("express");
const router = express.Router();

router.get("/get", (req, res) => {
  const data = req.query;
  res.send({
    status: 0,
    msg: "ok",
    data,
  });
});

router.post("/post", (req, res) => {
  const data = req.body;
  res.send({
    status: 0,
    msg: "ok",
    data,
  });
});

router.delete("/delete", (req, res) => {
  res.send({
    status: 0,
    msg: "ok",
  });
});

module.exports = router;

到这里,我们就熟悉了怎么处理常见的接口请求了

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1577892.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

引脚数量最少的单片机

引脚数量最少的单片机 2款SOT23-6封装单片机介绍 参考价格 PMS150C-U06 整盘单价&#xff1a;0.19688&#xff0c;该芯片为中国台湾品牌PADAUK(应广) SQ013L-SOT23-6-TR 整盘单价&#xff1a;0.27876&#xff0c;该芯片为国产&#xff1a;holychip(芯圣电子) 上述价格为2024…

弹幕功能1

今天看pure-admin的时候发现有个弹幕功能 GitHub - hellodigua/vue-danmaku: 基于 Vue 的弹幕交互组件 | A danmaku component for Vue

MySQL典型示例

目录 1.使用环境 2.设计表 3.创建表 4.准备数据 5.查询 1.使用环境 数据库&#xff1a;MySQL 8.0.30 客户端&#xff1a;Navicat 15.0.12 2.设计表 假设我们已经建好了一个名为test的数据库。我们添加如下几个表&#xff1a;教师、课程、学生、班级、成绩。实体联系图设…

GESP Python编程八级认证真题 2024年3月

Python 八级 2024 年 03 月 1 单选题&#xff08;每题 2 分&#xff0c;共 30 分&#xff09; 第 1 题 下列代码中&#xff0c;用到的算法是什么算法&#xff0c;去掉存储的空间&#xff0c;算法本身用到的空间复杂度是多少&#xff08; &#xff09; A. 二分法 &#xff0c; O…

无源定位之TDOA定位

一、基本原理 时差定位系统由一个中心站和两个以上的辅站组成&#xff0c;定位原理如下图&#xff08;a&#xff09;所示。主站以及辅站的位置均已知&#xff0c;并且接收辐射源信号&#xff0c;测出雷达发射的脉冲信号到达A,C两个基站之间的时间差&#xff0c;如图&#xff0…

提取COCO数据集中特定的类—vehicle 4类

提取COCO数据集中特定的类—vehicle 4类 1 安装pycocotools2 下载COCO数据集3 提取特定的类别4 多类标签合并 1 安装pycocotools pycocotools github地址 pip install githttps://github.com/philferriere/cocoapi.git#subdirectoryPythonAPI2 下载COCO数据集 COCO官网下载2…

Java常用API——五道综合练习

练习一&#xff1a; 键盘录入一些1~100的整数&#xff0c;并添加到集合中 直到集合中所有数据的和超过200为止 代码&#xff1a; public class Test1 {public static void main(String[] args) {/*键盘录入一些1~100的整数&#xff0c;并添加到集合中直到集合中所有数据的和…

比 Nest.js 更优雅的 TS 控制反转策略 - 依赖查找

一、Cabloy5.0 内测预告 Cabloy5.0 采用 TS 对整个全栈框架进行了脱胎换骨般的大重构&#xff0c;并且提供了更加优雅的 ts 控制反转策略&#xff0c;让我们的业务开发更加快捷顺畅 1. 新旧技术栈对比&#xff1a; 后端前端旧版js、egg2.0、mysqljs、vue2、framework7新版ts…

ISTQB选择国内版,还是国际版呢

1, ISTQB简介 ISTQB&#xff08;International Software Testing Qualifications Board&#xff09;是一个国际软件测试资格认证机构&#xff0c;旨在提供一个统一的软件测试认证标准。ISTQB成立于2002年&#xff0c;是非盈利性的组织&#xff0c;由世界各地的国家或地区软件测…

交叉注意力融合时域、频域特征的FFT + CNN -Transformer-CrossAttention电能质量扰动识别模型

往期精彩内容&#xff1a; 电能质量扰动信号数据介绍与分类-Python实现-CSDN博客 Python电能质量扰动信号分类(一)基于LSTM模型的一维信号分类-CSDN博客 Python电能质量扰动信号分类(二)基于CNN模型的一维信号分类-CSDN博客 Python电能质量扰动信号分类(三)基于Transformer…

OpenAI又更新,自定义AI模型上线

OpenAI 4日表示&#xff0c;他们正在为fine-tuning API引入新的改进功能&#xff0c;以帮助开发者更好地控制fine-tuning的过程&#xff0c;并且宣布了利用OpenAI构建自定义模型的新途径。 为了减少延迟、提高准确性和降低成本&#xff0c;开发者可以使用各种技术来提高模型性…

特别详细的Spring Cloud 系列教程2:微服务网关gateway的启动

继上一篇&#xff1a;特别详细的Spring Cloud 系列教程1&#xff1a;服务注册中心Eureka的启动 在比较多的教程和书籍里&#xff0c;spring cloud的微服务网关用的Zuul。然而&#xff0c;zuul已经不被官方提倡&#xff0c;现在提倡用的是spring cloud gateway。因为gateway的整…

安达发|五金加工业生产计划与排产常见问题及解决方法

五金加工业生产计划与排产是确保制造流程顺畅、高效的关键。在实际操作中&#xff0c;企业可能会遇到多种问题&#xff0c;影响生产效率和产品质量。以下是一些常见问题及其解决方法&#xff1a; 1. 需求预测不准确&#xff1a; - 建立更为精确的需求预测模型&#xff0c;结…

uni-app项目创建方式

原生小程序与uni-app的区别 创建uni-app的方式 1.通过HBuilderX创建 2.通过命令行创建 vue3ts版&#xff1a;npx degit dcloudio/uni-preset-vue#vite-ts 项目名称 用vscode开发uni-app项目 安装命令&#xff1a;npm i -D types/wechat-miniprogram uni-helper/uni-app-typ…

软件设计师-基础知识科目-数据结构3

三、 数据结构&#xff1a; 时间复杂度&#xff1a; 背复杂度对应的代码。Tips&#xff1a;时间复杂度估算看最内层循环&#xff0c;如若没有循环和递归则为O&#xff08;1&#xff09;。 空间复杂度&#xff1a; 需要单独空间存储数据时使用。考点&#xff1a;非递归的空间…

希亦、石头、添可洗地机哪个更好用?资深家电测评师多角度横评

作为一个测评了许多洗地机的家电测评师&#xff0c;有很多人问我&#xff0c;他想入手一款适合自己的家用洗地机&#xff0c;不知道怎么购买到自己合适的&#xff0c;结果自己跑去搜索后发现为什么有的洗地机几百块钱就能入手&#xff0c;而有的又得几千元&#xff0c;买贵的怕…

CSS实现热门创作者排行榜(毛玻璃效果)

CSS实现热门创作者排行榜&#xff08;毛玻璃效果&#xff09; 效果展示 CSS 知识点 CSS 基础知识回顾filter 属性运用回顾 整体页面布局实现 <div class"container"><h3>Popular Creator Rank List</h3><!-- 用户列表容器 --><div cl…

NetSuite Saved Search-当前库存快照查询报表(二)

之前第一篇文章我们说明了&#xff0c;如何利用Saved Search来制作一个能够显示批次物料与非批次物料的Lot信息以及On Hand在手数量的“当前库存快照查询报表”&#xff0c;但是当用户提出“我们能否再加上批次物料的效期”需求时&#xff0c;我们原有的Saved Search并不能达到…

k8s知识

k8s是用于容器编排和管理的&#xff0c;docker或者ctr是k8s的运行时&#xff0c;k8s通过容器运行时来启动容器&#xff0c;容器启动需要镜像&#xff0c;镜像可以用docker构建&#xff0c;dockerfile就是用于自定义如何构建镜像&#xff0c;所以上面那套流水线就是先用dockerfi…

苍穹外卖Day10——总结10

前期文章 文章标题地址苍穹外卖Day01——总结1https://lushimeng.blog.csdn.net/article/details/135466359苍穹外卖Day02——总结2https://lushimeng.blog.csdn.net/article/details/135484126苍穹外卖Day03——总结3https://blog.csdn.net/qq_43751200/article/details/1363…