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校验“统一社会信用代码”相关推荐

  1. JS校验统一社会信用代码的真实性

    统一代码的构成 结构 代码及说明 统一社会信用代码来源字符与数值对应关系表 统一社会信用代码相应顺序上对应的加权因子 计算示例 js代码实现 统一社会信用代码:每一个法人和其他组织在全国范围内唯一的. ...

  2. 前端校验统一社会信用代码

    统一社会信用代码规则 由18位的阿拉伯数字或大写英文字母(不使用I.O.Z.S.V)组成: 第1位~第2位.第9位~第18位 [0-9A-HJ-NP-RT-UW-Y] 第3位~第8位,由阿拉伯数字表示 ...

  3. JAVA生成统一社会信用代码和组织机构代码

    统一社会信用代码规则如下: 代码如下: 引入jar包下载:https://mvnrepository.com/artifact/cn.hutool/hutool-all/5.8.3 package c ...

  4. Python实现统一社会信用代码校验(GB32100-2015)

    Python实现统一社会信用代码校验 统一社会信用代码国标校验 统一社会信用代码国标校验规则 示例说明 Python代码实现(仅实现GB- 32100-2015中的规则) 统一社会信用代码国标校验   ...

  5. 身份证号与统一社会信用代码的校验

    身份证号与统一社会信用代码的表单校验 一.校验身份证号 <el-form ref="form" :model="form" :rules="ru ...

  6. 统一社会信用代码(营业执照)和组织机构代码校验规则

    import org.springframework.util.StringUtils; import java.util.ArrayList; import java.util.List; impo ...

  7. JAVA 身份证校验与统一社会信用代码校验

    B话少说,上代码 原理默认大家都懂了,不懂的话可以百度一下 package com.microlinktech.rns.util;import lombok.Getter; import lombok ...

  8. 组织机构代码和统一社会信用代码校验规则以及java校验工具类

    组织机构代码 编码规则编辑 1.全国组织机构代码由八位数字(或大写拉丁字母)本体代码和一位数字(或大写拉丁字母)校验码组成. 本体代码采用系列(即分区段)顺序编码方法. 校验码按照以下公式计算: C9 ...

  9. 使用Java校验【统一社会信用代码】真假

    统一社会信用代码校验规则: 定义一个方法判断统一社会信用代码真假: /*** 验证机构代码真假** @param orgCode 组织机构信用代码* @return 真返回true 假返回false* ...

最新文章

  1. 如何定位EXC_BAD_ACCESS错误 (info malloc-history)
  2. 北大燕博南:下一代AI芯片— 存内计算的硬核与软着陆 | 报告详解
  3. javapanel根据内部组件_java gui中怎么用jpanel实现组件的绝对定位
  4. 其他测试用例设计方法-错误推测法与正交实验法
  5. 我的Android进阶之旅------解决:debug-stripped.ap_' specified for property 'resourceFile' does not exist....
  6. [UWP]了解模板化控件(8):ItemsControl
  7. 单主机多git账户多rsa密钥+根据私钥生成公钥+knownhosts+.git/config相关配置
  8. 获取csdn 积分和c币方法指南
  9. 在英文论文写作中,什么时候该用斜体?
  10. Getx - 如何使用路由管理页面
  11. JAVA 115个面试题及个人部分衍生疑问?
  12. 卡特加特数字家庭又爆重磅合作!厦门火炬创投莅临卡特加特考察
  13. SAP 移动价(V)与标准价(S)
  14. 长时间 正在加载个人设置 开机很慢
  15. opencv实现视频实时去雾算法
  16. 网络天才网页中文版_akinator中文版在线玩
  17. span之间的空隙怎样解决?
  18. 【Ubuntu 1】ubuntu的软件包
  19. TEC1401.Report开发技术总结 - 第九章 使用BI Publisher开发报表-使用BI Publisher创建RTF模板的语法(4/5)
  20. 2021中国留学白皮书——附下载链接

热门文章

  1. Ubuntu 18.04 系统安装
  2. mysql 数据割接_数据割接笔记
  3. 互联网+5G,开创评标管理新模式
  4. 深入浅出CenterFusion
  5. 知识库平台功能结构分析
  6. 过滤请求绝技 !布隆过滤器与布谷鸟过滤器
  7. java.lang.NoClassDefFoundError: com.google.gson.Gson
  8. 完全解密企业信息安全风险评估
  9. unity3D游戏开发十五之NGUI二
  10. springboot国际化配置中英文切换