网关限制需要前端做什么

 

 平时我们写的地址为了方便开发,都是直观的看见地址的源头。但是这个地址是不能放到互联网上,一旦被不怀好意的人发现了接口的源地址,就会造成数据的泄露。那么互联网上的地址是什么样的结构呢?我们来看一看

 画横线的地方是怎么生成的呢?以下代码就是需要前端做的修改


import { JSEncrypt } from "jsencrypt";

var rsa = {
  encrypt: function (publicKey, data) {
    // 使用公钥加密
    var encrypt = new JSEncrypt();
    encrypt.setPublicKey(
      "-----BEGIN PUBLIC KEY-----" + publicKey + "-----END PUBLIC KEY-----"
    );
    var encrypted = encrypt.encrypt(data);
    return encrypted;
  },
};
// 格式化数据
function toFormData(obj) {
  var query = "";
  var name, value, fullSubName, subName, subValue, innerObj, i;

  for (name in obj) {
    value = obj[name];

    if (value instanceof Array) {
      for (i = 0; i < value.length; ++i) {
        subValue = value[i];
        fullSubName = name; // name + '[' + i + ']';
        innerObj = {};
        innerObj[fullSubName] = subValue;
        query += toFormData(innerObj) + "&";
      }
    } else if (value instanceof Object) {
      for (subName in value) {
        subValue = value[subName];
        fullSubName = name + "[" + subName + "]";
        innerObj = {};
        innerObj[fullSubName] = subValue;
        query += toFormData(innerObj) + "&";
      }
    } else if (value !== undefined && value !== null) {
      query += encodeURIComponent(name) + "=" + encodeURIComponent(value) + "&";
    }
  }
  return query.length ? query.substr(0, query.length - 1) : query;
}
/**
 * 网关访问地址
 */
var DOMAIN_ADDRESS = "你的网关地址";
/**
 * 注册到网关的调用方应用所属的公钥,用于加密需要加密的参数
 */
var publicKey =
  "公钥";
/**
 * 注册到网关的调用方应用的key,作为唯一标识符
 */
var athenaAppKey = "唯一标识符";
/**
 * 注册到网关的调用方应用的名字
 */
var athenaAppName = "名字";

var rsaAppKey = encodeURIComponent(rsa.encrypt(publicKey, athenaAppKey));

var rsaAppName = encodeURIComponent(athenaAppName);

export { DOMAIN_ADDRESS, rsaAppKey, rsaAppName, toFormData };

公钥以及调用方应用的名字,后端在进行接口注册的时候会自动生成,到时候找后端大哥要就可以了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Zwq8023520

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值