开源项目低代码表单FormCreate重写内置的请求方法,实现中间件和附带token

低代码表单FormCreate中为了确保所有的接口请求都包含认证 Token,您可以重写内置的请求方法,并在请求前动态地设置 Token。这不仅确保了请求的安全性,也使得 Token 的管理更加集中和一致。

源码地址: Github | Gitee | 帮助文档

重写内置请求方法并设置 Token

您可以自定义 formCreate.fetch 方法,以便在每次请求时自动附加 Token

js 复制代码
formCreate.fetch = (options) => {
    // 获取或生成 Token
    const token = 'your-auth-token'; // 这里的 token 可以从 Vuex、localStorage 或其他地方获取


// 设置请求头,附加 Authorization token
    const headers = {
        ...options.headers,
        Authorization: `Bearer ${token}`,
    };


// 发起请求
    fetch(options.action, {
        method: options.method || 'GET', // 默认请求方法为 GET
        headers: headers,                 // 包含 Authorization 的请求头
        body: options.method !== 'GET' ? JSON.stringify(options.data) : null, // 如果是 POST 或其他方法,添加请求体
    })
    .then(response => response.json())  // 解析响应为 JSON
    .then(data => {
        if (options.onSuccess) {
            options.onSuccess(data);  // 成功回调
        }
    })
    .catch(error => {
        if (options.onError) {
            options.onError(error);  // 失败回调
        }
    });
};

在请求前设置 Token

通过 beforeFetch 钩子,您可以在每次请求发送前设置 Token。以下是如何在 Vue 组件中使用这个钩子:

html 复制代码
<template>
    <form-create :rule="rule" v-model:api="fApi" :option="options" />
</template>

<script setup>
    import { ref } from 'vue';
    const fApi = ref({});
    const options = {
        // 在请求发送前的钩子
        beforeFetch: (options) => {
            // 动态设置请求头中的 Authorization token
            const token = 'your-auth-token'; // 这里的 token 可以从任何存储中获取
            options.headers = {
                Authorization: `Bearer ${token}`
            };
        }
    };
    const rule = [
        {
            type: 'select',
            field: 'product',
            title: '选择产品',
            fetch: {
                action: '/api/products',
                to: 'options',
                parse: (res) => res.data.map(product => ({ label: product.name, value: product.id })),
                onError: (error) => console.error('加载产品数据失败:', error),
            },
        }
    ];
</script>
相关推荐
Hommy8816 小时前
【开源剪映小助手】项目概述
开源·剪映小助手·视频剪辑自动化
CJH(本人账号)16 小时前
AI Agent 安全危机:当你的“智能助手“变成攻击者的“远程武器“
网络·人工智能·安全·ai·开源·github
henrylin999917 小时前
开源量化软件功能介绍
python·开源
AI_零食18 小时前
鸿蒙原生 ArkTS:margin 溢出、Row 弹性分配与 alignItems 的交互
学习·华为·开源·harmonyos·鸿蒙·鸿蒙系统
爱上纯净的蓝天18 小时前
30 分钟上手 AtomCode:用它写一个 Python 批量整理文件/改名/生成报告小工具(新手教程)
python·开源·自动化脚本·atomcode·ai 编码助手
GitCode官方18 小时前
AtomGit 5月:下载中心上线;AtomCode Air 新品发布会顺利开展;AtomGit AI 荣获「昇腾开源合作杰出团队奖」
人工智能·开源·atomgit
m0_7373025818 小时前
OpenClaw:让AI从对话走向落地的开源智能体新范式
人工智能·开源
xixixi7777719 小时前
英伟达 Cosmos3 开源物理世界模型、国内具身智能评测标准落地、宇树冲刺人形机器人第一股|具身智能进入技术、标准、商业化三重爆发期
大数据·人工智能·ai·机器人·开源·英伟达·人形机器人
该昵称用户已存在19 小时前
技术栈无关化设计:MyEMS 能源中台的兼容层架构与开源
架构·开源·能源
咖啡星人k19 小时前
MonkeyCode 开源安全审计:第三方依赖风险管理与供应链安全
安全·开源·monkeycode