一個完整的台灣身分驗證 TypeScript 套件,支援身分證件、營業代碼、車牌號碼等多種格式驗證。
npm install taiwan-validator
import {
validateNationalId,
validateBusinessNumber,
validateResidentCertificate,
validateMobilePhone,
validateCitizenCertificate,
validateEInvoiceMobileBarcode,
validateEInvoiceDonationCode,
validateLicensePlate,
} from "taiwan-validator";
// 身分證字號
validateNationalId("A123456789"); // { isValid: true }
validateNationalId("AA23456786"); // { isValid: true } - 新式格式
// 統一編號
validateBusinessNumber("12345676"); // { isValid: true }
// 居留證號
validateResidentCertificate("A823456783"); // { isValid: true } - 舊式
validateResidentCertificate("AA23456786"); // { isValid: true } - 新式
// 手機號碼
validateMobilePhone("0912345678"); // { isValid: true }
validateMobilePhone("0912-345-678"); // { isValid: true } - 含分隔符號
// 自然人憑證
validateCitizenCertificate("AB12345678901234"); // { isValid: true }
// 電子發票手機條碼
validateEInvoiceMobileBarcode("/ABCD123"); // { isValid: true }
// 電子發票捐贈碼
validateEInvoiceDonationCode("12345"); // { isValid: true }
// 車牌號碼
validateLicensePlate("ABC-1235"); // { isValid: true, plateType: 'car' }
validateLicensePlate("EAB-1235"); // { isValid: true, plateType: 'electric-car' }
validateLicensePlate("AB1-234"); // { isValid: true, plateType: 'motorcycle' }
validateNationalId(id: string, format?: 'old' | 'new'): ValidationResult驗證台灣身分證字號。
A123456789)AA23456786)validateNationalId("A123456789"); // 自動偵測格式
validateNationalId("A123456789", "old"); // 明確指定舊式格式
validateNationalId("AA23456786", "new"); // 明確指定新式格式
validateBusinessNumber(number: string): ValidationResult驗證台灣統一編號。
validateBusinessNumber("12345676");
validateResidentCertificate(id: string, format?: 'old' | 'new'): ValidationResult驗證台灣居留證號。
validateResidentCertificate("A823456783"); // 自動偵測格式
validateResidentCertificate("A823456783", "old"); // 舊式格式
validateResidentCertificate("AA23456786", "new"); // 新式格式
validateMobilePhone(phone: string): ValidationResult驗證台灣手機號碼。
validateMobilePhone("0912345678");
validateMobilePhone("0912-345-678"); // 接受分隔符號
validateCitizenCertificate(certNumber: string): ValidationResult驗證台灣自然人憑證號碼。
validateCitizenCertificate("AB12345678901234");
validateEInvoiceMobileBarcode(barcode: string): ValidationResult驗證台灣電子發票手機條碼。
/ + 7 個字元(A-Z、0-9、+、-、.)validateEInvoiceMobileBarcode("/ABCD123");
validateEInvoiceDonationCode(code: string): ValidationResult驗證台灣電子發票捐贈碼。
validateEInvoiceDonationCode("12345");
validateLicensePlate(plate: string, options?: { type?: LicensePlateType, detectType?: boolean }): LicensePlateValidationResult驗證台灣車牌號碼,支援多種車輛類型。
car):3個英文字母 - 4個數字(例如:ABC-1235)
car-old):1個數字 + 1個英文字母 - 4個數字(例如:1A-2345)electric-car):E + 2個英文字母 - 4個數字(例如:EAB-1235)
motorcycle-small):
123-ABC)ABC-123)motorcycle):2個英文字母 + 1個數字 - 3個數字(例如:AB1-234)// 基本驗證(自動偵測車牌類型)
validateLicensePlate("ABC-1235");
// { isValid: true, plateType: 'car' }
// 電動汽車
validateLicensePlate("EAB-1235");
// { isValid: true, plateType: 'electric-car' }
// 舊制汽車
validateLicensePlate("1A-2345");
// { isValid: true, plateType: 'car-old' }
// 小型機車
validateLicensePlate("123-ABC");
// { isValid: true, plateType: 'motorcycle-small' }
validateLicensePlate("ABC-123");
// { isValid: true, plateType: 'motorcycle-small' }
// 一般機車
validateLicensePlate("AB1-234");
// { isValid: true, plateType: 'motorcycle' }
// 指定車牌類型驗證
validateLicensePlate("ABC-1235", { type: "car" });
// { isValid: true, plateType: 'car' }
// 不偵測車牌類型
validateLicensePlate("ABC-1235", { detectType: false });
// { isValid: true }
// 處理小寫和空格
validateLicensePlate(" abc-1235 ");
// { isValid: true, plateType: 'car' }
所有驗證函式都會回傳 ValidationResult 物件:
interface ValidationResult {
isValid: boolean;
message?: string; // 當 isValid 為 false 時的錯誤訊息
}
車牌驗證函式會回傳 LicensePlateValidationResult,包含額外的車牌類型資訊:
interface LicensePlateValidationResult extends ValidationResult {
plateType?:
| "car"
| "car-old"
| "electric-car"
| "motorcycle-small"
| "motorcycle";
}
# 複製專案
git clone https://github.com/imgarylai/taiwan-validator.git
cd taiwan-validator
# 安裝相依套件
npm install
# 執行測試
npm test
# 執行測試並產生覆蓋率報告
npm run test:coverage
# 建置套件
npm run build
# 開發模式(監看)
npm run dev
npm run build - 使用 tsup 建置套件npm run dev - 開發模式(監看)npm test - 執行測試npm run test:coverage - 執行測試並產生覆蓋率報告npm run lint - 程式碼檢查npm run type-check - 型別檢查npm run docs - 產生文件npm run clean - 清除建置輸出歡迎貢獻!請隨時提交 Pull Request。
git checkout -b feature/amazing-feature)git commit -m 'feat: add amazing feature')git push origin feature/amazing-feature)本專案使用 MIT 授權 - 詳見 LICENSE 檔案。
Gary Lai - @imgarylai
本套件實作了台灣官方的身分證件與代碼驗證演算法。