基于C#实现12306的动态验证码变成静态验证码的方法
本以为这次12306的动态验证码很厉害,什么刷票软件都不行了,看了以后发现并不是很复杂,估计不出两日刷票软件又会卷土重来,开来要一个验证码很难遏制这些刷票软了。
这次换的动态验证码采用的是GIF格式在客户端输出,至于要拿到这个gif文件然后把动态图的各张图片拼凑起来就能得到完整的静态验证码,接下来就是识别静态验证码的事情了。
比如这张动态验证码
他的静态效果就是
下面是随手写的代码,有点混乱
Image imgGif = Image.FromFile(Application.StartupPath + @"\getPassCodeNew.gif"); FrameDimension ImgFrmDim = new FrameDimension(imgGif.FrameDimensionsList[0]); System.Drawing.Bitmap bp = new Bitmap(imgGif.Size.Width, imgGif.Size.Height); int nFrameCount = imgGif.GetFrameCount(ImgFrmDim); for (int i = 0; i < nFrameCount; i++) { imgGif.SelectActiveFrame(ImgFrmDim, i); System.Drawing.Bitmap nbp = new Bitmap(imgGif); Color dd = nbp.GetPixel(1, 1); if (i == 0) { for (int x = 0; x < nbp.Width; x++) { for (int y = 0; y < nbp.Height; y++) { bp.SetPixel(x, y, dd); } } } for (int x = 0; x < nbp.Width; x++) { for (int y = 0; y < nbp.Height; y++) { Color c = nbp.GetPixel(x, y); if (c == dd) continue; bp.SetPixel(x, y, c); } } } bp.Save(Application.StartupPath + @"\Frame.jpg", ImageFormat.Bmp);
以上代码有点乱,希望大家不要放弃,其实这些代码写的都是精华,代码比较实用,有哪些不明白的地方欢迎大家留言,我会在第一时间和大家取得联系的,谢谢大家一直以来对我们网站的支持。
相关推荐
-
12306验证码破解思路分享
一个12306验证码破解思路, 图片采集 + 概率 //分析: 1. 单次验证码里面有8个图片,类型最多8种,最少不太确定 2. 8个图是规则排列,可以很容易分隔 3. 图片库应该是有限的,可以采集,计算hash入库,这里需要关联相同类型图片 (比如 "杯子","刷子"等) 备注:这里的图片hash并不是md5,有很多算法,自行搜索吧. //下面,我假设图片已经采集好了,分类也完成了,开始进行识别: 1. 选一张验证码,分隔成8个图片,分别计算hash,然后查
-
Python验证码识别的方法
本文实例讲述了Python验证码识别的方法.分享给大家供大家参考.具体实现方法如下: #encoding=utf-8 import Image,ImageEnhance,ImageFilter import sys image_name = "./22.jpeg" #去处 干扰点 im = Image.open(image_name) im = im.filter(ImageFilter.MedianFilter()) enhancer = ImageEnhance.Contrast(
-
使用Python神器对付12306变态验证码
临近春节,我们小编带领大家用Python抢火车票! 首先我们需要splinter 安装: pip install splinter -i http://pypi.douban.com/simple –trusted-host pypi.douban.com 然后还需要一个浏览器的驱动,当然用chrome啦 下载地址: http://chromedriver.storage.googleapis.com/index.html?path=2.20/ 根据下载的自己的电脑系统选择下载包,我的windo
-
python 图片验证码代码分享
复制代码 代码如下: #coding: utf-8 import Image,ImageDraw,ImageFont,os,string,random,ImageFilter def initChars(): """ 允许的字符集合,初始集合为数字.大小写字母 usage: initChars() param: None return: list 返回允许的字符集和 for: picChecker类初始字符集合 todo: Nothing """
-
12306奇葩验证码引发思考之C#实现验证码程序
近日铁路订票网"12306"又出现多道另类考题,竟要订票者在8个图案中"点击图中所有美男子"."请点击下图中所有的非智能眼镜"."请点击下图中所有的博斯普鲁斯海峡",网友吐槽:比高考题还难,到底是什么样子的,先跟大家分享一下几个例子: 哈哈,是有点奇葩的验证码,怪不得有人会说"妈妈我已经找不到回家",这让分秒必争的春运网上抢票者瞬间傻眼,九成网友已经被打败-- 正巧小编最近也在研究验证码,参考了许多网上案例
-
12306动态验证码启发之ASP.NET实现动态GIF验证码(附源码)
12306网站推出"彩色动态验证码机制",新版验证码不但经常出现字符叠压,还不停抖动,不少人大呼"看不清",称"那个验证码,是毕加索的抽象画么!"铁总客服则表示:为了能正常购票只能这样.而多家抢票软件接近"报废",引发不少网友不满的吐槽称"太抽象太艺术了". 以前做项目有时候也会用到验证码,但基本都是静态的,这次也想凑凑12306的热闹.闲言少续,切入正题,先上代码. 实现方法: public void S
-
基于Android在布局中动态添加view的两种方法(总结)
一.说明 添加视图文件的时候有两种方式:1.通过在xml文件定义layout:2.java代码编写 二.前言说明 1.构造xml文件 2.LayoutInflater 提到addview,首先要了解一下LayoutInflater类.这个类最主要的功能就是实现将xml表述的layout转化为View的功能.为了便于理解,我们可以将它与findViewById()作一比较,二者都是实例化某一对象,不同的是findViewById()是找xml布局文件下的具体widget控件实例化,而LayoutI
-
JSP技术实现动态页面到静态页面的方法
本文是介绍了jsp技术实现动态页面到静态页面的方法,分享给大家,具体如下: 对于JSP技术实现动态页面到静态页面的方案,我们从三个步骤来说明: JSP技术实现动态页面到静态页面的方案第一: 为了能深入浅出的理解这个框架的由来,我们首先来了解一下JSP解析器将我们写的JSP代码转换成的JAVA文件的内容. 下面是一个JSP文件test.jsp ﹤%@ page language=java contentType=text/html;charset=GB2312 %﹥ ﹤% out.write(﹤!
-
基于C#实现12306的动态验证码变成静态验证码的方法
本以为这次12306的动态验证码很厉害,什么刷票软件都不行了,看了以后发现并不是很复杂,估计不出两日刷票软件又会卷土重来,开来要一个验证码很难遏制这些刷票软了. 这次换的动态验证码采用的是GIF格式在客户端输出,至于要拿到这个gif文件然后把动态图的各张图片拼凑起来就能得到完整的静态验证码,接下来就是识别静态验证码的事情了. 比如这张动态验证码 他的静态效果就是 下面是随手写的代码,有点混乱 Image imgGif = Image.FromFile(Application.StartupPat
-
基于Bootstrap和JQuery实现动态打开和关闭tab页的实例代码
1. 测试环境 JQuery-3.2.1.min.j Bootstrap-3.3.7-dist win7 1.2. 实践 HTML代码片段 <div class="container-fluid"> <div class="row"> <!--添加左侧菜单栏 --> <div class="col-xs-2 col-sm-2 col-md-2 col-lg-2"> <div class
-
基于Echarts图表在div动态切换时不显示的解决方式
简单粗暴,先上图,大概长这样: 在使用vue时有遇到像上图下拉框change事件切换div,change切完后大概会变成这个样子: 上代码: <div class="test"> <p class="title"> <select v-model="selected" v-on:change="change"> <option v-for="option in options
-
基于nginx实现上游服务器动态自动上下线无需reload的实现方法
网上关于nginx的介绍有很多,这里讲述的是上游服务(如下图的Java1服务)在没有"网关"的情况下,如何通过nginx做到动态上下线. 传统的做法是,手动修改nginx的upstream文件,将Java1的配置注释或者标记为down,然后reload nginx生效.当然可以做成脚本自动化修改,然而对于一个繁忙的nginx来说,贸然reload轻则响应缓慢,重则雪崩丢失流量. 那么怎样做到nginx动态加载upstream配置呢?网上大体有3种方案: 通过Lua脚本结合nginx,也
-
python自动化操作之动态验证码、滑动验证码的降噪和识别
目录 前言 一.动态验证码 二.滑动验证码 三.验证码的降噪 四.验证码的识别 总结 前言 python对动态验证码.滑动验证码的降噪和识别,在各种自动化操作中,我们经常要遇到沿跳过验证码的操作,而对于验证码的降噪和识别,的确困然了很多的人.这里我们就详细讲解一下不同验证码的降噪和识别. 一.动态验证码 动态验证码是服务端生成的,点击一次,就会更换一次,这就会造成很多人在识别的时候,会发现验证码一直过期 这是因为,如果你是把图片下载下来,进行识别的话,其实在下载的这个请求中,其实相当于点击了一次
-
python识别和降噪动态验证码与滑动验证码
目录 一.动态验证码 二.滑动验证码 三.验证码的降噪 四.验证码的识别 〝 古人学问遗无力,少壮功夫老始成 〞 python对动态验证码.滑动验证码的降噪和识别,在各种自动化操作中,我们经常要遇到沿跳过验证码的操作,而对于验证码的降噪和识别,的确困然了很多的人.这里我们就详细讲解一下不同验证码的降噪和识别.如果这篇文章能给你带来一点帮助,希望各位小伙伴们多多支持我们. 一.动态验证码 动态验证码是服务端生成的,点击一次,就会更换一次,这就会造成很多人在识别的时候,会发现验证码一直过期 这是因为
-
基于PyQt5制作一个gif动态图片生成器
这个小工具制作的目的是为了将多张图片组合后生成一张动态的GIF图片.设置界面化的操作,只需要将选中的图片导入最后直接生成动态图片. 导入界面相关的第三方库 from PyQt5.QtWidgets import * from PyQt5.QtGui import * 动态图片处理模块 import imageio 应用操作相关库 import sys import os from datetime import datetime 这是用图片生成器生成的一张GIF图片,大家在生成时尽量选择两张大小
-
基于python使用Pillow做动态图在图中生成二维码以及图像处理
目录 1.什么是Pillow 2.pillow图像处理的简单使用 图片信息显示 修改图片尺寸 裁剪旋转图片 为图片添加水印 生成gif图片 1.什么是Pillow 首先我们需要了解一下PIL(Python Imaging Library),它是Python2中非常强大的图像处理标准库,但只支持到Python2.7.Pillow是在PIL的基础上创建了兼容的版本,支持最新Python 3.x,又加入了许多新特性. 安装: pip install pillow 其中Image是pillow库的一个常
随机推荐
- 详解Webstorm 新建.vue文件支持高亮vue语法和es6语法
- 浅谈angular.js跨域post解决方案
- 在职程序员为啥比不过在野程序员
- iOS通过逆向理解Block的内存模型
- js判断浏览器类型为ie6时不执行
- js创建对象的方式总结
- PHP数组相关函数汇总
- 查看apk签名信息方法
- JavaScript利用Date实现简单的倒计时实例
- asp之字符串函数示例
- 基于jquery实现简单的分页控件
- jQuery EasyUI中DataGird动态生成列的方法
- iis 访问由于凭据无效被拒绝+请求的资源在使用中的解决方法
- Android开发教程之ContentProvider数据存储
- java控制台输出数字金字塔示例分享
- 举例介绍Python中的25个隐藏特性
- vue登录路由验证的实现
- 不使用JavaScript实现菜单的打开和关闭效果demo
- Ubuntu16.04搭建NFS 文件共享服务器的方法
- webpack4.x打包过程详解