收藏本站 Archiver
    请 后使用快捷导航
    没有账号?入住 CI 中国社区
    查看: 3219|回复: 0

    [Web] Java实现KgCaptcha短信验证码

    [复制链接]
    楼主
    发表于 2023年4月13日 10:50:56 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |
    本帖最后由 宙哈哈 于 2023年4月13日 10:50 编辑

    背景
    Java是一种流行的编程语言,验证码是一种常用的网络安全技术。Java发展至今,网上也出现了各种各样的验证码,本人初学Java,下面是我用Java实现短信验证码的总结。

    截图展示

    6.PNG (234.26 KB, 下载次数: 93)

    下载附件

    2023年4月13日 10:47 上传




    实现代码
    后台接收前台的kgCaptchaToken进行验证,验证成功执行成功处理,验证失败返回错误代码及信息。
    1. package com.kyger;
    2. import jakarta.servlet.ServletException;
    3. import jakarta.servlet.http.HttpServlet;
    4. import jakarta.servlet.http.HttpServletRequest;
    5. import jakarta.servlet.http.HttpServletResponse;
    6. import java.io.IOException;
    7. import java.util.Map;
    8. public class demo extends HttpServlet {
    9. private static final long serialVersionUID = 1L;
    10. public demo() {
    11. super();
    12. }
    13. protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    14. // 编码
    15. request.setCharacterEncoding("utf-8");
    16. response.setCharacterEncoding("utf-8");;
    17. response.setContentType("text/html; charset=utf-8");
    18. // 后台处理
    19. if (request.getMethod().equals("POST")){
    20. String html, appId, appSecret, Token;
    21. // 设置 AppId 及 AppSecret,在应用管理中获取
    22. appId = "appId";
    23. appSecret = "appSecret";
    24. // 填写你的 AppId 和 AppSecret,在应用管理中获取
    25. KgCaptchaSDK KgRequest = new KgCaptchaSDK(appId, appSecret);
    26. // 前端验证成功后颁发的 token,有效期为两分钟
    27. KgRequest.token = request.getParameter("kgCaptchaToken");
    28. // System.out.print(KgRequest.token);
    29. // 填写应用服务域名,在应用管理中获取
    30. KgRequest.appCdn = "https://cdn.kgcaptcha.com";
    31. // 请求超时时间,秒
    32. KgRequest.connectTimeout = 5;
    33. // 用户登录或尝试帐号,当安全策略中的防控等级为3时必须填写,一般情况下可以忽略
    34. // 可以填写用户输入的登录帐号(如:request.getParameter("username"),可拦截同一帐号多次尝试等行为
    35. KgRequest.userId = "kgCaptchaDemo";
    36. // request 对象,当安全策略中的防控等级为3时必须填写,一般情况下可以忽略
    37. KgRequest.request = request;
    38. // java 环境中无法提供 request 对象,请分别定义:clientIp|clientBrowser|domain 参数,即:
    39. // KgRequest.clientIp = "127.0.0.1"; // 填写客户端IP
    40. // KgRequest.clientBrowser = ""; // 客户端浏览器信息
    41. // KgRequest.domain = "http://localhost"; // 你的授权域名或服务IP
    42. // 发送验证请求
    43. Map<String, String> requestResult = KgRequest.sendRequest();
    44. if("0".toString().equals(requestResult.get("code"))) {
    45. // 验签成功逻辑处理 ***
    46. // 这里做验证通过后的数据处理
    47. // 如登录/注册场景,这里通常查询数据库、校验密码、进行登录或注册等动作处理
    48. // 如短信场景,这里可以开始向用户发送短信等动作处理
    49. // ...
    50. html = "<script>alert('验证通过');history.back();</script>";
    51. } else {
    52. // 验签失败逻辑处理
    53. html = "<script>alert(\"" + requestResult.get("msg") + " - " + requestResult.get("code") + "\");history.back();</script>";
    54. }
    55. response.getWriter().append(html);
    56. } else {
    57. response.sendRedirect("index.html");
    58. }
    59. }
    60. protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    61. doGet(request, response);
    62. }
    63. }
    复制代码

    后端检测
    后台接收数据,同时对来源及应用进行检测。
    1. # 服务器黑名单检测
    2. if self.auth.client_blacklist():
    3. return self.r_code(20017) # 服务器黑名单[/align][align=left]
    4. # 验签次数限制检测
    5. excess = self.auth.excess(2)
    6. if excess:
    7. return self.r_code(code=[20020, 20021, 20022][excess - 1])[/align][align=left]
    8. # 来路域名检测
    9. if not self.kg["HTTP_REFERER"]: return self.r_code(20004) # 域名不合法,无法获取来路域名
    10. if not self.auth.domain_auth(): return self.r_code(20005) # 来源域名未授权

    11. # 应用有效时间检测
    12. validity = self.auth.app_validity()
    13. if validity[0] == 1: return self.r_code(20006) # 授权未开始
    14. if validity[0] == 2: return self.r_code(20007) # 授权已结束
    15. if self.auth.app_state(): return self.r_code(20008) # 当前应用/域名被禁用
    复制代码

    结尾
    SDK开源地址:https://github.com/KgCaptcha,顺便做了一个演示:https://www.kgcaptcha.com/demo/


    返回列表
    您需要登录后才可以回帖 登录 | 入住 CI 中国社区

    本版积分规则

    AltStyle によって変換されたページ (->オリジナル) /