首页 > 其他分享 >抖音旋转验证码角度识别方案

抖音旋转验证码角度识别方案

时间:2024-09-02 16:53:11浏览次数:4  
标签:img format base64 验证码 抖音 str img2 识别

  

一、简介

上图是抖音最新的旋转验证码,和老款旋转验证码相比,现在新增了很多防御措施,比如内圈小图增加了白色花边,内外圈图片颜色有一定差异等等。所以给我们识别增加了很大难度。

二、免费识别方法介绍

经过我们大量的数据标注,我们终于完成了这款验证码的角度识别。我们可以完成原图、截图两种识别方式,并且正确率可以达到99%左右。我们封装成了接口,大家可以在这里免费测试识别效果:得塔云

大家可以根据下图所示,点击在线获取图片,然后得到图片,最后点击识别

识别效果如下,下面就会看到图片矫正效果,因为实际旋转是中间小图顺时针旋转,外圈大图是逆时针旋转,所以下图识别的69度就是小图顺时针旋转69度,外圈大图是逆时针旋转69度的结果。

三、识别代码

1、原图识别

原图识别是指通过网站上图片链接直接下载的图片,具有固定的图片尺寸,大图347×347、小图211×211,如下图所示

python识别代码如下

import base64
import requests
import datetime
import numpy as np
from io import BytesIO
from PIL import Image

t1 = datetime.datetime.now()

#PIL图片保存为base64编码
def PIL_base64(img, coding='utf-8'):
    img_format = img.format
    if img_format == None:
        img_format = 'JPEG'

    format_str = 'JPEG'
    if 'png' == img_format.lower():
        format_str = 'PNG'
    if 'gif' == img_format.lower():
        format_str = 'gif'

    if img.mode == "P":
        img = img.convert('RGB')
    if img.mode == "RGBA":
        format_str = 'PNG'
        img_format = 'PNG'

    output_buffer = BytesIO()
    # img.save(output_buffer, format=format_str)
    img.save(output_buffer, quality=100, format=format_str)
    byte_data = output_buffer.getvalue()
    base64_str = 'data:image/' + img_format.lower() + ';base64,' + base64.b64encode(byte_data).decode(coding)

    return base64_str

# 旋转图片
def rotate_img(img, angle):
    # 转换为有alpha层
    temp_img2 = img.convert('RGBA')
    # 旋转
    rot = temp_img2.rotate(-angle)
    # 创建一个与旋转图像大小相同的白色图像
    fff = Image.new('RGBA', rot.size, (255, 255, 255, 0))
    # 使用alpha层的rot作为掩码创建一个复合图像
    out = Image.composite(rot, fff, rot)
    # 将临时图片转换为元素图片颜色模式
    temp_img2 = out.convert(img.mode)

    return temp_img2

# 加载外圈大图
img1 = Image.open(r'E:\Python\lixin_project\OpenAPI接口测试\test_img\58-1.png')
# 图片转base64
img1_base64 = PIL_base64(img1)
# 加载内圈小图
img2 = Image.open(r'E:\Python\lixin_project\OpenAPI接口测试\test_img\58-2.png')
# 图片转base64
img2_base64 = PIL_base64(img2)

# 验证码识别接口
url = "https://www.detayun.cn/openapi/verify_code_identify/"
data = {
    # 用户的key
    "key":"EI4vT8UGFTXRE4hZR7cE",
    # 验证码类型
    "verify_idf_id":"58",
    # 外圈大图
    "img1":img1_base64,
    # 内圈小图
    "img2":img2_base64,
}
header = {"Content-Type": "application/json"}
# 发送请求调用接口
response = requests.post(url=url, json=data, headers=header)

# 获取响应数据,识别结果
print(response.text)
print("耗时:", datetime.datetime.now() - t1)
angle = response.json()['data']['angle']

# 使用crop方法裁剪图片
s_img = img2
b_img = img1
# 旋转图片
b_img = rotate_img(b_img, -angle)
s_img = rotate_img(s_img, angle)
# 将小图粘贴到大图的中心
b_img.paste(s_img, (70, 70))
b_img.show()

