Maison  >  Article  >  php教程  >  php版的三证合一统一社会信用代码制作

php版的三证合一统一社会信用代码制作

PHP中文网
PHP中文网original
2016-05-22 18:26:592901parcourir

          

<?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(&#39;Content-type:text/html;charset=utf-8&#39;);
$lenght = 18;//长度
$text = &#39;0123456789ABCDEFGHJKLMNPQRTUWXY&#39;;//可以出现的字符
$notext = &#39;IOZSV&#39;;//不会出现的字符
require &#39;./demo.php&#39;;//区域码
function check_group($str) {
	$one = &#39;159Y&#39;;//第一位可以出现的字符
	$two = &#39;12391&#39;;//第二位可以出现的字符
	$str = strtoupper($str);
	if(!strstr($one,$str[&#39;0&#39;]) || !strstr($two,$str[&#39;1&#39;]) || !empty($array[substr($str,2,6)])){
		echo &#39;错误&#39;;
		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; $i10,&#39;B&#39;=>11,&#39;C&#39;=>12,&#39;D&#39;=>13,&#39;E&#39;=>14,&#39;F&#39;=>15,&#39;G&#39;=>16,&#39;H&#39;=>17,&#39;J&#39;=>18,&#39;K&#39;=>19,&#39;L&#39;=>20,&#39;M&#39;=>21,&#39;N&#39;=>22,&#39;P&#39;=>23,&#39;Q&#39;=>24,&#39;R&#39;=>25,&#39;T&#39;=>26,&#39;U&#39;=>27,&#39;W&#39;=>28,&#39;X&#39;=>29,&#39;Y&#39;=>30);//值转换
	if($status == true){
		$list = array_flip($list);//翻转key/value
	}
	return $list[$num];
}
// $str = &#39;911101083180403603&#39;;
// $str = &#39;91350100M000100Y45&#39;;
// $str = &#39;911101083180403603&#39;;
$str = &#39;52440111MJK9980480&#39;;
// $str = &#39;53330000MJ8741013R&#39;;
echo check_group($str);
// var_dump($str);


                           

       

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn