#import <Foundation/Foundation.h>





typedef enum 

{

    IdentifierTypeKnown = 0,

    IdentifierTypeZipCode,      //1

    IdentifierTypeEmail,        //2

    IdentifierTypePhone,        //3

    IdentifierTypeUnicomPhone,  //4    

    IdentifierTypeQQ,           //5

    IdentifierTypeNumber,       //6

    IdentifierTypeString,       //7

    IdentifierTypeIdentifier,   //8

    IdentifierTypePassort,      //9

    IdentifierTypeCreditNumber, //10

    IdentifierTypeBirthday,     //11 

}IdentifierType;



@interface IdentifierValidator : NSObject

{

}



+ (BOOL) isValid:(IdentifierType) type value:(NSString*) value;



@end

#import "IdentifierValidator.h"

#import "NSString+ITTAdditions.h"



int getIndex (char ch);

BOOL isNumber (char ch);



int getIndex (char ch) {

    if ((ch >= '0'&& ch <= '9')||(ch >= 'a'&& ch <= 'z')||

        (ch >= 'A' && ch <= 'Z')|| ch == '_') {

        return 0;

    }

    if (ch == '@') {

        return 1;

    }

    if (ch == '.') {

        return 2;

    }

    return -1;

}



BOOL isNumber (char ch)

{

    if (!(ch >= '0' && ch <= '9')) {

        return FALSE;

    }

    return TRUE;

}

@implementation IdentifierValidator



+ (BOOL) isValidZipcode:(NSString*)value 

{

    const char *cvalue = [value UTF8String];

    int len = strlen(cvalue);

    if (len != 6) {

        return FALSE;

    }

    for (int i = 0; i < len; i++) 

    {

        if (!(cvalue[i] >= '0' && cvalue[i] <= '9')) 

        {

            return FALSE;

        }

    }

    return TRUE;

}



+ (BOOL) validateEmail:(NSString *)candidate

{

    NSArray *array = [candidate componentsSeparatedByString:@"."];

    if ([array count] >= 4) {

        return FALSE;

    }

    NSString *emailRegex = @"[A-Z0-9a-z._%+-]+@[A-Za-z0-9.-]+\\.[A-Za-z]{2,4}"; 

    NSPredicate *emailTest = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", emailRegex]; 

    return [emailTest evaluateWithObject:candidate];

}



+ (BOOL) isValidEmail:(NSString*)value {

    static int state[5][3] = {

        {1, -1, -1},

        {1,  2, -1},

        {3, -1, -1},

        {3, -1, 4},

        {4, -1, -1}

    };

    BOOL valid = TRUE;

    const char *cvalue = [value UTF8String];

    int currentState = 0;

    int len = strlen(cvalue);

    int index;

    for (int i = 0; i < len && valid; i++) {

        index = getIndex(cvalue[i]);

        if (index < 0) {

            valid = FALSE;

        }

        else {

            currentState = state[currentState][index];

            if (currentState < 0) {

                valid = FALSE;

            }

        }

    }

    //end state is invalid

    if (currentState != 4) {

        valid = FALSE;

    }

    return valid;

}



+ (BOOL) isValidNumber:(NSString*)value{

    const char *cvalue = [value UTF8String];

    int len = strlen(cvalue);

    for (int i = 0; i < len; i++) {

        if(!isNumber(cvalue[i])){

            return FALSE;

        }

    }

    return TRUE;

}



+ (BOOL) isValidPhone:(NSString*)value {

    const char *cvalue = [value UTF8String];

    int len = strlen(cvalue);

    if (len != 11) {

        return FALSE;

    }

    if (![IdentifierValidator isValidNumber:value]) 

    {

        return FALSE;

    }

    NSString *preString = [[NSString stringWithFormat:@"%@",value] substringToIndex:2];    

    if ([preString isEqualToString:@"13"] ||

        [preString isEqualToString: @"15"] || 

        [preString isEqualToString: @"18"]) 

    {

        return TRUE;

    }

    else

    {

        return FALSE;

    }

    return TRUE;

}

+ (BOOL) isValidString:(NSString*)value 

{

    return value && [value length];

}

const int factor[] = { 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2 };//加权因子 

const int checktable[] = { 1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2 };//校验值相应表

+ (BOOL) isValidIdentifier:(NSString*)value 