运行上面代码,可以直接看到识别后的拼接效果图

2、截图识别

截图识别对图片有一定的要求,必须是对圆形图片切边截取,截取下来应该是一个正方形。如果切边截图不标准,可能会影响到识别正确率。

切边截取样例图如下,比如如下图蓝线所示,与圆形外切:

python识别代码如下:


import base64
import requests
import datetime
import numpy as np
from io import BytesIO
from PIL import Image

t1 = datetime.datetime.now()

#PIL图片保存为base64编码
def PIL_base64(img, coding='utf-8'):
    img_format = img.format
    if img_format == None:
        img_format = 'JPEG'

    format_str = 'JPEG'
    if 'png' == img_format.lower():
        format_str = 'PNG'
    if 'gif' == img_format.lower():
        format_str = 'gif'

    if img.mode == "P":
        img = img.convert('RGB')
    if img.mode == "RGBA":
        format_str = 'PNG'
        img_format = 'PNG'

    output_buffer = BytesIO()
    # img.save(output_buffer, format=format_str)
    img.save(output_buffer, quality=100, format=format_str)
    byte_data = output_buffer.getvalue()
    base64_str = 'data:image/' + img_format.lower() + ';base64,' + base64.b64encode(byte_data).decode(coding)

    return base64_str

# 旋转图片
def rotate_img(img, angle):
    # 转换为有alpha层
    temp_img2 = img.convert('RGBA')
    # 旋转
    rot = temp_img2.rotate(-angle)
    # 创建一个与旋转图像大小相同的白色图像
    fff = Image.new('RGBA', rot.size, (255, 255, 255, 0))
    # 使用alpha层的rot作为掩码创建一个复合图像
    out = Image.composite(rot, fff, rot)
    # 将临时图片转换为元素图片颜色模式
    temp_img2 = out.convert(img.mode)

    return temp_img2

# 加载外圈大图
img1 = Image.open(r'E:\Python\lixin_project\OpenAPI接口测试\test_img\58-5.jpg')
# 图片转base64
img1_base64 = PIL_base64(img1)

# 验证码识别接口
url = "https://www.detayun.cn/openapi/verify_code_identify/"
data = {
    # 用户的key
    "key":"EI4vT8UGFTXRE4hZR7cE",
    # 验证码类型
    "verify_idf_id":"58",
    # 外圈大图
    "img1":img1_base64,
    # 内圈小图
    "img2":"",     # 这里必须设置为空字符串
}
header = {
    "Content-Type": "application/json"
}
# 发送请求调用接口
response = requests.post(url=url, json=data, headers=header)

# 获取响应数据,识别结果
print(response.text)
print("耗时:", datetime.datetime.now() - t1)
angle = response.json()['data']['angle']

width, height = img1.size
# 判断图片的形状是否是300x300
if width != 300 or height != 300:
    # 如果不是,则调整图片大小到300x300
    img = img1.resize((300, 300), Image.ANTIALIAS)  # 注意:应该是 Image.ANTIALIAS 或 Image.ANTIALIASED
# 定义裁剪区域(左上角坐标,宽度,高度)
# 这里的坐标和尺寸都是基于像素的
crop_rectangle = (55, 55, 245, 245)  # 例如:(100, 100, 400, 400) 表示从(100, 100)开始裁剪,宽度和高度都是300像素
# 使用crop方法裁剪图片
s_img = img.crop(crop_rectangle)
b_img = img
# 旋转图片
b_img = rotate_img(b_img, -angle)
s_img = rotate_img(s_img, angle)
# 将小图粘贴到大图的中心
b_img.paste(s_img, (55, 55))
b_img.show()

想了解更多验证码识别,请访问:得塔云

标签:img,format,base64,验证码,抖音,str,img2,识别
From: https://blog.csdn.net/2201_75821470/article/details/141821219

