今天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地址进行了判断。可能最后的那种正则表达式还有优化的方法,请大家给予批评与建议。
github主页:https://github.com/chenyufeng1991 。欢迎大家访问!