{

    const int LENGTH = 18;    

    const char *str = [[value lowercaseString] UTF8String];

    NSInteger i;    

    NSInteger length = strlen(str);

    BOOL result = TRUE;    

    /*

     * identifier length is invalid

     */

    if (15 != length && LENGTH != length)

    {

        result = FALSE;

    }

    else

    {

        for (i = 1; i < length - 1; i++)

        {

            if(!(str[i] >= '0' && str[i] <= '9')) 

            {

                result = FALSE;

                break;

            }

        }

        if (result) 

        {

            if(LENGTH == length)

            {

                if (!((str[i] >= '0' && str[i] <= '9')||str[i] == 'X'||str[i] == 'x'))

                {

                    result = FALSE;

                }

            }

        }

        /*

         * check sum for second generation identifier

         */

        if (result && length == LENGTH) 

        {

            int i;

            int *ids = malloc(sizeof(int)*LENGTH);

            for (i = 0; i < LENGTH; i++) 

            {

                ids[i] = str[i] - 48;             

            }

            int checksum = 0; 

            for (i = 0; i < LENGTH - 1; i ++ )

            {

                checksum += ids[i] * factor[i];

            }

            if (ids[17] == checktable[checksum%11]|| 

                (str[17] == 'x' && checktable[checksum % 11] == 10))  

            {

                result  = TRUE;

            }

            else 

            {

                result  = FALSE;            

            }

            free(ids);

            ids = NULL;

        }        

    }

    return result;

}

+ (BOOL) isValidPassport:(NSString*)value 

{

    const char *str = [value UTF8String];

    char first = str[0];

    NSInteger length = strlen(str);

    if (!(first == 'P' || first == 'G')) 

    {

        return FALSE;

    }

    if (first == 'P')

    {

        if (length != 8) 

        {

            return FALSE;

        }

    }

    if (first == 'G') 

    {

        if (length != 9) 

        {

            return FALSE;

        }

    }

    BOOL result = TRUE;

    for (NSInteger i = 1; i < length; i++) 

    {

        if (!(str[i] >= '0' && str[i] <= '9')) 

        {

            result = FALSE;

            break;

        }

    }        

    return result;

}

/*

 * 经常使用信用卡卡号规则

 * Issuer Identifier  Card Number                            Length

 * Diner's Club       300xxx-305xxx, 3095xx, 36xxxx, 38xxxx  14

 * American Express   34xxxx, 37xxxx                         15

 * VISA               4xxxxx                                 13, 16

 * MasterCard         51xxxx-55xxxx                          16

 * JCB                3528xx-358xxx                          16

 * Discover           6011xx                                 16

 * 银联                622126-622925                          16 

 *

 * 信用卡号验证基本算法: 

 * 偶数位卡号奇数位上数字*2。奇数位卡号偶数位上数字*2。

* 大于10的位数减9。

* 所有数字加起来。

* 结果不是10的倍数的卡号非法。

* prefrences link:http://www.truevue.org/licai/credit-card-no

 *

 */

+ (BOOL) isValidCreditNumber:(NSString*)value

{

    BOOL result = TRUE;

    NSInteger length = [value length];    

    if (length >= 13) 

    {

        result = [IdentifierValidator isValidNumber:value];    

        if (result) 

        {

            NSInteger twoDigitBeginValue = [[value substringWithRange:NSMakeRange(0, 2)] integerValue];

            NSInteger threeDigitBeginValue = [[value substringWithRange:NSMakeRange(0, 3)] integerValue];        

            NSInteger fourDigitBeginValue = [[value substringWithRange:NSMakeRange(0, 4)] integerValue];        

            //Diner's Club

            if (((threeDigitBeginValue >= 300 && threeDigitBeginValue <= 305)||

                 fourDigitBeginValue == 3095||twoDigitBeginValue==36||twoDigitBeginValue==38) && (14 != length)) 

            {

                result = FALSE;

            }

            //VISA

            else if([value isStartWithString:@"4"] && !(13 == length||16 == length))

            {

                result = FALSE;

            }

            //MasterCard

            else if((twoDigitBeginValue >= 51||twoDigitBeginValue <= 55) && (16 != length))

            {

                result = FALSE;

            }        

            //American Express

            else if(([value isStartWithString:@"34"]||[value isStartWithString:@"37"]) && (15 != length))

            {

                result = FALSE;

            }  

            //Discover

            else if([value isStartWithString:@"6011"] && (16 != length))

            {

                result = FALSE;

            }          

            else 

            {

                NSInteger begin = [[value substringWithRange:NSMakeRange(0, 6)] integerValue];

                //CUP

                if ((begin >= 622126 && begin <= 622925) && (16 != length))

                {

                    result = FALSE;                

                }

                //other

                else 

                {

                    result = TRUE;

                }

            }

        }

        if (result) 

        {

            NSInteger digitValue;

            NSInteger checkSum = 0;

            NSInteger index = 0; 

            NSInteger leftIndex;

            //even length, odd index 

            if (0 == length%2) 

            {

                index = 0;

                leftIndex = 1;

            }

            //odd length, even index         

            else 

            {

                index = 1;  

                leftIndex = 0;

            }

            while (index < length) 

            {

                digitValue = [[value substringWithRange:NSMakeRange(index, 1)] integerValue];            

                digitValue = digitValue*2;

                if (digitValue >= 10) 

                {

                    checkSum += digitValue/10 + digitValue%10;

                }

                else

                {

                    checkSum += digitValue;

                }

                digitValue = [[value substringWithRange:NSMakeRange(leftIndex, 1)] integerValue];                        

                checkSum += digitValue;    

                index += 2;

                leftIndex += 2;            

            }

            result = (0 == checkSum%10) ? TRUE:FALSE;

        }        

    }

    else

    {

        result = FALSE;

    }

    return result;

}

