在vue 脚手架中实现阿里PC端人机验证前端

在vue 脚手架中实现阿里云PC网页的人机滑动验证

这里附上官方文档 阿里pc网页滑动验证代码集成

  1. 在public/index里添加
<head>
     <!-- 国内使用 -->
    <script type="text/JAVAscript" charset="utf-8" src="https://g.alicdn.com/sd/ncpc/nc.js?t=2015052012"></script>
    <!-- 若您的主要用户来源于海外,请替换使用下面的js资源 -->
    <!-- <script type="text/JavaScript" charset="utf-8" src="//aeis.alicdn.com/sd/ncpc/nc.js?t=2015052012"></script> -->
</head>

2.页面使用
html代码

       <div id="slide" class="nc-container"></div>//slide为id可自定义
       <div class="container">
          <form action="http://192.168.0.100/api/Verification_code" method="post">//后台地址
              <input type="hidden" id="nc_token" name="token"/>//token
              <input type="hidden" id="csessionid" name="session_id"/>//sesson_id
              <input type="hidden" id="scene" name="scene" />//客户端场景
              <input type="hidden" id="sig" name="sig" />//签名
              <!-- <div class="ln">
               <input type="submit" value="提交" />
                </div> -->
           </form>
       </div>

在script标签前新加一个script标签

<script type="text/javascript"></script>//这里不加会报noCaptcha没有声明等错误

mounted

 mounted() {
    this.init();
  },

methods

 init() {
      var nc_token = [
        "FFFFXXXXXXXXXXXXXX",//appkey(自己填写)
        new Date().getTime(),
        Math.random()
      ].join(":");
      var NC_Opt = {
        renderTo: "#slide",
        appkey: "FFXXXXXXXXXXXXXXXXX", //appkey(自己填写)
        scene: "register", //场景值(当前pc网页端)
        token: nc_token,
        customWidth: 300,
        trans: { key1: "code0" },
        elementID: ["usernameID"],
        is_Opt: 0,
        language: "cn",
        isEnabled: true,
        timeout: 3000,
        times: 5,
        apimap: {},
        callback: function(data) {
          //组装数据到后台
          document.getElementById("nc_token").value = nc_token;
          document.getElementById("csessionid").value = data.csessionid;
          document.getElementById("sig").value = data.sig;
          //在这里可以拿到返回的数据
          // console.log("nc_token", nc_token);
          // console.log("csessionid", data.csessionid);
          // console.log("data.sig", data.sig);
          // 调取接口把数据返回给后端
          Verification({
            token: nc_token, //token
            session_id: data.csessionid, //客户端session
            sig: data.sig, //签名
            scene: "register" //客户端场景
          })
            .then(res => {
              console.log("验证返回", res);
            })
            .catch(err => {
              console.log(err);
            });
        }
      };
      var nc = new noCaptcha(NC_Opt);
      nc.upLang("cn", {
        _startTEXT: "请按住滑块,拖动到最右边",
        _yesTEXT: "验证通过",
        _error300:
          '哎呀,出错了,点击<a href="javascript:__nc.reset()">刷新</a>再来一次',
        _errorNetwork:
          '网络不给力,请<a href="javascript:__nc.reset()">点击刷新</a>'
      });

      var self = this;
      this.nc_token = [this.appKey, new Date().getTime(), Math.random()].join(
        ":"
      );
    },

如果想自定义样式可以查看文档 或者自行右键检查元素获取类名 使用v-deep穿透修改样式即可

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值