ホームページ >バックエンド開発 >PHPチュートリアル >検証コードのクラッキングとクラッキング防止のアイデア

検証コードのクラッキングとクラッキング防止のアイデア

WBOY
WBOYオリジナル
2016-07-25 08:51:051634ブラウズ
PHP を使用して検証コードを解読する方法は 1 つだけあり、それは、検証コードに含まれる文字の署名を収集し、検証コード内の文字を分離する方法を見つけることです。どのような人工知能かというと、明らかに PHP にはできないので、検証コードに含まれる文字の署名をすべて収集し、検証コード内の文字を分離する方法を見つけることができれば、解読することができます。
クラッキング対策のアイデアは主にこれら 2 つのステップを中心に展開し、中国語などのより多くの文字を使用し、より多くのフォントと変形を使用して、同じ文字に複数の特徴コードがあるか、固定の特徴コードが存在しないようにします。文字の分離の難易度が高くなります。検証コード内で不確実な位置、サイズ、間隔で表示される文字が影響を与える可能性があります。
以下では、特定のWebサイトの確認コードを例として、上記の2つの手順で確認コードを解読する方法を説明します。
注: コードの一部は phper "Baba" からのものです。特別に感謝します。
  1. /* 数値を並べ替えて 2 番目に多い要素を見つけます。最初にある要素は背景色で、2 番目に多い要素は文字の色です。つまり、各文字の場合。全部違う色を使っている、または背景の色が単調ではない 文字の色を分けるにはどうしたらよいでしょうか? */
  2. function getMostRepeated($array){
  3. $count = array_count_values($array);
  4. arsort($count);
  5. $keys = array_keys($count);
  6. return $keys[1];
  7. }
  8. / * 検証コード画像を読み取り、ピクセル RGB を 2 次元配列に読み取り、有効な文字を分離します */
  9. function fixImg($url){
  10. $img = imagecreatefrompng($url);
  11. $with = imagex ($ img);
  12. $height = imagey($img);
  13. $middle = $height / 2;
  14. $colors = array();
  15. for ($i = 0; $i < $with; + +$ i) {
  16. $color = imagecolorat($img, $i, $middle);// 中心線のピクセルカラーを読み取ると、中心線が確実に文字に食い込みます。 。 。
  17. $colors[] = $color;
  18. }
  19. $mainColor = getMostRepeated($colors);//文字色を分離
  20. $pic = array();
  21. for ($x = 0; $x < $ with; ++$x) {
  22. $flag = true;
  23. for ($y = 0; $y < $height; ++$y) {
  24. $currentColor = imagecolorat($img, $x, $y) ;
  25. $pos = 0;// 元の画像は文字分離を容易にするために斜体になっているため、斜体を使用しても意味がありません。 。 。
  26. if($y < 16){
  27. $pos = 0;
  28. }elseif($y >= 16 && $y $pos = 1;
  29. $pic[$y][0 ] = 0;
  30. }elseif($y >= 21 && $y $pos = 2;
  31. $pic[$y][0] = $pic[$y][1] = 0;
  32. }else{
  33. $pos = 3;
  34. $pic[$y][0] = $pic[$y][1] = $pic[$y][2] = 0;
  35. }
  36. //干渉ピクセルと文字の色はまったく異なるため、文字の色を分離して文字のピクセル ポイントを 1 に設定するのは簡単です。したがって、干渉ピクセルの少なくとも一部の色は文字の色と同じでなければなりません。
  37. if ($currentColor !== $mainColor) {
  38. $pic[$y][$x+$pos] = 0;
  39. }else{
  40. $pic[$y][$x+$pos] = 1;
  41. $ flag = false;
  42. }
  43. }
  44. }
  45. return $pic;
  46. }
  47. // 伝説の機能コード
  48. $char = array(
  49. 'A'=>'00000000000000000001000000000000000000101100000000000000011111000000000000001110100000 0000001111100000000000000111110000000000001011100110000000000111110000110000000001110100000110000000111100000000110000 11110000001100000001111111100011000000000001111111011000000000000011111100000000000000001111111000000000000000011 000000000001111111000000000000000000111000000000000000000110',
  50. 'B'=>'11111111111111111111011111111111111 111111111111110110000000110000000110110000000110000000110110000000110000000110110000001110000000110111000011 11100000011011 11111110011000111100111111000111111100001110 100000000000000111101000',
  51. 'C'=>'000001011110 000000000000011111111111100000001111111111100000011101000011111110000111000000000000111000110000000000000011000110000 000000001110110000000000000001110110000000000000000110110000000000000000110110000000000000000011011000000000000000011011 0000000000000110110000000000000001100011000000000000001100011000000000000011000',
  52. 'D '=>'1111111111111111111101111111 111111111111011111111111111111110110000000000000000110110000000000000000110110000000000000000110110000000000000000110110 0000000000000001101100000000000000001101100000000000000001101 1100000000000000111001100000000000001110001111000000000011100 00111100000000111100000011111111111111000000011111111111100000000000011111110000000',
  53. 'E'=>'1111111111111111111101 1111111111111111110111111111111111111011000000011000000011 01100000001100000001101100000001100000001101100000001100000001 10110000000110000000110110000000110000000110110000000110000000110110000000000000000110000000000000000000110',
  54. 'F'=> '111111111111111111011111111111111111101111111111111111111011000000011000000000011000000011000000000011000000011000000 0000110000000110000000000110000000110000000000110000000110000000000110000000110000000000110000000000000000000',
  55. 'G'=&g t;'00000101111000000000000001111111111110000000111111111111100000011101000011111110000111000000000000111000110000000000 00001100011000000000000011101100000000000000111011000000000 00000001101100000000000000001101100000000000000001101100000000 00000000110110000000000000000110110000000001111111110011000000001111111100011000000001111111100'、
  56. 'H'=>'1111111111111111111011111111111111111110111111111111111111100000000001100000000000000000001100000000000000000 001100000000000000000011000000000000000000110000000000000000000110000000000000000000110000000000000000001100000000000000 0000011000000000000000000011000000000011111111111111111110111111111111111111011111111111111111110 ',
  57. 'I'=>'11111 11111111111111011111111111111111110111111111111111111110',
  58. 'J'=>'11111111111111111111111111111111111111111111111 111111111111110',
  59. 'K'=>'111111111111111111110111111111111111111101111111111111111111100000000001100000000000000000 0111000000000000000001101100000000000000111100111000000000001111000111100000000011110000011110000000111000000000111000001 1100000000000111000111000000000000011100110000000000000001110100000000000000000110000000000000000000010',
  60. 'L'=> '111111111111111111101111111111111111111011111111111111111110000000000000000000110000000000000000000110000000000000000 0001100000000000000000001100000000000000000001100000000000000000001100000000000000000001100000000000000000001100000000000 00000000110',
  61. 'M' =>'111111111111111111110111111111111111111011111100000000000000011111100000000000000000111111110000 00000000000011111 1000000000000000011111100000000000000001111100000000000000001111110000000000000000011110000000000000011 1110000000000 001011100000000000000111110000000000001111101000000000000111000000000000001110000000000000000011111111111 111110111 111111111111111101111111111111111110',
  62. 'N'=>'11111111110111111111111111111011111000000000000000011111 000000000011110000000000000000001110000000000000000 00111100000000000000000111100000000000000000001110000000000001 1100000000000000000111110000000000000001111100000000000000000111000000000000000000000111101111111111111111111 111111111110',
  63. 'O'=>'0000010111100000000000000 1111111111000000001111111111100000011101000000111110000 00111000110000000000000110001100000000000000111 01100000000000000001101100000000000000001101100000000000000001 000000001101100000000000000001101110000000000000001100110000000000000111000111100000000000111100001111000000001111000000111 11111111111000000001111111110000000000011111 1110000000',
  64. 'P'=>'111111111111111111011111111111111111 1110111111111111111101100000000110000000011000 0000001100000000110000 00000110000000011000000011100 00000001111000011100000000000111111110000000000001111111000000000000000111110000000000000',
  65. 'Q'=>'000001011110000000000000011111111111100000000111111111111100000011101000011111110000111000000000000111000110000 00000000001100010000000000000011101100000000000000011011000 00000000000001101100000000000000001101100000000000000001101100 00000000000000110111000000000000000111011000000000000001111101111000000000011110100111100000000111100100011111111111111000 00000011111111100000000000011111110000000',
  66. 'R'=>'11111 111111111111110111111111111111111101111111111111111111011 0000000110000000000110000000110000000000110000000110000000000110000000110000000000110000001111100000000111001011101111000 000111111111001111110000011111110000111100000011101100000001 111000000000000000000011100000000000000000111000000000000000 000010',
  67. 'S'=>'00011100000000000100000111110000000001100 011111111000000001100011000111100000000110110000011110000000 110110000001110000000110110000001110000000110110000000111000000110110000000011100011100111000000011111111000110000000011 1111100000000000001111100000',
  68. 'T'=>'110000000000000000 001100000000000000000001100000000000000000001100000000000000 000001100000000000000000001100000000000000000001100000000000000000001111111111111111111011111111111111111111011111111111 111111110110000000000000000000110000000000000000000110000000 00000000000011000000000000000000011000000000000000000011000000 0000000000000110000000000000000000',
  69. 'T '=> '110000000000000000000110000000000000000000110000000000000000000110000000000000000000110000000000000000000110000000000000 0000001111111111111111111011111111111111111110111111111111111111101100000000000000000001100000000000000000001100000000 00000000000110000000000000000000110000000000000000000110000000000000000000110000000000000000000',//vttimet左边会被侵犯一列
  70. ' U'=>'111111111111111110000111111111111111100001111111111111111110000000000000000000110000000000000000000111000000000 0000000000110000000000000000000110000000000000000000110000000000000000000110000000000000000000110000000000000000001100000 00000000000011110011111111111111111000111111111111111000000',
  71. 'V'=>'1111000000000000000001111110000000000000001111 11111000000000000000001111110000000000000000111111100000000000000000111111100000000000000011111100000000000000000111111 000000000000000001111000000000000000111110000000000010111101 0000000000001111100000000000010111110000000000001111100000000 0000001110100000000000000111100000000000000000',//少读一列
  72. 'W'=>' 111111000000000000000111111111000000000000111111111110000000000000000111111111110000000000001111111110000000000000001111111110000000000000000111110000000000000011111110000000001111111001000000011111111100000000011111110000000000000111111000000000000000111111000000000000000111111111110000000000000000111111111110000000000011111111111000000000000001111111110000000000000000111110000000000000011111110000000001111111001000000011111111100000000001111111000000000000111110100000000000000',
  73. 'X'=>'000000000000000000010110000000000000000110111100000000000011100111111000000000111000001111000000001100000000011110000011000000000000111110110000000000000111111100000000000000001111000000000000000001111100000000000001111001111000000000011110001111110000000111100000011110000001110000000000111100011100000000000001110110000000000000001110100000000000000000010',
  74. 'Y'=>'110000000000000000000111100000000000000000111111000000000000000001111000000000000000000011111000000000000000000111110000000000000000111111111111110000000000111111111110000000001111111111110000000011100000000000000001111000000000000000111100000000000000001110000000000000000011100000000000000000110000000000000000000100000000000000000000',
  75. 'Z'=>'000000000000000000110110000000000000011110110000000000001111110110000000000011111110110000000000111100110110000000011110000110110000000111100000110110000011111000000110110001111100000000110110011111000000000110110111100000000000110111110000000000000110111100000000000000110111000000000000000110',
  76. '0'=>'000001011110100000000000111111111111110000001111111101111110000011100000000000011100011000000000000001100110000000000000001110110000000000000000110110000000000000000110110000000000000000110111000000000000011100011111000000000111100001111111110111111000000011111111111100000000000111111110000000',
  77. '1 '=>'001100000000000000110001100000000000000110011000000000000000110011000000000000000110011111111111111111110011111111 11111111111011111111111111111110000000000000000000110000000000000000000110000000000000000000110000000000000000000110',
  78. '2'=>'00000000000000000011000110000000000011110011000011111001100000000000110111011000000000001100011011000 0000000111000110110000000001110000110110000000011100000110111000000111000000110111100001111000000110011111111100000000110 001111111000000000110000111110000000000110'、
  79. '3'=>'0110000000000000011000100000000000000011001100000001100000001101100000001100000001101100000001100000001101100000 0011000000011011000000111000000011011100001101100000111011111111101100001110001111111000111111110000111010000111111100000 0000000000111101000',
  80. '4'=>'00000000000011000000000000000 001111000000000000000011111000000000000000110011000000000000 1111000110000000000011110000110000000000111100000110000000001110000000110000000011100000000110000000111111111111111111110 11111111111111111111011111111111111111110000000000000110000000000000000000110000000000000000000110000000',
  81. '5'=>'1 111111110000000011001111111100000000111011000001100000000011 01100000110000000001101100000110000000001101100000110000000001 1011000000110000000011011000000111000000111011000000111000011110011000000011111111110011000000001111111100011000000000111 1100000',
  82. '6'=>'000001011110111000000000011111111111110000001111111111111111000001110100101000011100011000001100000 0011000110000010000000011101100000110000000001101100000110000 00000110110000011000000000110110000011100000000110110000011110 000011100111000001111111111100011000000111111111000000000000001111000000',
  83. '7'=> '11000000000000000000011000000000000000001011000000000000011111011000000000001111110110000000000111111100110000000011111 0000001100000011111000000001100000111010000000001100011110000 00000000110111110000000000000111110000000000000000111100000000 000000000111000000000000000000',
  84. '8'=>'000000000000011110 00000011100000011111100000111111001111111110001111111111100 0011000110001111110000011101100000111000000001101100000111100 0000011011000000111000000011011000000111100000011011100101111 000000110111111110011100011100011111110001111111100001110100 001111111000000000000000111100000',
  85. '9'=>'000011111100000 00000000111111110000001100001111111100000011000111000001110 00000110111000000011100000110110000000001100000110110000000001 1000001101100000000011000001101100000000011000011001110000000110000111000111110001110011110000011111111111111110000001111 11111111000000000000111111110000000',
  86. );
  87. $arr = fixImg("https://xxxxxxxxxx");// 哦、这里ある社の領域名とテストコード地址を去って、https、你のphp環境をサポートするために开启openssl
  88. for($i = 0;$i unset($arr[$i]);// 前の 10 行は空白です
  89. $y = 0;// 採用上から下、左から右顺序读機能、从第0行開始(实际は第 10 行)
  90. $len = 31;// 多读一行、JQ 超过 20 行、および J 後面行が上文字の位置を占有する
  91. $code = array();// 分离結果的字特征码
  92. $str = '';
  93. while($y < count($arr[10])){
  94. $flag = true;// 全0は空白竖線
  95. $line = '';
  96. for($i = 10;$i < $len;$i++){
  97. if($arr[$i][$y])
  98. $flag = false;
  99. $line .= $arr[$i] [$y];
  100. }
  101. $isw = false;
  102. $isy = false;
  103. // 对vwの特殊処理
  104. if($str === $char['V'] || $str === $ char['W']){
  105. $flag = true;
  106. $isw = true;
  107. }elseif($str === $char['Y'] || $str === $char['A'] ){
  108. $isy = true;
  109. $flag = true;
  110. }
  111. if($flag){
  112. if(strlen($str) > 21)
  113. $code[] = $str;
  114. $str = ' ';
  115. }else{
  116. $str .= $line;
  117. }
  118. if($isw){
  119. $str = '00'.substr($line,2,strlen($line));
  120. if($str === '000000000000000000000')
  121. $str = '';
  122. $isw = false;
  123. }
  124. if($isy){
  125. $str = $line;
  126. if($str === '000000000000000000000')
  127. $ str = '';
  128. $isy = false;
  129. }
  130. $y++;
  131. }
  132. // 出字符
  133. foreach($code as $v){
  134. $match = false;
  135. foreach($char as $key => $v2){
  136. if($v === $v2){
  137. echo $key;
  138. $match = true;
  139. }
  140. }
  141. if(!$match)
  142. echo '?';//一致する文字符出问号
  143. }
复制定


声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。