+ (BOOL) isValidBirthday:(NSString*)birthday

{

    BOOL result = FALSE;

    if (birthday && 8 == [birthday length]) 

    {

        NSDateFormatter *formatter = [[NSDateFormatter alloc] init];

        [formatter setDateFormat:@"yyyyMMdd"];

        NSDate *date = [formatter dateFromString:birthday];

        [formatter release];

        if (date)

        {

            result = TRUE;

        }

    }

    return result;

}

+ (BOOL) isChinaUnicomPhoneNumber:(NSString*) phonenumber

{

    /**

     * 手机号码

     * 移动:134[0-8],135,136,137,138,139,150,151,157,158,159,182,187,188

     * 联通:130,131,132,152,155,156,185,186

     * 电信:133,1349,153,180,189

     */

//    NSString * MOBILE = @"^1(3[0-9]|5[0-35-9]|8[025-9])\\d{8}$";

    /**

     10         * 中国移动:China Mobile

     11         * 134[0-8],135,136,137,138,139,150,151,157,158,159,182,187,188

     12         */

//    NSString * CM = @"^1(34[0-8]|(3[5-9]|5[017-9]|8[278])\\d)\\d{7}$";

//    /**

//     15         * 中国联通:China Unicom

//     16         * 130,131,132,152,155,156,185,186

//     17         */

    NSString * CU = @"^1(3[0-2]|5[256]|8[56])\\d{8}$";

//    /**

//     20         * 中国电信:China Telecom

//     21         * 133,1349,153,180,189

//     22         */

//    NSString * CT = @"^1((33|53|8[09])[0-9]|349)\\d{7}$";

//    /**

//     25         * 大陆地区固话及小灵通

//     26         * 区号:010,020,021,022,023,024,025,027,028,029

//     27         * 号码:七位或八位

//     28         */

//    NSString * PHS = @"^0(10|2[0-5789]|\\d{3})\\d{7,8}$";

//    NSString * PHS1 = @"^0(10|2[0-5789]|\\d{3}-)\\d{7,8}$";

    

//    NSPredicate *regextestmobile = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", MOBILE];

//    NSPredicate *regextestcm = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", CM];

    NSPredicate *regextestcu = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", CU];

//    NSPredicate *regextestct = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", CT];

//    NSPredicate *regextestphs = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", PHS];

//    NSPredicate *regextestphs1 = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", PHS1];

    

    if (//([regextestmobile evaluateWithObject:phonenumber] == YES)|| 

//        ([regextestcm evaluateWithObject:phonenumber] == YES)||

//        ([regextestct evaluateWithObject:phonenumber] == YES)||

          ([regextestcu evaluateWithObject:phonenumber] == YES)

//        || ([regextestphs evaluateWithObject:phonenumber] == YES)

//        || ([regextestphs1 evaluateWithObject:phonenumber] == YES)

        )

    {

        return YES;

    }

    else 

    {

        return NO;

    }

}

//+ (BOOL) isChinaUnicomPhoneNumber:(NSString*) phoneNumber

