一個常用的正則表達驗證類
來源:易賢網(wǎng) 閱讀:1436 次 日期:2015-02-06 15:26:13
溫馨提示:易賢網(wǎng)小編為您整理了“一個常用的正則表達驗證類”,方便廣大網(wǎng)友查閱!

很早以前寫的一個正則表達式驗證工具類,包含了一些常見的校驗和支持自定義的正則表達式匹配,可以選擇完全匹配,也可以獲取所有匹配項。曾用它仿造Eclispe下的正則表達式插件寫過一個工具。因為最近突然有幾個朋友都在問這方面的問題,干脆就把代碼貼出來好了。

using System;

02.using System.Collections;

03.using System.Text.RegularExpressions;

04.

05.namespace Xrinehart.Framework.Common.Validate

06.{

07. /**//// <summary>

08. /// RegularMatch 的摘要說明。

09. /// </summary>

10. public class RegularMatch

11. {

12. private string _String;

13. private bool _IsEntirety;

14.

15. /**//// <summary>

16. /// 可以進行判斷的類型

17. /// </summary>

18. public enum Operation

19. {

20. Byte, SByte, Int16, Int32, Int64, Single, Double, Boolean, Char, Decimal, DateTime, Date, Time,

21. EMail, URL, ChinaPhone, ChineseWord, ChinesePostalCode, Number, StringModel_01, StringModel_02, WideWord, NarrowWord, IPAddress,

22. ChineseMobile, ChineseID

23. };

24.

25. public RegularMatch() { }

26.

27. 用于判斷字符串是否是對應類型(默認為包含匹配)#region 用于判斷字符串是否是對應類型(默認為包含匹配)

28. public bool IsAccordType(string strVerifyString, Operation op)

29. {

30. return IsAccordType(strVerifyString, op, false);

31. }

32. #endregion

33.

34. 用于判斷字符串是否是對應類型(或是否包含對應類型的字符)#region 用于判斷字符串是否是對應類型(或是否包含對應類型的字符)

35. /**//// <summary>

36. /// 用于判斷字符串是否是對應類型

37. /// </summary>

38. /// <param name="strVerifyString">String,需要判斷的字符串</param>

39. /// <param name="op">Operation枚舉,用于選擇需要進行的操作</param>

40. /// <param name="IsEntirety">Boolean,判斷是完全匹配還是包含匹配模式(僅適用于非類型判斷時)</param>

41. /// <returns></returns>

42. public bool IsAccordType(string strVerifyString, Operation op, bool IsEntirety)

43. {

44. _String = strVerifyString;

45. _IsEntirety = IsEntirety;

46.

47. switch (op)

48. {

49. case Operation.Byte:

50. {

51. return IsByte();

52. }

53. case Operation.SByte:

54. {

55. return IsSByte();

56. }

57. case Operation.Int16:

58. {

59. return IsInt16();

60. }

61. case Operation.Int32:

62. {

63. return IsInt32();

64. }

65. case Operation.Int64:

66. {

67. return IsInt64();

68. }

69. case Operation.Single:

70. {

71. return IsSingle();

72. }

73. case Operation.Double:

74. {

75. return IsDouble();

76. }

77. case Operation.Boolean:

78. {

79. return IsBoolean();

80. }

81. case Operation.Char:

82. {

83. return IsChar();

84. }

85. case Operation.Decimal:

86. {

87. return IsDecimal();

88. }

89. case Operation.DateTime:

90. {

91. return IsDateTime();

92. }

93. case Operation.Date:

94. {

95. return IsDate();

96. }

97. case Operation.Time:

98. {

99. return IsTime();

100. }

101. case Operation.IPAddress:

102. {

103. return IsIPAddress();

104. }

105. case Operation.ChinaPhone:

106. {

107. return IsChinaPhone();

108. }

109. case Operation.ChinesePostalCode:

110. {

111. return IsChinesePostalCode();

112. }

113. case Operation.ChineseMobile:

114. {

115. return IsChineseMobile();

116. }

117. case Operation.EMail:

118. {

119. return IsEmail();

120. }

121. case Operation.URL:

122. {

123. return IsURL();

124. }

125. case Operation.ChineseWord:

126. {

127. return IsChineseWord();

128. }

129. case Operation.Number:

130. {

131. return IsNumber();

132. }

133. case Operation.StringModel_01:

134. {

135. return IsStringModel_01();

136. }

137. case Operation.StringModel_02:

138. {

139. return IsStringModel_02();

140. }

141. case Operation.WideWord:

142. {

143. return IsWideWord();

144. }

145. case Operation.NarrowWord:

146. {

147. return IsNarrowWord();

148. }

149. case Operation.ChineseID:

150. {

151. return IsChineseID();

152. }

153. default:

154. {

155. return false;

156. }

157. }

158. }

159. #endregion

160.

161. 具體驗證方法#region 具體驗證方法

162.

163. 是否Byte類型(8 位的無符號整數(shù)): 0 和 255 之間的無符號整數(shù)#region 是否Byte類型(8 位的無符號整數(shù)): 0 和 255 之間的無符號整數(shù)

164. /**//// <summary>

165. /// 是否Byte類型(8 位的無符號整數(shù)): 0 和 255 之間的無符號整數(shù)

166. /// </summary>

167. /// <returns>Boolean</returns>

168. protected bool IsByte()

169. {

170. try

171. {

172. Byte.Parse(_String);

173. }

174. catch

175. {

176. return false;

177. }

178. return true;

179. }

180. #endregion

181.

182. 是否SByte類型(8 位的有符號整數(shù)): -128 到 +127 之間的整數(shù)#region 是否SByte類型(8 位的有符號整數(shù)): -128 到 +127 之間的整數(shù)

183. /**//// <summary>

184. /// 是否SByte類型(8 位的有符號整數(shù)): -128 到 +127 之間的整數(shù)

185. /// </summary>

186. /// <returns>Boolean</returns>

187. protected bool IsSByte()

188. {

189. try

190. {

191. SByte.Parse(_String);

192. }

193. catch

194. {

195. return false;

196. }

197. return true;

198. }

199. #endregion

200.

201. 是否Int16類型(16 位的有符號整數(shù)): -32768 到 +32767 之間的有符號整數(shù)#region 是否Int16類型(16 位的有符號整數(shù)): -32768 到 +32767 之間的有符號整數(shù)

202. /**//// <summary>

203. /// 是否Int16類型(16 位的有符號整數(shù)): -32768 到 +32767 之間的有符號整數(shù)

204. /// </summary>

205. /// <returns>Boolean</returns>

206. protected bool IsInt16()

207. {

208. try

209. {

210. Int16.Parse(_String);

211. }

212. catch

213. {

214. return false;

215. }

216. return true;

217. }

218. #endregion

219.

220. 是否Int32類型(32 位的有符號整數(shù)):-2,147,483,648 到 +2,147,483,647 之間的有符號整數(shù)#region 是否Int32類型(32 位的有符號整數(shù)):-2,147,483,648 到 +2,147,483,647 之間的有符號整數(shù)

221. /**//// <summary>

222. /// 是否Int32類型(32 位的有符號整數(shù)):-2,147,483,648 到 +2,147,483,647 之間的有符號整數(shù)

223. /// </summary>

224. /// <returns>Boolean</returns>

225. protected bool IsInt32()

226. {

227. try

228. {

229. Int32.Parse(_String);

230. }

231. catch

232. {

233. return false;

234. }

235. return true;

236. }

237. #endregion

238.

239. 是否Int64類型(64 位的有符號整數(shù)): -9,223,372,036,854,775,808 到 +9,223,372,036,854,775,807 之間的整數(shù)#region 是否Int64類型(64 位的有符號整數(shù)): -9,223,372,036,854,775,808 到 +9,223,372,036,854,775,807 之間的整數(shù)

240. /**//// <summary>

241. /// 是否Int64類型(64 位的有符號整數(shù)): -9,223,372,036,854,775,808 到 +9,223,372,036,854,775,807 之間的整數(shù)

242. /// </summary>

243. /// <returns>Boolean</returns>

244. protected bool IsInt64()

245. {

246. try

247. {

248. Int64.Parse(_String);

249. }

250. catch

251. {

252. return false;

253. }

254. return true;

255. }

256. #endregion

257.

258. 是否Single類型(單精度(32 位)浮點數(shù)字): -3.402823e38 和 +3.402823e38 之間的單精度 32 位數(shù)字#region 是否Single類型(單精度(32 位)浮點數(shù)字): -3.402823e38 和 +3.402823e38 之間的單精度 32 位數(shù)字

259. /**//// <summary>

260. /// 是否Single類型(單精度(32 位)浮點數(shù)字): -3.402823e38 和 +3.402823e38 之間的單精度 32 位數(shù)字

261. /// </summary>

262. /// <returns>Boolean</returns>

263. protected bool IsSingle()

264. {

265. try

266. {

267. Single.Parse(_String);

268. }

269. catch

270. {

271. return false;

272. }

273. return true;

274. }

275. #endregion

276.

277. 是否Double類型(單精度(64 位)浮點數(shù)字): -1.79769313486232e308 和 +1.79769313486232e308 之間的雙精度 64 位數(shù)字#region 是否Double類型(單精度(64 位)浮點數(shù)字): -1.79769313486232e308 和 +1.79769313486232e308 之間的雙精度 64 位數(shù)字

278. /**//// <summary>

279. /// 是否Double類型(單精度(64 位)浮點數(shù)字): -1.79769313486232e308 和 +1.79769313486232e308 之間的雙精度 64 位數(shù)字

280. /// </summary>

281. /// <returns>Boolean</returns>

282. protected bool IsDouble()

283. {

284. try

285. {

286. Double.Parse(_String);

287. }

288. catch

289. {

290. return false;

291. }

292. return true;

293. }

294. #endregion

295.

296. 是否Boolean類型(布爾值):true 或 false#region 是否Boolean類型(布爾值):true 或 false

297. /**//// <summary>

298. /// 是否Double類型(單精度(64 位)浮點數(shù)字): -1.79769313486232e308 和 +1.79769313486232e308 之間的雙精度 64 位數(shù)字

299. /// </summary>

300. /// <returns>Boolean</returns>

301. protected bool IsBoolean()

302. {

303. try

304. {

305. Boolean.Parse(_String);

306. }

307. catch

308. {

309. return false;

310. }

311. return true;

312. }

313. #endregion

314.

315. 是否Char類型(Unicode(16 位)字符):該 16 位數(shù)字的值范圍為從十六進制值 0x0000 到 0xFFFF#region 是否Char類型(Unicode(16 位)字符):該 16 位數(shù)字的值范圍為從十六進制值 0x0000 到 0xFFFF

316. /**//// <summary>

317. /// 是否Char類型(Unicode(16 位)字符):該 16 位數(shù)字的值范圍為從十六進制值 0x0000 到 0xFFFF

318. /// </summary>

319. /// <returns>Boolean</returns>

320. protected bool IsChar()

321. {

322. try

323. {

324. Char.Parse(_String);

325. }

326. catch

327. {

328. return false;

329. }

330. return true;

331. }

332. #endregion

333.

334. 是否Char類型(96 位十進制值):從正 79,228,162,514,264,337,593,543,950,335 到負 79,228,162,514,264,337,593,543,950,335 之間的十進制數(shù)#region 是否Char類型(96 位十進制值):從正 79,228,162,514,264,337,593,543,950,335 到負 79,228,162,514,264,337,593,543,950,335 之間的十進制數(shù)

335. /**//// <summary>

336. /// 是否Char類型(96 位十進制值):從正 79,228,162,514,264,337,593,543,950,335 到負 79,228,162,514,264,337,593,543,950,335 之間的十進制數(shù)

337. /// </summary>

338. /// <returns>Boolean</returns>

339. protected bool IsDecimal()

340. {

341. try

342. {

343. Decimal.Parse(_String);

344. }

345. catch

346. {

347. return false;

348. }

349. return true;

350. }

351. #endregion

352.

353. 是否DateTime類型(表示時間上的一刻): 范圍在公元(基督紀元)0001 年 1 月 1 日午夜 12:00:00 到公元 (C.E.) 9999 年 12 月 31 日晚上 11:59:59 之間的日期和時間#region 是否DateTime類型(表示時間上的一刻): 范圍在公元(基督紀元)0001 年 1 月 1 日午夜 12:00:00 到公元 (C.E.) 9999 年 12 月 31 日晚上 11:59:59 之間的日期和時間

354. /**//// <summary>

355. /// 是否DateTime類型(表示時間上的一刻): 范圍在公元(基督紀元)0001 年 1 月 1 日午夜 12:00:00 到公元 (C.E.) 9999 年 12 月 31 日晚上 11:59:59 之間的日期和時間

356. /// </summary>

357. /// <returns>Boolean</returns>

358. protected bool IsDateTime()

359. {

360. try

361. {

362. DateTime.Parse(_String);

363. }

364. catch

365. {

366. return false;

367. }

368. return true;

369. }

370. #endregion

371.

372. 是否Date類型(表示時間的日期部分): 范圍在公元(基督紀元)0001 年 1 月 1 日 到公元 (C.E.) 9999 年 12 月 31 日之間的日期#region 是否Date類型(表示時間的日期部分): 范圍在公元(基督紀元)0001 年 1 月 1 日 到公元 (C.E.) 9999 年 12 月 31 日之間的日期

373. /**//// <summary>

374. /// 是否Date類型(表示時間的日期部分): 范圍在公元(基督紀元)0001 年 1 月 1 日 到公元 (C.E.) 9999 年 12 月 31 日之間的日期

375. /// </summary>

376. /// <returns>Boolean</returns>

377. protected bool IsDate()

378. {

379. DateTime Value;

380. try

381. {

382. Value = DateTime.Parse(_String);

383. }

384. catch

385. {

386. return false;

387. }

388. if (Value.Date.ToString() == _String)

389. {

390. return true;

391. }

392. else

393. {

394. return false;

395. }

396. }

397. #endregion

398.

399. 是否Time類型(表示時間部分HHMMSS): 范圍在夜 12:00:00 到晚上 11:59:59 之間的時間#region 是否Time類型(表示時間部分HHMMSS): 范圍在夜 12:00:00 到晚上 11:59:59 之間的時間

400. /**//// <summary>

401. /// 是否Time類型(表示時間部分HHMMSS): 范圍在夜 12:00:00 到晚上 11:59:59 之間的時間

402. /// </summary>

403. /// <returns>Boolean</returns>

404. protected bool IsTime()

405. {

406. DateTime Value;

407. try

408. {

409. Value = DateTime.Parse(_String);

410. }

411. catch

412. {

413. return false;

414. }

415. if (Value.Year == 1 && Value.Month == 1 && Value.Day == 1)

416. {

417. return true;

418. }

419. else

420. {

421. return false;

422. }

423. }

424. #endregion

425.

426. 是否IPAddress類型(IPv4 的情況下使用以點分隔的四部分表示法格式表示,IPv6 的情況下使用冒號與十六進制格式表示)#region 是否IPAddress類型(IPv4 的情況下使用以點分隔的四部分表示法格式表示,IPv6 的情況下使用冒號與十六進制格式表示)

427. /**//// <summary>

428. /// 是否IPAddress類型(IPv4 的情況下使用以點分隔的四部分表示法格式表示,IPv6 的情況下使用冒號與十六進制格式表示)

429. /// </summary>

430. /// <returns>Boolean</returns>

431. protected bool IsIPAddress()

432. {

433. try

434. {

435. System.Net.IPAddress.Parse(_String);

436. }

437. catch

438. {

439. return false;

440. }

441. return true;

442. }

443. #endregion

444.

445. 是否中國電話號碼類型(XXX/XXXX-XXXXXXX/XXXXXXXX (/d{3,4})-?/d{7,8}):判斷是否是(區(qū)號:3或4位)-(電話號碼:7或8位)#region 是否中國電話號碼類型(XXX/XXXX-XXXXXXX/XXXXXXXX (/d{3,4})-?/d{7,8}):判斷是否是(區(qū)號:3或4位)-(電話號碼:7或8位)

446. /**//// <summary>

447. /// 是否中國電話號碼類型(XXX/XXXX-XXXXXXX/XXXXXXXX (/d{3,4})-?/d{7,8}):判斷是否是(區(qū)號:3或4位)-(電話號碼:7或8位)

448. /// </summary>

449. /// <returns>Boolean</returns>

450. protected bool IsChinaPhone()

451. {

452. ArrayList aryResult = new ArrayList();

453. return CommRegularMatch(_String, @"(/d{3,4})-?/d{7,8}", RegexOptions.None, ref aryResult, _IsEntirety);

454. }

455. #endregion

456.

457. 是否中國郵政編碼(6位數(shù)字 /d{6})#region 是否中國郵政編碼(6位數(shù)字 /d{6})

458. /**//// <summary>

459. /// 是否中國郵政編碼(6位數(shù)字 /d{6})

460. /// </summary>

461. /// <returns>Boolean</returns>

462. protected bool IsChinesePostalCode()

463. {

464. ArrayList aryResult = new ArrayList();

465. return CommRegularMatch(_String, @"/d{6}", RegexOptions.None, ref aryResult, _IsEntirety);

466. }

467. #endregion

468.

469. 是否中國移動電話號碼(13開頭的總11位數(shù)字 13/d{9})#region 是否中國移動電話號碼(13開頭的總11位數(shù)字 13/d{9})

470. /**//// <summary>

471. /// 是否中國移動電話號碼(13開頭的總11位數(shù)字 13/d{9})

472. /// </summary>

473. /// <returns>Boolean</returns>

474. protected bool IsChineseMobile()

475. {

476. ArrayList aryResult = new ArrayList();

477. return CommRegularMatch(_String, @"13/d{9}", RegexOptions.None, ref aryResult, _IsEntirety);

478. }

479. #endregion

480.

481. 是否EMail類型(XXX@XXX.XXX /w+([-+.]/w+)*@/w+([-.]/w+)*/./w+([-.]/w+)*)#region 是否EMail類型(XXX@XXX.XXX /w+([-+.]/w+)*@/w+([-.]/w+)*/./w+([-.]/w+)*)

482. /**//// <summary>

483. /// 是否EMail類型(XXX@XXX.XXX /w+([-+.]/w+)*@/w+([-.]/w+)*/./w+([-.]/w+)*)

484. /// </summary>

485. /// <returns>Boolean</returns>

486. protected bool IsEmail()

487. {

488. ArrayList aryResult = new ArrayList();

489. return CommRegularMatch(_String, @"/w+([-+.]/w+)*@/w+([-.]/w+)*/./w+([-.]/w+)*", RegexOptions.None, ref aryResult, _IsEntirety);

490. }

491. #endregion

492.

493. 是否Internet URL地址類型(http://)#region 是否Internet URL地址類型(http://)

494. /**//// <summary>

495. /// 是否Internet URL地址類型(http://)

496. /// </summary>

497. /// <returns>Boolean</returns>

498. protected bool IsURL()

499. {

500. ArrayList aryResult = new ArrayList();

501. return CommRegularMatch(_String, @"http://([/w-]+/.)+[/w-]+(/[/w- ./?%&=]*)?", RegexOptions.None, ref aryResult, _IsEntirety);

502. }

503. #endregion

504.

505. 是否中文字符([/u4e00-/u9fa5])#region 是否中文字符([/u4e00-/u9fa5])

506. /**//// <summary>

507. /// 是否中文字符([/u4e00-/u9fa5])

508. /// </summary>

509. /// <returns>Boolean</returns>

510. protected bool IsChineseWord()

511. {

512. ArrayList aryResult = new ArrayList();

513. return CommRegularMatch(_String, @"[/u4e00-/u9fa5]", RegexOptions.None, ref aryResult, _IsEntirety);

514. }

515. #endregion

516.

517. 是否是數(shù)字(0到9的數(shù)字[/d]+):不包括符號"."和"-"#region 是否是數(shù)字(0到9的數(shù)字[/d]+):不包括符號"."和"-"

518. /**//// <summary>

519. /// 是否是數(shù)字(0到9的數(shù)字[/d]+):不包括符號"."和"-"

520. /// </summary>

521. /// <returns>Boolean</returns>

522. protected bool IsNumber()

523. {

524. ArrayList aryResult = new ArrayList();

525. return CommRegularMatch(_String, @"[/d]+", RegexOptions.None, ref aryResult, _IsEntirety);

526. }

527. #endregion

528.

529. 是否只包含數(shù)字,英文和下劃線([/w]+)#region 是否只包含數(shù)字,英文和下劃線([/w]+)

530. /**//// <summary>

531. /// 是否只包含數(shù)字,英文和下劃線([/w]+)

532. /// </summary>

533. /// <returns>Boolean</returns>

534. protected bool IsStringModel_01()

535. {

536. ArrayList aryResult = new ArrayList();

537. return CommRegularMatch(_String, @"[/w]+", RegexOptions.None, ref aryResult, _IsEntirety);

538. }

539. #endregion

540.

541. 是否大寫首字母的英文字母([A-Z][a-z]+)#region 是否大寫首字母的英文字母([A-Z][a-z]+)

542. /**//// <summary>

543. /// 是否大寫首字母的英文字母([A-Z][a-z]+)

544. /// </summary>

545. /// <returns>Boolean</returns>

546. protected bool IsStringModel_02()

547. {

548. ArrayList aryResult = new ArrayList();

549. return CommRegularMatch(_String, @"[A-Z][a-z]+", RegexOptions.None, ref aryResult, _IsEntirety);

550. }

551. #endregion

552.

553. 是否全角字符([^/x00-/xff]):包括漢字在內(nèi)#region 是否全角字符([^/x00-/xff]):包括漢字在內(nèi)

554. /**//// <summary>

555. /// 是否全角字符([^/x00-/xff]):包括漢字在內(nèi)

556. /// </summary>

557. /// <returns>Boolean</returns>

558. protected bool IsWideWord()

559. {

560. ArrayList aryResult = new ArrayList();

561. return CommRegularMatch(_String, @"[^/x00-/xff]", RegexOptions.None, ref aryResult, _IsEntirety);

562. }

563. #endregion

564.

565. 是否半角字符([/x00-/xff])#region 是否半角字符([/x00-/xff])

566. /**//// <summary>

567. /// 是否半角字符([^/x00-/xff]):包括漢字在內(nèi)

568. /// </summary>

569. /// <returns>Boolean</returns>

570. protected bool IsNarrowWord()

571. {

572. ArrayList aryResult = new ArrayList();

573. return CommRegularMatch(_String, @"[/x00-/xff]", RegexOptions.None, ref aryResult, _IsEntirety);

574. }

575. #endregion

576.

577. 是否合法的中國身份證號碼#region 是否合法的中國身份證號碼

578. protected bool IsChineseID()

579. {

580. if (_String.Length == 15)

581. {

582. _String = CidUpdate(_String);

583. }

584. if (_String.Length == 18)

585. {

586. string strResult = CheckCidInfo(_String);

587. if (strResult == "非法地區(qū)" || strResult == "非法生日" || strResult == "非法證號")

588. {

589. return false;

590. }

591. else

592. {

593. return true;

594. }

595. }

596. else

597. {

598. return false;

599. }

600. }

601. #endregion

602.

603. #endregion

604.

605. 通用正則表達式判斷函數(shù)#region 通用正則表達式判斷函數(shù)

606. /**//// <summary>

607. /// 通用正則表達式判斷函數(shù)

608. /// </summary>

609. /// <param name="strVerifyString">String,用于匹配的字符串</param>

610. /// <param name="strRegular">String,正則表達式</param>

611. /// <param name="regOption">RegexOptions,配置正則表達式的選項</param>

612. /// <param name="aryResult">ArrayList,分解的字符串內(nèi)容</param>

613. /// <param name="IsEntirety">Boolean,是否需要完全匹配</param>

614. /// <returns></returns>

615. public bool CommRegularMatch(string strVerifyString, string strRegular, System.Text.RegularExpressions.RegexOptions regOption, ref System.Collections.ArrayList aryResult, bool IsEntirety)

616. {

617. System.Text.RegularExpressions.Regex r;

618. System.Text.RegularExpressions.Match m;

619.

620. 如果需要完全匹配的處理#region 如果需要完全匹配的處理

621. if (IsEntirety)

622. {

623. strRegular = strRegular.Insert(0, @"/A");

624. strRegular = strRegular.Insert(strRegular.Length, @"/z");

625. }

626. #endregion

627.

628. try

629. {

630. r = new System.Text.RegularExpressions.Regex(strRegular, regOption);

631. }

632. catch (System.Exception e)

633. {

634. throw (e);

635. }

636.

637. for (m = r.Match(strVerifyString); m.Success; m = m.NextMatch())

638. {

639. aryResult.Add(m);

640. }

641.

642. if (aryResult.Count == 0)

643. {

644. return false;

645. }

646. else

647. {

648. return true;

649. }

650. }

651. #endregion

652.

653. 中國身份證號碼驗證#region 中國身份證號碼驗證

654. private string CheckCidInfo(string cid)

655. {

656. string[] aCity = new string[] { null, null, null, null, null, null, null, null, null, null, null, "北京", "天津", "河北", "山西", "內(nèi)蒙古", null, null, null, null, null, "遼寧", "吉林", "黑龍江", null, null, null, null, null, null, null, "上海", "江蘇", "浙江", "安微", "福建", "江西", "山東", null, null, null, "河南", "湖北", "湖南", "廣東", "廣西", "海南", null, null, null, "重慶", "四川", "貴州", "云南", "西藏", null, null, null, null, null, null, "陜西", "甘肅", "青海", "寧夏", "新疆", null, null, null, null, null, "臺灣", null, null, null, null, null, null, null, null, null, "香港", "澳門", null, null, null, null, null, null, null, null, "國外" };

657. double iSum = 0;

658. string info = string.Empty;

659. System.Text.RegularExpressions.Regex rg = new System.Text.RegularExpressions.Regex(@"^/d{17}(/d|x)$");

660. System.Text.RegularExpressions.Match mc = rg.Match(cid);

661. if (!mc.Success)

662. {

663. return string.Empty;

664. }

665. cid = cid.ToLower();

666. cid = cid.Replace("x", "a");

667. if (aCity[int.Parse(cid.Substring(0, 2))] == null)

668. {

669. return "非法地區(qū)";

670. }

671. try

672. {

673. DateTime.Parse(cid.Substring(6, 4) + " - " + cid.Substring(10, 2) + " - " + cid.Substring(12, 2));

674. }

675. catch

676. {

677. return "非法生日";

678. }

679. for (int i = 17; i >= 0; i--)

680. {

681. iSum += (System.Math.Pow(2, i) % 11) * int.Parse(cid[17 - i].ToString(), System.Globalization.NumberStyles.HexNumber);

682. }

683. if (iSum % 11 != 1)

684. {

685. return ("非法證號");

686. }

687. else

688. {

689. return (aCity[int.Parse(cid.Substring(0, 2))] + "," + cid.Substring(6, 4) + "-" + cid.Substring(10, 2) + "-" + cid.Substring(12, 2) + "," + (int.Parse(cid.Substring(16, 1)) % 2 == 1 ? "男" : "女"));

690. }

691. }

692. #endregion

693.

694. 身份證號碼15升級為18位#region 身份證號碼15升級為18位

695. private string CidUpdate(string ShortCid)

696. {

697. char[] strJiaoYan = { '1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2' };

698. int[] intQuan = { 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2, 1 };

699. string strTemp;

700. int intTemp = 0;

701.

702. strTemp = ShortCid.Substring(0, 6) + "19" + ShortCid.Substring(6);

703. for (int i = 0; i <= strTemp.Length - 1; i++)

704. {

705. intTemp += int.Parse(strTemp.Substring(i, 1)) * intQuan[i];

706. }

707. intTemp = intTemp % 11;

708. return strTemp + strJiaoYan[intTemp];

709. }

710. #endregion

711. }

712.}

更多信息請查看IT技術(shù)專欄

更多信息請查看數(shù)據(jù)庫
易賢網(wǎng)手機網(wǎng)站地址:一個常用的正則表達驗證類
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復僅供參考,敬請考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇剩?/div>

2025國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)