java、正则表达式、php校验“统一社会信用代码”
java
import java.util.HashMap;
import java.util.Map;
/**
* Desc: 社会信用代码证 检验
* Created 2016/5/18.
*/
class Regex_CreditCode {
static String creditCode = "91350100M000100Y43";// 测试
static String isCreditCode = "true";
static String error_CreditCode = "社会信用代码有误";
static String error_CreditCode_min = "社会信用代码不足18位,请核对后再输!";
static String error_CreditCode_max = "社会信用代码大于18位,请核对后再输!";
static String error_CreditCode_empty ="社会信用代码不能为空!";
private static Map<String,Integer> datas = null;
private static char[] pre17s;
static int[] power = {1,3,9,27,19,26,16,17,20,29,25,13,8,24,10,30,28};
// 社会统一信用代码不含(I、O、S、V、Z) 等字母
static char[] code = {'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F','G','H','J','K','L','M','N','P','Q','R','T','U','W','X','Y'};
public static void main(String[] args){
String temp = creditCode;
System.out.println(temp);
initDatas(code.length);
pre17(temp);
isCreditCode(temp);
}
/**
* 判断是否是一个有效的社会信用代码
* @param creditCode
* @return
*/
static String isCreditCode(String creditCode){
if("".equals(creditCode)||" ".equals(creditCode)){
System.out.println(error_CreditCode_empty);
return error_CreditCode_empty;
}else if(creditCode.length()<18){
System.out.println(error_CreditCode_min);
return error_CreditCode_min;
}else if(creditCode.length()>18){
System.out.println(error_CreditCode_max);
return error_CreditCode_max;
}else{
int sum = sum(pre17s);
int temp = sum%31;
temp = temp==0?31:temp;// 谢谢 whhitli的帮助
System.out.println(code[31-temp]+" "+(creditCode.substring(17,18).equals(code[31-temp]+"")?isCreditCode:error_CreditCode));
return creditCode.substring(17,18).equals(code[31-temp]+"")?isCreditCode:error_CreditCode;
}
}
/**
* @param chars
* @return
*/
private static int sum(char[] chars){
int sum = 0;
for(int i=0;i<chars.length;i++){
int code = datas.get(chars[i]+"");
sum+=power[i]*code;
}
return sum;
}
/**
* 获取前17位字符
* @param creditCode
*/
static void pre17(String creditCode){
String pre17 = creditCode.substring(0,17);
pre17s = pre17.toCharArray();
}
/**
* 初始化数据
* @param count
*/
static void initDatas(int count){
datas = new HashMap<>();
for(int i=0;i<code.length;i++){
datas.put(code[i]+"",i);
}
System.out.println();
}
}
/*原文地址:http://blog.csdn.net/u013361668/article/details/51595169*/
正则表达式
方法1.[0-9A-HJ-NPQRTUWXY]{2}\d{6}[0-9A-HJ-NPQRTUWXY]{10}
方法2.
[^_IOZSVa-z\W]{2}\d{6}[^_IOZSVa-z\W]{10}
<span style="color:#000080"><span style="color:#dd1144">测试数据:91350100M000100Y43</span></span>
<span style="color:#000080"><span style="color:#dd1144"><span style="color:#333333">参照标准:</span>
<span style="color:#333333">《GB_32100-2015_法人和其他组织统一社会信用代码编码规则.》</span>
<span style="color:#333333">按照编码规则:</span>
<span style="color:#333333">统一代码为18位,统一代码由十八位的数字或大写英文字母(不适用</span><code>I、O、Z、S、V</code><span style="color:#333333">)组成,由五个部分组成:</span>
<span style="color:#333333">第一部分(第1位)为登记管理部门代码,9表示工商部门;(</span><span style="color:#333333">数字或大写英文字母</span><span style="color:#333333">)</span>
<span style="color:#333333">第二部分(第2位)为机构类别代码;(</span><span style="color:#333333">数字或大写英文字母</span><span style="color:#333333">)</span>
<span style="color:#333333">第三部分(第3-8位)为登记管理机关行政区划码;(</span><code>数字</code><span style="color:#333333">)</span>
<span style="color:#333333">第四部分(第9-17位)为全国组织机构代码;(</span><span style="color:#333333">数字或大写英文字母</span><span style="color:#333333">)</span>
<span style="color:#333333">第五部分(第18位)为校验码(</span><span style="color:#333333">数字或大写英文字母</span><span style="color:#333333">)</span>
</span></span>
另一种情况:
php
php版的三证合一统一社会信用代码,验证
<?php
//自动转换为大写进行的检验
//入库前需要所有字母转为大写strtoupper
//统一社会信用代码为18位无‘-’
/*
统一社会信用代码是新的全国范围内唯一的、始终不变的法定代码标识。
由18位数字(或大写拉丁字母)组成
第一位是 登记部门管理代码
第二位是 机构类别代码
第三位到第八位是 登记管理机关行政区域码
第九位到第十七位 主体标识码(组织机构代码)
第十八位 校验码
校验码按下列公式计算:
C18 = 31 - MOD ( ∑Ci * Wi ,31) (1)
MOD 表示求余函数;
i 表示代码字符从左到右位置序号;
Ci 表示第i位置上的代码字符的值,采用附录A“代码字符集”所列字符;
C18 表示校验码;
Wi 表示第i位置上的加权因子,其数值如下表:
i 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
Wi 1 3 9 27 19 26 16 17 20 29 25 13 8 24 10 30 28
当MOD函数值为0(即 C18 = 31)时,校验码用数字0表示。
*/
header('Content-type:text/html;charset=utf-8');
$lenght = 18;//长度
$test = '0123456789ABCDEFGHJKLMNPQRTUWXY';//可以出现的字符
$notest = 'IOZSV';//不会出现的字符
require './demo.php';//区域码
function check_group($str) {
$one = '159Y';//第一位可以出现的字符
$two = '12391';//第二位可以出现的字符
$str = strtoupper($str);
if(!strstr($one,$str['1']) && !strstr($two,$str['2']) && !empty($array[substr($str,2,6)])){
echo '错误';
exit;
}
$wi = array(1,3,9,27,19,26,16,17,20,29,25,13,8,24,10,30,28);//加权因子数值
$str_organization = substr($str,0,17);
$num =0;
for ($i=0; $i <17; $i++) {
$num +=transformation($str_organization[$i])*$wi[$i];
}
switch ($num%31) {
case '0':
$result = 0;
break;
default:
$result = 31-$num%31;
break;
}
if(substr($str,-1,1) == transformation($result,true)){
return '通过';
}else{
return '统一社会信用代码有误';
}
}
function transformation($num,$status=false){
$list =array(0,1,2,3,4,5,6,7,8,9,'A'=>10,'B'=>11,'C'=>12,'D'=>13,'E'=>14,'F'=>15,'G'=>16,'H'=>17,'J'=>18,'K'=>19,'L'=>20,'M'=>21,'N'=>22,'P'=>23,'Q'=>24,'R'=>25,'T'=>26,'U'=>27,'W'=>28,'X'=>29,'Y'=>30);//值转换
if($status == true){
$list = array_flip($list);
}
return $list[$num];
}
// $str = '911101083180403603';
// $str = '91350100M000100Y45';
// $str = '911101083180403603';
$str = '52440111MJK9980480';
// $str = '53330000MJ8741013R';
echo check_group($str);
// var_dump($str);
java、正则表达式、php校验“统一社会信用代码”相关推荐
- JS校验统一社会信用代码的真实性
统一代码的构成 结构 代码及说明 统一社会信用代码来源字符与数值对应关系表 统一社会信用代码相应顺序上对应的加权因子 计算示例 js代码实现 统一社会信用代码:每一个法人和其他组织在全国范围内唯一的. ...
- 前端校验统一社会信用代码
统一社会信用代码规则 由18位的阿拉伯数字或大写英文字母(不使用I.O.Z.S.V)组成: 第1位~第2位.第9位~第18位 [0-9A-HJ-NP-RT-UW-Y] 第3位~第8位,由阿拉伯数字表示 ...
- JAVA生成统一社会信用代码和组织机构代码
统一社会信用代码规则如下: 代码如下: 引入jar包下载:https://mvnrepository.com/artifact/cn.hutool/hutool-all/5.8.3 package c ...
- Python实现统一社会信用代码校验(GB32100-2015)
Python实现统一社会信用代码校验 统一社会信用代码国标校验 统一社会信用代码国标校验规则 示例说明 Python代码实现(仅实现GB- 32100-2015中的规则) 统一社会信用代码国标校验 ...
- 身份证号与统一社会信用代码的校验
身份证号与统一社会信用代码的表单校验 一.校验身份证号 <el-form ref="form" :model="form" :rules="ru ...
- 统一社会信用代码(营业执照)和组织机构代码校验规则
import org.springframework.util.StringUtils; import java.util.ArrayList; import java.util.List; impo ...
- JAVA 身份证校验与统一社会信用代码校验
B话少说,上代码 原理默认大家都懂了,不懂的话可以百度一下 package com.microlinktech.rns.util;import lombok.Getter; import lombok ...
- 组织机构代码和统一社会信用代码校验规则以及java校验工具类
组织机构代码 编码规则编辑 1.全国组织机构代码由八位数字(或大写拉丁字母)本体代码和一位数字(或大写拉丁字母)校验码组成. 本体代码采用系列(即分区段)顺序编码方法. 校验码按照以下公式计算: C9 ...
- 使用Java校验【统一社会信用代码】真假
统一社会信用代码校验规则: 定义一个方法判断统一社会信用代码真假: /*** 验证机构代码真假** @param orgCode 组织机构信用代码* @return 真返回true 假返回false* ...
最新文章
- 如何定位EXC_BAD_ACCESS错误 (info malloc-history)
- 北大燕博南:下一代AI芯片— 存内计算的硬核与软着陆 | 报告详解
- javapanel根据内部组件_java gui中怎么用jpanel实现组件的绝对定位
- 其他测试用例设计方法-错误推测法与正交实验法
- 我的Android进阶之旅------解决:debug-stripped.ap_' specified for property 'resourceFile' does not exist....
- [UWP]了解模板化控件(8):ItemsControl
- 单主机多git账户多rsa密钥+根据私钥生成公钥+knownhosts+.git/config相关配置
- 获取csdn 积分和c币方法指南
- 在英文论文写作中,什么时候该用斜体?
- Getx - 如何使用路由管理页面
- JAVA 115个面试题及个人部分衍生疑问?
- 卡特加特数字家庭又爆重磅合作!厦门火炬创投莅临卡特加特考察
- SAP 移动价(V)与标准价(S)
- 长时间 正在加载个人设置 开机很慢
- opencv实现视频实时去雾算法
- 网络天才网页中文版_akinator中文版在线玩
- span之间的空隙怎样解决?
- 【Ubuntu 1】ubuntu的软件包
- TEC1401.Report开发技术总结 - 第九章 使用BI Publisher开发报表-使用BI Publisher创建RTF模板的语法(4/5)
- 2021中国留学白皮书——附下载链接