//{

//    BOOL unicom = TRUE;

//    NSString *mobileNumFormat13 = @"[1]{1}[3]{1}[4-9]{1}[0-9]{8}";

//    NSString *mobileNumFormat14 = @"[1]{1}[4]{1}[7]{1}[0-9]{8}";

//    NSString *mobileNumFormat15 = @"[1]{1}[5]{1}[012789]{1}[0-9]{8}";

//    NSString *mobileNumFormat18 = @"[1]{1}[8]{1}[2378]{1}[0-9]{8}";

//    NSPredicate *predicate13 = [NSPredicate predicateWithFormat:@"SELF MATCHES %@",mobileNumFormat13];

//    NSPredicate *predicate14 = [NSPredicate predicateWithFormat:@"SELF MATCHES %@",mobileNumFormat14];

//    NSPredicate *predicate15 = [NSPredicate predicateWithFormat:@"SELF MATCHES %@",mobileNumFormat15];

//    NSPredicate *predicate18 = [NSPredicate predicateWithFormat:@"SELF MATCHES %@",mobileNumFormat18];

//    if ([predicate13 evaluateWithObject:phoneNumber] ||

//        [predicate14 evaluateWithObject:phoneNumber] ||

//        [predicate15 evaluateWithObject:phoneNumber] ||

//        [predicate18 evaluateWithObject:phoneNumber]) 

//    {

//        unicom = FALSE;

//    }

//    return unicom;

//}

+ (BOOL) isValid:(IdentifierType) type value:(NSString*) value 

{

    if (!value ||[[value stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceCharacterSet]] isEqualToString:@""]) {        

        return FALSE;

    }

    BOOL result = TRUE;

    switch (type) 

    {

        case IdentifierTypeZipCode:

            result = [IdentifierValidator isValidZipcode:value];

            break;

        case IdentifierTypeEmail:

//            result = [IdentifierValidator isValidEmail:value];

            result = [IdentifierValidator validateEmail:value];

            break;

        case IdentifierTypePhone:

            result = [IdentifierValidator isValidPhone:value];

            break;

        case IdentifierTypeUnicomPhone:

            result = [IdentifierValidator isChinaUnicomPhoneNumber:value];

            break;

        case IdentifierTypeQQ:

            result = [IdentifierValidator isValidNumber:value];

            break;

        case IdentifierTypeNumber:

            result = [IdentifierValidator isValidNumber:value];

            break;           

        case IdentifierTypeString:

            result = [IdentifierValidator isValidString:value];

            break;

        case IdentifierTypeIdentifier:

            result = [IdentifierValidator isValidIdentifier:value];            

            break;

        case IdentifierTypePassort:

            result = [IdentifierValidator isValidPassport:value];            

            break;            

        case IdentifierTypeCreditNumber:

            result = [IdentifierValidator isValidCreditNumber:value];

            break;

        case IdentifierTypeBirthday:

            result = [IdentifierValidator isValidBirthday:value];            

            break;

        default:

            break;

    }

    return result;

}

- (void) dealloc 

{

    [super dealloc];

}

@end

