全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

iOS开发实现随机图片验证码封装

在 iOS 开发中,为了防止短信验证码的恶意获取,注册时需要图片验证,比如某共享单车 APP 在注册时就用了图片验证码,如下图:

图片验证码封装思路:

第一眼看到图片验证码,可能会觉得图片验证码是由 UIImage 实现的,但事实上明显不是,这里简单说下图片验证码封装思路。

  1. 首先要有一个数组,里面包含 1-9、a-z 这些字符
  2. 在 UIView 上显示这些字符
  3. 同时在 UIView 上绘制干扰线

效果图

图片验证码效果图

用法

  _testView = [[NNValidationView alloc] initWithFrame:CGRectMake((self.view.frame.size.width - 100) / 2, 200, 100, 40) andCharCount:4 andLineCount:4];
  [self.view addSubview:_testView];

以上两行代码便可以实现图片验证码,其中 charCount 和 lineCount 分别指显示的字符串数量以及干扰线的数量。

另外我们还需要知道图片验证码上的字符串,可以用下边这个 block 获取:

 __weak typeof(self) weakSelf = self;
  /// 返回验证码数字
  _testView.changeValidationCodeBlock = ^(void){
    NSLog(@"验证码被点击了:%@", weakSelf.testView.charString);
  };

打印效果如下

获取验证码数字

核心代码

#pragma mark - 绘制界面
- (void)drawRect:(CGRect)rect {
  [super drawRect:rect];
  self.backgroundColor = NNRandomColor;
  CGFloat rectWidth = rect.size.width;
  CGFloat rectHeight = rect.size.height;
  CGFloat pointX, pointY;
  
  NSString *text = [NSString stringWithFormat:@"%@",self.charString];
  NSInteger charWidth = rectWidth / text.length - 15;
  NSInteger charHeight = rectHeight - 25;
  
  // 依次绘制文字
  for (NSInteger i = 0; i < text.length; i++) {
    // 文字X坐标
    pointX = arc4random() % charWidth + rectWidth / text.length * i;
    // 文字Y坐标
    pointY = arc4random() % charHeight;
    unichar charC = [text characterAtIndex:i];
    NSString *textC = [NSString stringWithFormat:@"%C", charC];

    [textC drawAtPoint:CGPointMake(pointX, pointY) withAttributes:@{NSFontAttributeName:[UIFont systemFontOfSize:arc4random() % 10 + 15]}];
  }
  
  // 获取上下文
  CGContextRef context = UIGraphicsGetCurrentContext();
  // 设置线宽
  CGContextSetLineWidth(context, 1.0);
  
  // 依次绘制直线
  for(NSInteger i = 0; i < self.lineCount; i++) {
    // 设置线的颜色
    CGContextSetStrokeColorWithColor(context, NNRandomColor.CGColor);
    // 设置线的起点
    pointX = arc4random() % (NSInteger)rectWidth;
    pointY = arc4random() % (NSInteger)rectHeight;
    CGContextMoveToPoint(context, pointX, pointY);
    // 设置线的终点
    pointX = arc4random() % (NSInteger)rectWidth;
    pointY = arc4random() % (NSInteger)rectHeight;
    CGContextAddLineToPoint(context, pointX, pointY);
    // 绘画路径
    CGContextStrokePath(context);
  }
}

代码中写了注释,因此这里不再详细解释,需要看全部代码的童鞋可以点击下边的链接,有疑问或有建议的话欢迎讨论。

demo 地址:NNValidationView

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# iOS随机图片验证码  # iOS  # 图片验证码  # iOS 生成图片验证码绘制实例代码  # iOS 生成图片验证码(实用功能)  # 利用iOS绘制图片生成随机验证码示例代码  # IOS实现验证码倒计时功能(一)  # iOS获取短信验证码倒计时的两种实现方法  # iOS本地动态生成验证码的方法  # IOS实现验证码倒计时功能(二)  # iOS生成图片数字字母验证效果  # 验证码  # 是由  # 要有  # 可以用  # 用了  # 便可  # 要知道  # 写了  # 时就  # 还需  # 第一眼  # 为了防止  # 大家多多  # 两行  # 如下图  # 时需  # 童鞋  # 但事实上  # 有疑问  # view 


相关文章: 西安大型网站制作公司,西安招聘网站最好的是哪个?  免费公司网站制作软件,如何申请免费主页空间做自己的网站?  C++中的Pimpl idiom是什么,有什么好处?(隐藏实现)  建站主机选择指南:服务器配置与SEO优化实战技巧  香港网站服务器数量如何影响SEO优化效果?  建站之星图片链接生成指南:自助建站与智能设计教程  公司网站制作需要多少钱,找人做公司网站需要多少钱?  如何在云主机上快速搭建多站点网站?  如何选择高效稳定的ISP建站解决方案?  电商平台网站制作流程,电商网站如何制作?  如何通过服务器快速搭建网站?完整步骤解析  外贸公司网站制作哪家好,maersk船公司官网?  建站之星安装后界面空白如何解决?  建站之星如何防范黑客攻击与数据泄露?  香港服务器WordPress建站指南:SEO优化与高效部署策略  制作旅游网站html,怎样注册旅游网站?  内网网站制作软件,内网的网站如何发布到外网?  如何快速搭建安全的FTP站点?  我的世界制作壁纸网站下载,手机怎么换我的世界壁纸?  如何快速搭建个人网站并优化SEO?  网站制作网站,深圳做网站哪家比较好?  北京网站制作费用多少,建立一个公司网站的费用.有哪些部分,分别要多少钱?  网站制作员失业,怎样查看自己网站的注册者?  如何制作一个表白网站视频,关于勇敢表白的小标题?  网站海报制作教学视频教程,有什么免费的高清可商用图片网站,用于海报设计?  建站之星如何助力网站排名飙升?揭秘高效技巧  网站制作说明怎么写,简述网页设计的流程并说明原因?  测试制作网站有哪些,测试性取向的权威测试或者网站?  如何选择适合PHP云建站的开源框架?  如何规划企业建站流程的关键步骤?  小米网站链接制作教程,请问miui新增网页链接调用服务有什么用啊?  如何用低价快速搭建高质量网站?  韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南  c++怎么使用类型萃取type_traits_c++ 模板元编程类型判断【方法】  已有域名和空间,如何快速搭建网站?  如何用免费手机建站系统零基础打造专业网站?  如何选择高效响应式自助建站源码系统?  网站网页制作电话怎么打,怎样安装和使用钉钉软件免费打电话?  如何在西部数码注册域名并快速搭建网站?  做企业网站制作流程,企业网站制作基本流程有哪些?  seo网站制作优化,网站SEO优化步骤有哪些?  宝塔新建站点为何无法访问?如何排查?  如何制作网站标识牌,动态网站如何制作(教程)?  浅谈Javascript中的Label语句  海南网站制作公司有哪些,海口网是哪家的?  大连网站设计制作招聘信息,大连投诉网站有哪些?  c# 在ASP.NET Core中管理和取消后台任务  宿州网站制作公司兴策,安徽省低保查询网站?  网站专业制作公司,网站编辑是做什么的?好做吗?工作前景如何?  如何在香港免费服务器上快速搭建网站? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。