id-validator/README.md

127 lines
4.8 KiB
Markdown
Raw Permalink Normal View History

2021-01-08 17:28:15 +08:00
# id-validator
2021-01-21 09:40:55 +08:00
[简体中文](README.md) | [ENGLISH](README-EN.md)
2021-01-20 18:05:38 +08:00
> 中国身份证号验证。
2021-01-08 17:28:15 +08:00
2021-01-12 16:26:52 +08:00
[![Tests](https://github.com/guanguans/id-validator/workflows/Tests/badge.svg)](https://github.com/guanguans/id-validator/actions)
2021-01-12 16:09:37 +08:00
[![gocover.io](https://gocover.io/_badge/github.com/guanguans/id-validator)](https://gocover.io/github.com/guanguans/id-validator)
[![Go Report Card](https://goreportcard.com/badge/github.com/guanguans/id-validator)](https://goreportcard.com/report/github.com/guanguans/id-validator)
[![GoDoc](https://godoc.org/github.com/guanguans/id-validator?status.svg)](https://godoc.org/github.com/guanguans/id-validator)
2021-01-20 18:05:38 +08:00
[![GitHub release](https://img.shields.io/github/tag/guanguans/id-validator.svg)](https://github.com/guanguans/id-validator/releases)
2021-01-12 16:09:37 +08:00
[![GitHub license](https://img.shields.io/github/license/guanguans/id-validator.svg)](https://github.com/guanguans/id-validator/blob/master/LICENSE)
2021-01-08 17:28:15 +08:00
2021-01-20 18:05:38 +08:00
## 功能
* 中国身份证号验证
* 获取身份证号信息
* 升级 15 位身份证号为 18 位
* 伪造符合校验的身份证号
## 环境要求
2021-01-08 17:28:15 +08:00
2021-01-12 14:18:17 +08:00
* Go >= 1.11
2021-01-08 17:28:15 +08:00
2021-01-20 18:05:38 +08:00
## 安装
2021-01-08 17:28:15 +08:00
``` shell script
2021-01-12 14:18:17 +08:00
$ go get -u github.com/guanguans/id-validator
2021-01-08 17:28:15 +08:00
```
2021-01-20 18:05:38 +08:00
## 使用
2021-01-12 16:09:37 +08:00
2021-01-20 18:05:38 +08:00
这只是一个快速介绍, 请查看 [GoDoc](https://godoc.org/github.com/guanguans/id-validator) 获得详细信息。
2021-01-12 16:09:37 +08:00
2021-01-12 14:18:17 +08:00
``` go
package main
import (
2021-01-12 17:46:05 +08:00
idvalidator "github.com/guanguans/id-validator"
2021-01-19 18:21:36 +08:00
"gopkg.in/ffmt.v1"
2021-01-12 14:18:17 +08:00
)
func main() {
// 验证身份证号合法性
ffmt.P(idvalidator.IsValid("440308199901101512")) // 大陆居民身份证18位
ffmt.P(idvalidator.IsValid("610104620927690")) // 大陆居民身份证15位
ffmt.P(idvalidator.IsValid("810000199408230021")) // 港澳居民居住证18位
ffmt.P(idvalidator.IsValid("830000199201300022")) // 台湾居民居住证18位
// 获取身份证号信息
ffmt.P(idvalidator.GetInfo("440308199901101512"))
// []interface {}[
// github.com/guanguans/id-validator.IdInfo{ // 身份证号信息
// AddressCode: int(440308) // 地址码
// Abandoned: int(0) // 地址码是否废弃1为废弃的0为正在使用的
// Address: string("广东省深圳市盐田区") // 地址
// AddressTree: []string[ // 省市区三级列表
// string("广东省") // 省
// string("深圳市") // 市
// string("盐田区") // 区
// ]
// Birthday: <1999-01-10 00:00:00 +0000 UTC> // 出生日期
// Constellation: string("摩羯座") // 星座
// ChineseZodiac: string("卯兔") // 生肖
// Sex: int(1) // 性别1为男性0为女性
// Length: int(18) // 号码长度
// CheckBit: string("2") // 校验码
// }
// <nil> // 错误信息
// ]
// 生成可通过校验的假身份证号
ffmt.P(idvalidator.FakeId()) // 随机生成
ffmt.P(idvalidator.FakeRequireId(true, "江苏省", "200001", 1)) // 生成出生于2000年1月江苏省的男性居民身份证
// 15位号码升级为18位
ffmt.P(idvalidator.UpgradeId("610104620927690"))
// []interface {}[
// string("610104196209276908") // 升级后号码
// <nil> // 错误信息
// ]
}
```
2021-01-20 18:05:38 +08:00
## 测试
2021-01-08 17:28:15 +08:00
``` bash
2021-01-25 17:06:49 +08:00
$ make test
2021-01-08 17:28:15 +08:00
```
2021-01-20 18:05:38 +08:00
## 变更日志
2021-01-08 17:28:15 +08:00
2021-01-20 18:05:38 +08:00
请参阅 [CHANGELOG](CHANGELOG.md) 获取最近有关更改的更多信息。
2021-01-08 17:28:15 +08:00
2021-01-20 18:05:38 +08:00
## 贡献指南
2021-01-08 17:28:15 +08:00
2021-01-20 18:05:38 +08:00
请参阅 [CONTRIBUTING](.github/CONTRIBUTING.md) 有关详细信息。
2021-01-08 17:28:15 +08:00
2021-01-20 18:05:38 +08:00
## 安全漏洞
2021-01-08 17:28:15 +08:00
2021-01-20 18:05:38 +08:00
请查看[我们的安全政策](../../security/policy)了解如何报告安全漏洞。
2021-01-08 17:28:15 +08:00
2021-01-20 18:05:38 +08:00
## 贡献者
2021-01-08 17:28:15 +08:00
* [guanguans](https://github.com/guanguans)
2021-01-20 18:05:38 +08:00
* [所有贡献者](../../contributors)
2021-01-08 17:28:15 +08:00
2021-01-12 14:18:17 +08:00
## 相关项目
2021-01-20 18:05:38 +08:00
* [jxlwqq/id-validator](https://github.com/jxlwqq/id-validator)jxlwqq
* [jxlwqq/id-validator.py](https://github.com/jxlwqq/id-validator.py)jxlwqq
* [mc-zone/IDValidator](https://github.com/mc-zone/IDValidator)mc-zone
* [renyijiu/id_validator](https://github.com/renyijiu/id_validator)renyijiu
2021-01-12 14:18:17 +08:00
## 参考资料
* [中华人民共和国公民身份号码](https://zh.wikipedia.org/wiki/中华人民共和国公民身份号码)
* [中华人民共和国民政部:行政区划代码](http://www.mca.gov.cn/article/sj/xzqh/)
* [中华人民共和国行政区划代码历史数据集](https://github.com/jxlwqq/address-code-of-china)
* [国务院办公厅关于印发《港澳台居民居住证申领发放办法》的通知](http://www.gov.cn/zhengce/content/2018-08/19/content_5314865.htm)
* [港澳台居民居住证](https://zh.wikipedia.org/wiki/港澳台居民居住证)
2021-01-20 18:05:38 +08:00
## 协议
2021-01-08 17:28:15 +08:00
2021-01-20 18:05:38 +08:00
MIT 许可证MIT。有关更多信息请参见[协议文件](LICENSE)。