ios 推断是qq,银行卡,手机号等等公用的方法。的更多相关文章

  1. 微信、QQ和手机号之间不得不说的故事!

    发文字,发图片,发心情,视频聊天,查看附近的人,微信能干的事情QQ都可以,那么它们有什么区别,我QQ用得好好的为什么要我联系人都导到微信去?我们很早就有了QQ,但是在QQ时代,我们虽然用QQ发消息聊天 ...

  2. iOS打开手机QQ与指定用户聊天界面

    开发中遇到一个联系客服qq的需求,找到这么一个实现方法,先记录下来.大概的原理就是,iOS启动第三方应用是采用schema模式的,这有点像url,打开不同的界面使用不同的地址.但这个url怎么得来的还 ...

  3. php通过gbk编码判断 含有连续数字 可用于判断QQ号,手机号等。

    有可能有些输入,不希望让用户的评论或者私信中含有类似于QQ号,手机号的文本,比如交友网站.还有些恶意SEO通过,构造恶意检索词,检索词中包含QQ,手机号等,让百度爬取到,增加展现.也需要将这些检索词屏 ...

  4. Android仿QQ ios dialog,仿QQ退出向上菜单

    Android仿QQ ios dialog,仿QQ退出向上菜单 EasyDialog两种模式 仿QQ退出向上菜单,自己定义向上菜单              github地址:https://gith ...

  5. iOS之处理不等高TableViewCell的几种方法

    课题一:如何计算Cell高度 方案一:直接法(面向对象) 直接法,就是把数据布局到Cell上,然后拿到Cell最底部控件的MaxY值. 第一步:创建Cell并正确设置约束,使文字区域高度能够根据文字内 ...

  6. IOS中获取各种文件的路径介绍及方法

    IOS中获取各种文件的目录路径的方法 技术交流新QQ群:414971585 iphone沙箱模型的有四个文件夹,分别是什么,永久数据存储一般放在什么位置,得到模拟器的路径的简单方式是什么. docum ...

  7. iOS阶段学习第32天笔记(页面传值方法介绍)

    iOS学习(UI)知识点整理 一.界面传值方法 1.方法一  Block传值  通过SubView视图的Block向View视图传值改变View视图的背景色 实例代码: 1)SubViewContro ...

  8. 让ecshop用户名、手机号、email登陆方法

    让ecshop用户名.手机号.email登陆方法, 仅适用于没有做过任何平台整合的ECSHOP网站   修改文件:   1.includes/modules/integrates/ecshop.php ...

  9. 关于iOS去除数组中重复数据的几种方法

    关于iOS去除数组中重复数据的几种方法   在工作工程中我们不必要会遇到,在数组中有重复数据的时候,如何去除重复的数据呢? 第一种:利用NSDictionary的AllKeys(AllValues)方 ...

随机推荐

  1. 转载——利用C#自带组件强壮程序日志

    利用C#自带组件强壮程序日志   在项目正式上线后,如果出现错误,异常,崩溃等情况 我们往往第一想到的事就是查看日志 所以日志对于一个系统的维护是非常重要的 声明 正文中的代码只是一个栗子,一个非常简 ...

  2. vue ---- 实现手机端(左滑 删除。右划 正常)

    touchstart: // 手指放到屏幕上的时候触发 touchmove: // 手指在屏幕上移动的时候触发 touchend: // 手指从屏幕上拿起的时候触发 touchcancel: // 系 ...

  3. IIS文件上传大小修改配置说明

    原因:Web 服务器上的请求筛选被配置为拒绝该请求,因为内容长度超过配置的值(IIS 7 默认文件上传大小时30M). 解决:IIS7更改asp.net文件上传大小限制 步骤如下: 1.    修改I ...

  4. Qwt库的一个使用注意事项

    作者:朱金灿 来源:http://blog.csdn.net/clever101 一般debug版本的程序链接release版本的库是没有问题的.今天使用debug版本程序链接release版本的qw ...

  5. Kinect 开发 —— 进阶指引(上)

    本文将会介绍一些第三方类库如何来帮助处理Kinect传感器提供的数据.使用不同的技术进行Kinect开发,可以发掘出Kinect应用的强大功能.另一方面如果不使用这些为了特定处理目的而开发的一些类库, ...

  6. BOOT项目依赖另外一个模块的包,开发的时候都正常,执行clean package打包成jar时却提示依赖的模块包不存在。

    我在service1模块里依赖了common模块,开发的时候包都能正常引用到,启动也能正常测试访问,可是奇怪的是,当我要打包成jar包时,就提示service1里依赖common的包都不存在,之前从没 ...

  7. centos的dns配置总结

    找的一篇好的存根 DNS正反向解析 DNS(Domain Name Service)域名服务.就是域名解析服务器.所谓名称解析的过程就是某个应用程序基于某个搜索键在指定的数据库中查询.而后查询到某些对 ...

  8. CMDB学习之一

    CMDB - 配置管理数据库 资产管理 自动化相关的平台(基础 CMDB): 1. 发布系统 2. 监控 3. 配管系统.装机 4. 堡垒机 CMDB的目的: 1. 替代EXCEL资产管理 —— 资产 ...

  9. django模型系统二

    常用查询及表关系的实现 1.常用查询 每一个django模型类,都有一个默认的管理器 objects QuerySet表示数据库中对象的列表,它可以有0到多个过滤器.过滤器通过给定参数,缩小查询范围. ...

  10. Python Web框架要点

    1. Web应用程序处理流程 前端客户端(浏览器.APP.ajax.爬虫程序)>>>--http的请求与响应--<<<服务器程序(Gunicorn.uwsig)&l ...