Blogger Information
Blog 16
fans 0
comment 0
visits 5784
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
【总结】Java实现短信验证码
Original
442 people have browsed it

背景

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

截图展示

实现代码

后台接收前台的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) # 服务器黑名单
  4. # 验签次数限制检测
  5. excess = self.auth.excess(2)
  6. if excess:
  7. return self.r_code(code=[20020, 20021, 20022][excess - 1])
  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/

Statement of this Website
The copyright of this blog article belongs to the blogger. Please specify the address when reprinting! If there is any infringement or violation of the law, please contact admin@php.cn Report processing!
All comments Speak rationally on civilized internet, please comply with News Comment Service Agreement
0 comments
Author's latest blog post