相关文章

  • 【验证码逆向专栏】某某邮政滑块逆向分析
    声明本文章中所有内容仅供学习交流使用,不用于其他任何目的,不提供完整代码,抓包内容、敏感网址、数据接口等均已做脱敏处理,严禁用于商业用途和非法用途,否则由此产生的一切后果均与作者无关!本文章未经许可禁止转载,禁止任何修改后二次传播,擅自使用本文讲解的技术而导致的任何意外,作......
  • 安全帽ai自动识别算法
    安全帽ai自动识别算法是人工智能与视觉系统算法技术性的结合。通过10年的工艺累积,SuiJivision具备深层次的人工智能自主学习、图像识别、行为分析、发展趋势认知、风险预警等工作能力,安全帽ai自动识别算法可以根据认知情景动态性、即时解析和管理方法情景个人行为来预知未来的风......
  • 安全帽检测识别系统
    安全帽检测识别系统是运用多感知融合多流水线处理技术对监控画面进行实时剖析识别。假如安全帽检测识别系统发觉施工作业现场工作人员未按要求配戴安全帽,系统将全自动发出预警声响。在提示管理者的与此同时,系统将全自动储存违规视频、现场地址和监控画面截图。在人工智能化的浪潮......
  • 工地安全帽智能识别检测系统
    工地安全帽智能识别检测系统可以在大部分工程施工损害中充分发挥保障功效。但在具体运用中,不戴安全帽、临时性摘帽子等违纪行为常常产生,安全性工作人员不可以即时查验施工队伍是不是戴安全帽,多次开展工作人员查验,提升经济成本和用工成本费。工地安全帽智能识别检测系统全自动监管......
  • 工地安全帽识别系统
    工地安全帽识别系统运用智能视频采集和认真贯彻神经元网络技术性,根据分布在工地各处的监控终端传回的视频即时解析和预警信息,工地安全帽识别系统将完成施工工地、石油化工、电力工程等高风险行业生产制造地区工作人员活动的即时解析和识别,判断施工作业人员是不是配戴帽子、追踪和......
  • 安全帽佩戴识别系统
    安全帽佩戴识别系统的机理是应用人工智能技术即时剖析工作中現场的监控视频画面。假如现场作业人员无法依照规定佩戴安全帽或进行抽烟,安全帽佩戴识别系统将全自动传出报警。在提示管理负责人与此同时,系统全自动将时长、地址和相对应相片储存为违规依据。在人工智能的形势下,传统式......
  • 安全帽智能识别系统
    安全帽智能识别系统可以全自动检测和分析监控画面范畴内的施工作业人员的安全帽的佩戴情况,针对未佩戴帽子规范的不安全行为,安全帽智能识别系统可以即时监控和向发送抓拍图片进行预警。PC手机客户端可以显示警示视频信息和屏幕截屏,施工作业现场可以放置音箱和扬声器进行实时警示。......
  • 安全帽佩戴识别检测系统
    安全帽佩戴识别检测系统是根据分布在现场各个角落的终端监控传回的视频流进行实时分析识别的系统。安全帽佩戴识别检测系统应用深度神经网络和云计算技术来全自动识别现场监控画面中人跟物的违规操作。安全帽佩戴识别检测系统可以监控识别现场作业人员是否佩戴安全帽,并应用多流水......
  • 监控识别未佩戴安全帽
    监控识别未佩戴安全帽对生产制造现场施工作业起到关键的安全防范措施之一,监控识别未佩戴安全帽使作业现场的施工人员在施工作业的时候一定戴安全帽。因为在施工作业的工地或者煤矿作业现场会出现:有的人随便取下安全帽,有的人在高处工作中不戴安全帽这种情况。传统式的生产现场管......
  • zdppy+vue3+onlyoffice文档管理系统实战 20240901 上课笔记 基于验证码登录功能基本完
    遗留的问题1、点击切换验证码2、1分钟后自动切换验证码点击切换验证码实现步骤:1、点击事件2、调用验证码接口3、更新验证码的值点击事件给图片添加点击事件:<img:src="'data:image/png;base64,'+captchaImg"style="width:100%;height:50px;margin-top:10......