【中检在线-注册安全分析报告】

前言

由于网站注册入口容易被黑客攻击,存在如下安全问题:

1. 暴力破解密码,造成用户信息泄露

2. 短信盗刷的安全问题,影响业务及导致用户投诉

3. 带来经济损失,尤其是后付费客户,风险巨大,造成亏损无底洞

所以大部分网站及App 都采取图形验证码或滑动验证码等交互解决方案, 但在机器学习能力提高的当下,连百度这样的大厂都遭受攻击导致点名批评, 图形验证及交互验证方式的安全性到底如何? 请看具体分析

一、 中检在线PC 注册入口

简介:"中检在线"隶属于中国检验认证(集团)有限公司,是中检集团的统一对外线上服务平台。"中检在线"致力于为客户提供高效、便捷的线上业务办理方式。平台提供在线下单、在线咨询、证书查询验真等功能,实现了中检集团业务互联网化,从客户下单、业务受理、证书查询,到开票申请、票据下载,实现全业务流程闭环操作。

二、 安全性分析报告:

中检在线采用的是自己研发的滑动验证码,容易被模拟器绕过甚至逆向后暴力攻击,滑动拼图识别率在 95% 以上。

三、 测试方法:

1 模拟器交互部分

java 复制代码
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的训练部署套件》

相关推荐
明月照山海-11 小时前
机器学习周报二十六
人工智能·机器学习·计算机视觉
乱世刀疤11 小时前
Dify修改默认80端口的方法
人工智能·dify
杨小扩12 小时前
提升开发效率的在线工具箱实践:集成AI能力的多功能工具平台体验
人工智能
Master_oid12 小时前
机器学习25:了解领域自适应(Domain Adaptation)
人工智能·深度学习·机器学习
永恒-龙啸12 小时前
图像增强与滤波
图像处理·人工智能·计算机视觉
嗷嗷哦润橘_12 小时前
AI Agent学习:MetaGPT项目之RAG
人工智能·python·学习·算法·deepseek
wanhengidc12 小时前
云手机 数据网络安全防护
安全·web安全
Buxxxxxx12 小时前
DAY 39 GPU训练及类的call方法
人工智能
我有医保我先冲12 小时前
企业级会议管理工具选型指南:从需求分析到方案落地
人工智能·经验分享·自然语言处理·需求分析
良策金宝AI12 小时前
从CAD插件到原生平台:工程AI的演进路径与智能协同新范式
大数据·人工智能