本文純乾貨,直接拿走使用,不用付費。在業務開發中,手機號碼驗證是我們常常需要面對的問題,目前市場上各種各樣的手機號碼驗證方式,比如正則表達式等等,本文結合實際業務場景,在業務級別對手機號碼進行嚴格驗證;同時增加可配置方式,方便業務擴展,代碼非常簡單,擴展非常靈活。 ...
前言
本文純乾貨,直接拿走使用,不用付費。在業務開發中,手機號碼驗證是我們常常需要面對的問題,目前市場上各種各樣的手機號碼驗證方式,比如正則表達式等等,本文結合實際業務場景,在業務級別對手機號碼進行嚴格驗證;同時增加可配置方式,方便業務擴展,代碼非常簡單,擴展非常靈活。
1. 目前手機號段有哪些
- 1.1 目前國內的手機號段主要集中在三大運營商手上,還有一些內部號段和虛擬號段
"中國電信": "133,153,189,180,181,177,173,199,174,141",
"中國移動": "139,138,137,136,135,134,159,158,157,150,151,152,147,188,187,182,183,184,178,198",
"中國聯通": "130,131,132,146,156,155,166,186,185,145,175,176",
"虛擬運營商": "170,171",
"內部號碼": "123"
2. 建立一個測試項目 Ron.PhoneTest
- 2.1 將上面的號段加入配置文件 appsettings.json 中
{
"Logging": {
"LogLevel": {
"Default": "Warning"
}
},
"AllowedHosts": "*",
"phone-segment": {
"中國電信": "133,153,189,180,181,177,173,199,174,141",
"中國移動": "139,138,137,136,135,134,159,158,157,150,151,152,147,188,187,182,183,184,178,198",
"中國聯通": "130,131,132,146,156,155,166,186,185,145,175,176",
"虛擬運營商": "170,171",
"內部號碼": "123"
}
}
3. 建立一個檢查類,負責初始化號段庫和校驗的工作
public class PhoneValidator
{
private static readonly Regex checktor = new Regex(@"^1\d{10}$");
public IDictionary segment = null;
public PhoneValidator(IDictionary segment)
{
this.segment = segment;
}
public bool IsPhone(ref string tel)
{
if (string.IsNullOrEmpty(tel))
{
return false;
}
tel = tel.Replace("+86-", "").Replace("+86", "").Replace("86-", "").Replace("-", "");
if (!checktor.IsMatch(tel))
{
return false;
}
string s = tel.Substring(0, 3);
if (segment.Count > 0 && !segment.Contains(s))
{
return false;
}
return true;
}
}
4. 通過 Startup.cs 實現讀取配置和註入,以便系統使用
public void ConfigureServices(IServiceCollection services)
{
services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_1);
CreatePhoneValidator(services);
}
private void CreatePhoneValidator(IServiceCollection services)
{
Hashtable segment = new Hashtable();
var coll = Configuration.GetSection("phone-segment").GetChildren();
foreach (var prefix in coll)
{
if (string.IsNullOrEmpty(prefix.Value))
continue;
foreach (var s in prefix.Value.Split(','))
segment[s] = s;
}
var pv = new PhoneValidator(segment);
services.AddSingleton<PhoneValidator>(pv);
}
- 以上代碼通過讀取配置文件節點 phone-segment 並初始化 PhoneValidator 類,最後註入到 IServiceCollection 中,完成了初始化的工作
5. 在控制器中使用 PhoneValidator 進行驗證
- 5.1 示例代碼
[Route("api/home")]
[ApiController]
public class HomeController : ControllerBase
{
PhoneValidator validator = null;
public HomeController(PhoneValidator pv)
{
validator = pv;
}
[HttpGet("login")]
public IActionResult Login(string phone)
{
bool accept = validator.IsPhone(ref phone);
return new JsonResult(new { phone, accept });
}
}
- 5.2 運行項目,在瀏覽器中輸入地址
http://localhost:33868/api/home/login?phone=86-13800138000
- 5.3 輸出結果
結語
- 通過上面的示例,可以實現對各種各樣手機號碼的控制,由於號段寫在配置文件中,我們可以在業務擴展到時候去動態的增加號段,還可以針對各個地區去擴展 PhoneValidator 類,以實現切合業務的驗證需求,從此,手機號碼驗證不再需要一刀切。
示例代碼下載
- https://files.cnblogs.com/files/viter/Ron.PhoneTest.zip