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);