正则表达式之判断用户注册信息是否为汉字、字母和数字
2015-08-11 11:44
609 查看
一般在写用户注册模块的时候都在对注册的用户名进行判断,查看一下有没有.!@#$%^&*()等这样的特殊字符,注册信息里一般将这些字符视为非法字符不允许注册。怎么进行判断呢,这里就用到了正则表达式了。
先来解释一下下面几个正则表达式:
String chinese = "^[\\u4E00-\\u9FA5\\uF900-\\uFA2D]+$"; /**这个正则表达式用来判断是否为中文**/
//用来用户注册。匹配由数字、26个英文字母或者下划线组成的字符串
String username = "^\\w+$"; /**此正则表达式判断单词字符是否为:[a-zA-Z_0-9]**/
String all = "^[\\u4E00-\\u9FA5\\uF900-\\uFA2D\\w]{2,10}$"; /**此正则表达式将上面二者结合起来进行判断,中文、大小写字母和数字,{2,10}字符的长度为2-10**/
下面是一个完整的例子程序,经测试运行通过:
[java] view plaincopy
import java.util.regex.Pattern;
public class ReplaceAllTest {
public static void main(String[] args){
String chinese = "^[\\u4E00-\\u9FA5\\uF900-\\uFA2D]+{1}quot;; /**这个正则表达式用来判断是否为中文**/
String username = "^\\w+{1}quot;; /**此正则表达式判断单词字符是否为:[a-zA-Z_0-9]**/
/**此正则表达式将上面二者结合起来进行判断,中文、大小写字母和数字**/
String all = "^[\\u4E00-\\u9FA5\\uF900-\\uFA2D\\w]{2,10}{1}quot;;//{2,10}表示字符的长度是2-10
Pattern pattern = Pattern.compile(all);
boolean tf = pattern.matcher("12345").matches();
// boolean tf = Pattern.matches(all, "刘垲l12厅要右见到");
System.out.println(tf);
// \\u4E00-\\u9FA5\\uF900-\\uFA2D是指汉字的Unicode编码范围
// \w是指单词字符:[a-zA-Z_0-9]
}
}
先来解释一下下面几个正则表达式:
String chinese = "^[\\u4E00-\\u9FA5\\uF900-\\uFA2D]+$"; /**这个正则表达式用来判断是否为中文**/
//用来用户注册。匹配由数字、26个英文字母或者下划线组成的字符串
String username = "^\\w+$"; /**此正则表达式判断单词字符是否为:[a-zA-Z_0-9]**/
String all = "^[\\u4E00-\\u9FA5\\uF900-\\uFA2D\\w]{2,10}$"; /**此正则表达式将上面二者结合起来进行判断,中文、大小写字母和数字,{2,10}字符的长度为2-10**/
下面是一个完整的例子程序,经测试运行通过:
[java] view plaincopy
import java.util.regex.Pattern;
public class ReplaceAllTest {
public static void main(String[] args){
String chinese = "^[\\u4E00-\\u9FA5\\uF900-\\uFA2D]+{1}quot;; /**这个正则表达式用来判断是否为中文**/
String username = "^\\w+{1}quot;; /**此正则表达式判断单词字符是否为:[a-zA-Z_0-9]**/
/**此正则表达式将上面二者结合起来进行判断,中文、大小写字母和数字**/
String all = "^[\\u4E00-\\u9FA5\\uF900-\\uFA2D\\w]{2,10}{1}quot;;//{2,10}表示字符的长度是2-10
Pattern pattern = Pattern.compile(all);
boolean tf = pattern.matcher("12345").matches();
// boolean tf = Pattern.matches(all, "刘垲l12厅要右见到");
System.out.println(tf);
// \\u4E00-\\u9FA5\\uF900-\\uFA2D是指汉字的Unicode编码范围
// \w是指单词字符:[a-zA-Z_0-9]
}
}
相关文章推荐
- S3C6410移植apache和php
- 在Ubuntu中安装twisted
- tomcat结合nginx使用小结
- 浅谈百度竞价访问URL的撰写规则和技巧
- 内部类和外部类之间互相访问
- nyoj106 背包问题
- Python中的列表、元祖、字典
- Parentheses Balance
- 【SpringMVC整合MyBatis】案例驱动-集合类型参数绑定
- 欢迎使用CSDN-markdown编辑器
- 字符测试 =~ 用法
- App Transport Security has blocked a cleartext HTTP (http://) 和Swift 2 中的异常处理
- 小心别让圆角成了你列表的帧数杀手
- github readme 格式
- vector<T>
- Android异步加载学习笔记之一:用AsyncTask加载服务器json数据
- IOS开发:发布APP
- 为什么relativelayout.layoutParams的width为-1
- FeatureLayer,FeatureDataset,FeatureClass,Feature几个概念一点点总结
- Cocos2d-JS 3.3 模态对话框的实现