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

抖音旋转验证码角度识别

时间:2024-08-30 14:52:06浏览次数:14  
标签: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/141717743

相关文章

  • Java人证合一接口原理、身份证识别、人工智能
    人脸识别,是基于人的脸部特征信息进行身份识别的一种生物识别技术。用摄像机或摄像头采集含有人脸的图像或视频流,并自动在图像中检测和跟踪人脸,进而对检测到的人脸进行脸部的一系列相关技术,通常也叫做人像识别、面部识别。人证合一接口,一般是指人脸与身份证识别接口的相结......
  • 升降梯人数统计识别摄像机
    升降梯人数统计识别摄像机是一种结合了图像识别技术和智能算法的设备,旨在监测和统计升降梯内乘客数量,并实时显示在屏幕上。这种摄像机可以有效提高建筑物管理的效率,方便管理人员及时掌握乘客流量情况,从而更好地安排运营和维护工作。升降梯人数统计识别摄像机具有高效的图像识别功能......
  • 卷积神经网络实现手写数字识别
    一、实验介绍手写数字识别是一个典型的图像分类问题,在日常生活中已经被广泛地应用。本实验基于mnist数据集,通过搭建卷积神经网络完成手写数字识别模型的训练,并通过训练集与自制手写数字图片对模型性能进行评估。二、设计过程1.环境搭建安装Python、Pytorch等必要的开发环......
  • 如何本地搭建Whisper语音识别模型
    如何本地搭建Whisper语音识别模型如何本地搭建Whisper语音识别模型1.引言Whisper模型简介本地搭建的意义和应用场景应用场景包括但不限于:2.环境准备系统要求Python环境安装依赖库安装3.安装Whisper模型使用pip安装Whisper依赖工具安装(如FFmpeg)权限和兼容性问题处理......
  • 【目标检测数据集】瓶子分类识别数据集1万张3类VOC+YOLO格式(玻璃瓶金属瓶塑料瓶数据集
     数据集格式:PascalVOC格式+YOLO格式(不包含分割路径的txt文件,仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件)图片数量(jpg文件个数):10106标注数量(xml文件个数):10106标注数量(txt文件个数):10106标注类别数:3标注类别名称:["glass-bottle","metal-bottle","p......
  • 2024年图像处理、机器学习与模式识别国际学术会议(IPMLP 2024)2024 International Conf
    文章目录一、会议详情二、重要信息三、大会介绍四、出席嘉宾五、征稿主题六、咨询一、会议详情二、重要信息大会官网:https://ais.cn/u/vEbMBz提交检索:EICompendex、IEEEXplore、Scopus会议时间:2024.9.13-15日会议地点:中国广州最终截稿时间:2024年9月9日23时59分......
  • 厉害了!字节又放大招,coze智能体可直接发布到抖音,秒变私域转化神器!
    今天在扣子上撸Bot,突然发现coze支持发布到抖音了!!!于是立马写了一个智能客服智能体进行测试。先看看测试效果,可以看到,这个智能客服智能体可以很好的引导用户留下联系方式,一秒化身私域转化神器!那么如何创建一个抖音智能客服呢?一)登录coze官网Coze官网网址:https://www.coze.cn/点击链......
  • 爬虫katana结合指纹识别
    这个Go程序的功能是识别给定URL所使用的网站内容管理系统(CMS)。其主要逻辑如下:1.并发发送HTTP请求:使用sendGetRequest函数发送HTTPGET请求到指定的URL,跳过SSL/TLS证书验证。通过goroutines并发处理多个URL。2.响应处理:extractBodyAndHeader函数从HTTP响应中提取响应体和......
  • 京东中文点选验证码识别方案
     一、验证码介绍这款验证码防御能力还是很强,主要是中文字体特殊,颜色和背景融合度很高,以至于人都很难看清楚。有些文字甚至进行了模糊处理,人都很难识别是上面字。所以给机器识别造成了很大困扰。二、识别代码1、识别参数介绍京东中文点选验证码识别,我们需要两种图片才能完......
  • C#护照查验接口集成示例、护照文字识别、外国人身份认证
    护照查验是对护照有效性、真实性和符合相关出入境要求的确认过程。护照作为跨国旅行的重要身份证明文件,其查验是国际旅行中的一个必要程序。护照查验接口,支持查验出入境管理局签发护照的真伪,接口集成,简单高效便捷。C#护照查验接口集成示例:varclient=newHttpClient()......