今天Boss给了一个小任务,要求给定一个字符串,判断该字符串是否是MAC地址,并用Java和正则表达式实现。于是我顺便百度了下MAC地址,并在cmd下使用getmac获取本机的MAC地址,了解了一点后,就用Java实现了。为了方便测试与输入输出,选择使用Android作为UI交互。反正都是用Java,对于这个问题,一个Java项目和Android区别不大。
首先看一个MAC地址:48-5D-60-61-3D-C5。其中由6个字节(十六进制)组成,简单理解为数字、大小写字母(a-fA-F)、短横线-组成。废话不说,先写MAC的正则表达式,我总共写了3个正则表达式,是不断优化的结果。
正则表达式:
(1)"[A-Fa-f0-9][A-Fa-f0-9]-[A-Fa-f0-9][A-Fa-f0-9]-[A-Fa-f0-9][A-Fa-f0-9]-[A-Fa-f0-9][A-Fa-f0-9]-[A-Fa-f0-9][A-Fa-f0-9]-[A-Fa-f0-9][A-Fa-f0-9]"
这个表达式虽然看起来长,但是是逻辑最简单的,最容易理解的,也是完全正确的。A-F a-f 0-9都表示其中的某一个,中间是“或”的关系。短横线-可以直接进行匹配。
(2)"[A-Fa-f0-9]{2}-[A-Fa-f0-9]{2}-[A-Fa-f0-9]{2}-[A-Fa-f0-9]{2}-[A-Fa-f0-9]{2}-[A-Fa-f0-9]{2}"
进行优化后,长度剪短了一半。{2}就是把前面的部分循环2次。在第一种方法的基础上,这也是容易理解的。
(3)"([A-Fa-f0-9]{2}-){5}[A-Fa-f0-9]{2}"
在(2)的基础上继续进行优化。把“[A-Fa-f0-9]{2}-“作为一个单元进行提取。{5}并循环5次,因为面·前面5个都是重复的,有很大压缩的空间。
代码编写较为简单,在Android上进行可视化编写:
public class MainActivity extends Activity {
private EditText isMAC;
private Button startMAC;
private TextView result;
private static String judgeMacAddress;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
isMAC = (EditText) findViewById(R.id.id_edit);
startMAC = (Button) findViewById(R.id.id_btn);
result = (TextView) findViewById(R.id.id_text);
startMAC.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
judgeMacAddress = isMAC.getText().toString();
boolean isMAC = stringIsMac(judgeMacAddress);
if (isMAC) {
result.setText("这是MAC地址");
} else {
result.setText("这不是MAC地址");
}
}
});
}
private boolean stringIsMac(String val) {
String trueMacAddress = "([A-Fa-f0-9]{2}-){5}[A-Fa-f0-9]{2}";
// 这是真正的MAV地址;正则表达式;
if (val.matches(trueMacAddress)) {
return true;
} else {
return false;
}
}
}
(1)(2)(3)最后的实现效果如下:
.
至此,已经对MAC地址进行了判断。可能最后的那种正则表达式还有优化的方法,请大家给予批评与建议。