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

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

PHP中文网
PHP中文网Original
2016-05-22 18:26:592901browse

          

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


                           

       

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn