防止频繁刷验证码接口-luosimao

在html中很容易可以拿到接口进行恶意访问,然后看到www.luosimao.com提供了免费的人机验证服务。

https://luosimao.com/docs/api/56 文档。

1.注册一个luosimao的账号。
2.选择人机验证,并添加新的网站
3.在客户端页面中添加以下相应的dom和脚本, site-key是创建完新网站,直接复制替换即可
// 这是异步的方式,如果使用同步的方式可参考文档用表单的形式提交

<div class="l-captcha" data-site-key="替换这里" data-callback="getResponse" data-width="250px"></div>
<a href="javascript:;" onclick="luosimaoRefresh();" class="l-reset"></a>


<script>

//验证完后成功会回调,并生成一个token
function getResponse(resp){
    luosimaoResp = resp;
    console.log(resp);  // resp 即验证成功后获取的值
}
//重置验证
function luosimaoRefresh(){
    luosimaoResp="";
    LUOCAPTCHA.reset();
}
</script>

4.服务端
替换 APIKEY

package com.ldd.common.luosimao;

import java.util.HashMap;
import java.util.Map;

import org.json.JSONObject;

import com.ldd.common.util.HttpUtil;

/**
 * @Description:luosimao 人机验证
 * @Author:lrj
 * @Date:2017年7月11日 上午11:28:36
 */

public class LuosimaoApi
{

    public static final String APIKEY = "替换这里";

    public static final String VALIDATE_URL = "https://captcha.luosimao.com/api/site_verify";

    /**
     * @Description:人机验证
     * @Author:lrj
     * @Date:2017年7月11日 上午11:53:38
     * resp 在客户端中会生成的token
     * @return 
     */
    public static boolean checkAuth(String resp)
    {
        Map<String, String> params = new HashMap<String, String>();
        params.put("api_key", APIKEY);
        params.put("response", resp);
        boolean flag = false;
        try
        {
            String httpResponse = HttpUtil.doPost(VALIDATE_URL, params);

            JSONObject jsonObj = new JSONObject(httpResponse);
            int error_code = jsonObj.getInt("error");
            String res = jsonObj.getString("res");
            if (error_code == 0 && "success".compareTo(res) == 0)
            {
                flag = true;
                System.out.println("Send message success.");
            }
            else
            {
                String error_msg = jsonObj.getString("msg");
                System.out.println("Fetch deposit failed,code is " + error_code + ",msg is " + error_msg);
            }
        }
        catch (Exception e)
        {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值