前言
由于网站注册入口容易被黑客攻击,存在如下安全问题:
1. 暴力破解密码,造成用户信息泄露
2. 短信盗刷的安全问题,影响业务及导致用户投诉
3. 带来经济损失,尤其是后付费客户,风险巨大,造成亏损无底洞
所以大部分网站及App 都采取图形验证码或滑动验证码等交互解决方案, 但在机器学习能力提高的当下,连百度这样的大厂都遭受攻击导致点名批评, 图形验证及交互验证方式的安全性到底如何? 请看具体分析
一、 中检在线PC 注册入口
简介:“中检在线”隶属于中国检验认证(集团)有限公司,是中检集团的统一对外线上服务平台。“中检在线”致力于为客户提供高效、便捷的线上业务办理方式。平台提供在线下单、在线咨询、证书查询验真等功能,实现了中检集团业务互联网化,从客户下单、业务受理、证书查询,到开票申请、票据下载,实现全业务流程闭环操作。
二、 安全性分析报告:
中检在线采用的是自己研发的滑动验证码,容易被模拟器绕过甚至逆向后暴力攻击,滑动拼图识别率在 95% 以上。
三、 测试方法:
1 模拟器交互部分
private static String INDEX_URL = "https://online.ccic.com/register";
@Override
public RetEntity send(WebDriver driver, String areaCode, String phone) {
try {
RetEntity retEntity = new RetEntity();
driver.get(INDEX_URL);
// 1 姓名
WebElement nameElement = driver.findElement(By.xpath("//input[contains(@placeholder,'请输入姓名')]"));
nameElement.sendKeys("Abc123456");
// 2 输入手机号
WebElement phoneElement = driver.findElement(By.xpath("//input[contains(@placeholder,'请输入手机号')]"));
phoneElement.sendKeys(phone);
phoneElement.getAttribute("src");
// 3 点击获取验证码
Thread.sleep(1000);
WebElement buttonElement = driver.findElement(By.xpath("//button/span[text()='获取验证码']"));
((JavascriptExecutor) driver).executeScript("arguments[0].click();", buttonElement);
// 滑动 1 获取带阴影的背景图
Thread.sleep(1000);
WebElement bigElement = ChromeDriverManager.waitElement(driver, By.xpath("//img[@class='slide-canvas']"), 400);
String bigBase64 = bigElement.getAttribute("src");
byte[] bigBytes = (bigBase64 != null) ? GetImage.imgStrToByte(bigBase64) : null;
int bigLen = (bigBytes != null) ? bigBytes.length : 0;
// 滑动 2 获取小图
WebElement smallElement = ChromeDriverManager.waitElement(driver, By.xpath("//img[@class='slide-block']"), 1);
String smallBase64 = smallElement.getAttribute("src");
byte[] smallBytes = (smallBase64 != null) ? GetImage.imgStrToByte(smallBase64) : null;
// 滑动 3 计算匹配到的位置
String ckSum = GenChecksumUtil.genChecksum(bigBytes);
Map<String, Double> openResult = cv2.getOpenCvDistance(ckSum, bigBytes, smallBytes, "Ccic", 0);
if (openResult == null || openResult.size() < 2) {
System.out.println("ckSum=" + ckSum + "->openResult=" + openResult);
return null;
}
Double tpLeft = openResult.get("tpLeft");
Double minX = openResult.get("minX");
BigDecimal disD = new BigDecimal((minX - tpLeft) * 1.08).setScale(0, BigDecimal.ROUND_HALF_UP);
int distance = disD.intValue();
if (distance == 0) {
System.out.println("err distance=" + distance);
return null;
}
// 滑动 4 移动轨迹
WebElement moveElemet = ChromeDriverManager.waitElement(driver, By.id("slider-button"), 20);
ActionMove.move(driver, moveElemet, distance);
String msg = (buttonElement != null) ? buttonElement.getText() : null;
retEntity.setMsg(msg);
if (msg != null && msg.contains("秒后重新获取")) {
retEntity.setRet(0);
}
return retEntity;
} catch (Exception e) {
logger.error("phone=" + phone + ",e=" + e.toString());
for (StackTraceElement ele : e.getStackTrace()) {
System.out.println(ele.toString());
}
return null;
} finally {
driver.manage().deleteAllCookies();
}
}
2 测试结果输出:
3. 图片比对结果测试样例:
四丶结语
“中检在线”隶属于中国检验认证(集团)有限公司,是中检集团的统一对外线上服务平台。“中检在线”致力于为客户提供高效、便捷的线上业务办理方式。平台提供在线下单、在线咨询、证书查询验真等功能,实现了中检集团业务互联网化,从客户下单、业务受理、证书查询,到开票申请、票据下载,实现全业务流程闭环操作。作为国子头的官方认证企业,技术实力雄厚,但好像对短信被盗刷的方面不够重视或没有安全方面的经验 ,公司研发的滑动验证产品, 在一定程度上提高了用户体验, 不过随着图形识别技术及机器学习能力的提升,所以在网上破解的文章和教学视频也是大量存在,并且经过验证的确有效, 所以除了滑动验证方式, 花样百出的产品层出不穷,但本质就是牺牲用户体验来提高安全。
很多人在短信服务刚开始建设的阶段,可能不会在安全方面考虑太多,理由有很多。
比如:“ 需求这么赶,当然是先实现功能啊 ”,“ 业务量很小啦,系统就这么点人用,不怕的 ” , “ 我们怎么会被盯上呢,不可能的 ”等等。有一些理由虽然有道理,但是该来的总是会来的。前期欠下来的债,总是要还的。越早还,问题就越小,损失就越低。
所以大家在安全方面还是要重视。(血淋淋的栗子!)#安全短信#
戳这里→康康你手机号在过多少网站注册过!!!
谷歌图形验证码在AI 面前已经形同虚设,所以谷歌宣布退出验证码服务, 那么当所有的图形验证码都被破解时,大家又该如何做好防御呢?
>>相关阅读
《腾讯防水墙滑动拼图验证码》
《百度旋转图片验证码》
《网易易盾滑动拼图验证码》
《顶象区域面积点选验证码》
《顶象滑动拼图验证码》
《极验滑动拼图验证码》
《使用深度学习来破解 captcha 验证码》
《验证码终结者-基于CNN+BLSTM+CTC的训练部署套件》