Android 用户验证(超全正则表达)

验证中英文

public static boolean isZhongYing(String str){

      String zhongyin="^[A-Za-z\u4e00-\u9fa5]+$";//中英文

        Pattern p = Pattern.compile(zhongyin);

        return p.matcher(str).matches();

    }

验证字母数字

public static boolean isShuZiYing(String str){

        String yinshuzi="^[A-Za-z0-9_@]+$";//字母数字_ @

        Pattern p = Pattern.compile(yinshuzi);

        return p.matcher(str).matches();

    }

验证各种

 /**
     * 中国电信号码格式验证 手机段: 133,153,180,181,189,177,1700,173
     * **/
    private static final String CHINA_TELECOM_PATTERN = "(^1(33|53|7[37]|8[019])\\d{8}$)|(^1700\\d{7}$)";

    /**
     * 中国联通号码格式验证 手机段:130,131,132,155,156,185,186,145,176,1707,1708,1709
     * **/
    private static final String CHINA_UNICOM_PATTERN = "(^1(3[0-2]|4[5]|5[56]|7[6]|8[56])\\d{8}$)|(^170[7-9]\\d{7}$)";

    /**
     * 中国移动号码格式验证
     * 手机段:134,135,136,137,138,139,150,151,152,157,158,159,182,183,184
     * ,187,188,147,178,1705
     *
     **/
    private static final String CHINA_MOBILE_PATTERN = "(^1(3[4-9]|4[7]|5[0-27-9]|7[8]|8[2-478])\\d{8}$)|(^1705\\d{7}$)";
    /**
     * 仅手机号格式校验
     */
    private static final String PHONE_PATTERN=new StringBuilder(300).append(CHINA_MOBILE_PATTERN)
            .append("|")
            .append(CHINA_TELECOM_PATTERN)
            .append("|")
            .append(CHINA_UNICOM_PATTERN)
            .toString();

    /**
     * 仅手机号码校验
     * @param input
     * @return
     */
    public static boolean isPhone(String input){
        return match(PHONE_PATTERN, input);
    }

    /**
     * 匹配函数
     * @param regex
     * @param input
     * @return
     */
    private static boolean match(String regex, String input) {
        return Pattern.matches(regex, input);
    }
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
正则表达式语法非常丰富,可以实现很多复杂的匹配和处理操作。虽然无法一一列举所有的语法,但我可以为您提供一些常用的语法元字符和模式: 1. 字符匹配: - 普通字符: 匹配与其自身相等的字符。 - . : 匹配除换行符外的任意字符。 - \d : 匹配任意数字字符。 - \w : 匹配任意字母、数字或下划线字符。 - \s : 匹配任意空白字符。 - [] : 匹配括号内的任意一个字符。 - [^] : 匹配除了括号内的字符以外的任意字符。 2. 重复匹配: - * : 匹配前面的字符0次或多次。 - + : 匹配前面的字符1次或多次。 - ? : 匹配前面的字符0次或1次。 - {n} : 匹配前面的字符恰好n次。 - {n,} : 匹配前面的字符至少n次。 - {n,m} : 匹配前面的字符至少n次但不超过m次。 3. 边界匹配: - ^ : 匹配字符串的开头。 - $ : 匹配字符串的结尾。 - \b : 匹配单词的边界。 4. 分组和捕获: - () : 将括号内的内容视为一个组。 - | : 匹配左右两边任意一个表达式。 - \1, \2, ... : 引用前面的分组,\1表示第一个分组,\2表示第二个分组,依此类推。 5. 其他元字符: - \ : 转义特殊字符。 - ^ : 在括号内表示取反。 - ? : 非贪婪匹配,尽可能少匹配字符。 - i : 忽略大小写匹配。 虽然这只是部分正则表达式语法的概述,但它们已经足够帮助您进行一些简单的正则匹配操作了。请根据您的需要选择适当的语法元字符和模式来编写您的正则表达式。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值