찾다

PHP QR 코드 생성

Aug 08, 2016 am 09:32 AM
arraygtpublicreturnthis

QR 코드를 생성하는 방법에는 여러 가지가 있으며, 가장 빠른 방법은 Google API를 사용하는 것입니다. 구글이 차단되어 잘 작동하지 않는 경우가 많아 안타깝습니다. 이제 좀 더 유용한 방법에 대해 이야기해 보겠습니다.

자세한 문서와 코드를 보려면 http://phpqrcode.sourceforge.net/을 방문하세요.

다음은 작성된 정보를 기반으로 자동으로 QR 코드를 생성하는 단순화된 버전입니다. 그리고 지정된 디렉토리에 저장합니다.

기본 프로그램 코드

		<?php include "./phpqrcode/qrcode.php";   //导入主文件 
	    $PNG_TEMP_DIR = dirname(__FILE__).DIRECTORY_SEPARATOR.&#39;qrcode&#39;.DIRECTORY_SEPARATOR;//文件保存目录
    	$PNG_WEB_DIR = &#39;qrcode/&#39;;//用于预览
    	if (!file_exists($PNG_TEMP_DIR))
        	mkdir($PNG_TEMP_DIR);
        $data = "test";//二维码写入内容
        
        $errorCorrectionLevel = &#39;L&#39;;//错误处理级别
        
        $matrixPointSize = 6;//二维码尺寸大小
        //md5加密生成文件名,data可以使用数据库id或者其他唯一标识符
        $filename = $PNG_TEMP_DIR.md5($data.&#39;|&#39;.$errorCorrectionLevel.&#39;|&#39;.$matrixPointSize).&#39;.png&#39;;
        //使用QRcode类生成二维码,文件保存在PNG_TEMP_DIR下
        QRcode::png($data, $filename, $errorCorrectionLevel, $matrixPointSize, 2); 
        //图片预览
         echo &#39;<img  src="/static/imghwm/default1.png"  data-src="&#39;.$PNG_WEB_DIR.basename($filename).&#39;"  class="lazy" / alt="PHP QR 코드 생성" ><hr>';  
        ?>

첨부 파일을 추가할 수 없어 다음 코드를 붙여넣어야 합니다. . . 다음의 긴 코드를 새 파일에 복사하고 이름을 qrcode.php로 지정하세요. 위 코드를 실행하여 QR 코드를 생성하세요. . . .

생성된 QR 코드 2개 게시


php 클래스 파일(http://phpqrcode.sourceforge.net /에서)

<?php /*
 * PHP QR 코드 인코더
 *
 * 이 파일에는 PHP QR 코드 라이브러리의 MERGED 버전이 포함되어 있습니다.
 * 귀하의 편의를 위해 정식 버전에서 자동 생성되었습니다.
 *
 * 이 병합 버전은 외부 파일이 필요하지 않도록 구성되었으며,
 * 비활성화된 캐시, 오류 로깅 및 더 약하지만 더 빠른 마스크 일치.
 * 튜닝이 필요한 경우 병합되지 않은 버전을 사용하세요.
 *
 * 정식 버전, 문서, 사용 예를 보려면 다음 사이트를 방문하세요.
 *
 * http://phpqrcode.sourceforge.net/
 * https://sourceforge.net/projects/phpqrcode/
 *
 * PHP QR 코드는 LGPL 3에 따라 배포됩니다.
 * Copyright (C) 2010 Dominik Dzienia <deltalab at poczta dot fm>
 *
 * 이 라이브러리는 무료 소프트웨어입니다. 재배포할 수 있으며/또는
 * GNU Lesser General Public의 조건에 따라 수정합니다.
 * 자유 소프트웨어 재단(Free Software Foundation)이 게시한 라이센스입니다. 어느 하나
 * 라이센스 버전 3 또는 이후 버전.
 *
 * 본 라이브러리는 유용하게 활용되길 바라는 마음으로 배포되며,
 * 그러나 어떠한 보증도 제공되지 않습니다. 묵시적인 보증조차 없이
 * 특정 목적에 대한 상품성 또는 적합성. GNU 보기
 * 자세한 내용은 약소 일반 공중 라이선스를 참조하세요.
 *
 * 당신은 GNU Lesser General Public의 사본을 받았어야 합니다.
 * 이 라이브러리와 함께 라이센스를 받습니다. 그렇지 않다면 자유 소프트웨어에 쓰십시오.
 * Foundation, Inc., 51 Franklin St, 5층, Boston, MA 02110-1301 USA
 */
 
 

/*
 * 버전: 1.1.4
 * 빌드: 2010100721
 */



//---- qrconst.php ----------------





/*
 * PHP QR 코드 인코더
 *
 * 공통 상수
 *
 * LGPL 2.1에 배포되는 libqrencode C 라이브러리 기반
 * 저작권(C) 2006, 2007, 2008, 2009 후쿠치 켄타로 <fukuchi>
 *
 * PHP QR 코드는 LGPL 3에 따라 배포됩니다.
 * Copyright (C) 2010 Dominik Dzienia <deltalab at poczta dot fm>
 *
 * 이 라이브러리는 무료 소프트웨어입니다. 재배포할 수 있으며/또는
 * GNU Lesser General Public의 조건에 따라 수정합니다.
 * 자유 소프트웨어 재단(Free Software Foundation)이 게시한 라이센스입니다. 어느 하나
 * 라이센스 버전 3 또는 이후 버전.
 *
 * 본 라이브러리는 유용하게 활용되길 바라는 마음으로 배포되며,
 * 그러나 어떠한 보증도 제공되지 않습니다. 묵시적인 보증도 없이
 * 특정 목적에 대한 상품성 또는 적합성. GNU 보기
 * 자세한 내용은 약소 일반 공중 라이선스를 참조하세요.
 *
 * 당신은 GNU Lesser General Public의 사본을 받았어야 합니다.
 * 이 라이브러리와 함께 라이센스를 받습니다. 그렇지 않다면 자유 소프트웨어에 쓰십시오.
 * Foundation, Inc., 51 Franklin St, 5층, Boston, MA 02110-1301 USA
 */
 
	// 인코딩 모드
	 
	정의('QR_MODE_NUL', -1);
	정의('QR_MODE_NUM', 0);
	정의('QR_MODE_AN', 1);
	정의('QR_MODE_8', 2);
	정의('QR_MODE_KANJI', 3);
	정의('QR_MODE_STRUCTURE', 4);

	// 오류 수정 수준.

	정의('QR_ECLEVEL_L', 0);
	정의('QR_ECLEVEL_M', 1);
	정의('QR_ECLEVEL_Q', 2);
	정의('QR_ECLEVEL_H', 3);
	
	// 지원되는 출력 형식
	
	정의('QR_FORMAT_TEXT', 0);
	정의('QR_FORMAT_PNG', 1);
	
	클래스 qrstr {
		공개 정적 함수 세트(&$srctab, $x, $y, $repl, $replLen = false) {
			$srctab[$y] = substr_replace($srctab[$y], ($replLen !== false)?substr($repl,0,$replLen):$repl, $x, ($replLen !== false) ?$replLen:strlen($repl));
		}
	}//---- merged_config.php ----------------




/*
 * PHP QR 코드 인코더
 *
 * 구성 파일, 병합된 버전에 맞게 조정됨
 */
     
    정의('QR_CACHEABLE', false);       // 캐시 사용 - 더 많은 디스크 읽기가 이루어지지만 CPU 성능, 마스크 및 형식 템플릿이 저장됩니다.
    정의('QR_CACHE_DIR', false);       // QR_CACHEABLE === true일 때 사용됩니다.
    정의('QR_LOG_DIR', false);         // 기본 오류 로그 디렉토리   
    
    정의('QR_FIND_BEST_MASK', 참);                                                          // true인 경우 최상의 마스크를 추정합니다(사양 기본값이지만 매우 느립니다. 상당한 성능 향상을 위해 false로 설정하지만 (아마도) 최악의 품질 코드)
    정의('QR_FIND_FROM_RANDOM', 2);                                                       // false인 경우 사용 가능한 모든 마스크를 확인하고, 그렇지 않은 경우 값은 확인해야 하는 마스크 수를 알려주며 마스크 ID는 무작위로 가져옵니다.
    정의('QR_DEFAULT_MASK', 2);                                                               // QR_FIND_BEST_MASK === false인 경우
                                                  
    정의('QR_PNG_MAXIMUM_SIZE', 1024);                                                       // 허용되는 최대 png 이미지 너비(픽셀 단위), GD와 PHP가 이러한 큰 이미지를 처리할 수 있도록 조정합니다.
                                                  



//---- qrtools.php ----------------




/*
 * PHP QR 코드 인코더
 *
 * 도구 세트, 편리한 디버그 유틸리티.
 *
 * PHP QR 코드는 LGPL 3에 따라 배포됩니다.
 * Copyright (C) 2010 Dominik Dzienia <deltalab at poczta dot fm>
 *
 * 이 라이브러리는 무료 소프트웨어입니다. 재배포할 수 있으며/또는
 * GNU Lesser General Public의 조건에 따라 수정합니다.
 * 자유 소프트웨어 재단(Free Software Foundation)이 게시한 라이센스입니다. 어느 하나
 * 라이센스 버전 3 또는 이후 버전.
 *
 * 본 라이브러리는 유용하게 활용되길 바라는 마음으로 배포되며,
 * 그러나 어떠한 보증도 제공되지 않습니다. 묵시적인 보증도 없이
 * 특정 목적에 대한 상품성 또는 적합성. GNU 보기
 * 자세한 내용은 약소 일반 공중 라이선스를 참조하세요.
 *
 * 당신은 GNU Lesser General Public의 사본을 받았어야 합니다.
 * 이 라이브러리와 함께 라이센스를 받습니다. 그렇지 않다면 자유 소프트웨어에 쓰십시오.
 * Foundation, Inc., 51 Franklin St, 5층, Boston, MA 02110-1301 USA
 */

    클래스 QRtools {
    
        //------------------------------------------------ ---------
        공개 정적 함수 이진화($frame)
        {
            $len = 개수($프레임);
            foreach($frame을 &$frameLine으로) {
                
                for($i=0; $i 1) {
                $ecc레벨 = $모드[1];
            }
                
            $qrTab = QRcode::text($code, false, $eccLevel);
            $size = 개수($qrTab);
                
            $barcode_array['num_rows'] = $size;
            $barcode_array['num_cols'] = $size;
            $barcode_array['bcode'] = 배열();
                
            foreach($qrTab을 $line으로) {
                $arrAdd = 배열();
                foreach(str_split($line)을 $char로)
                    $arrAdd[] = ($char=='1')?1:0;
                $barcode_array['bcode'][] = $arrAdd;
            }
                    
            $barcode_array를 반환합니다.
        }
        
        //------------------------------------------------ ---------
        공개 정적 함수 ClearCache()
        {
            self::$frames = 배열();
        }
        
        //------------------------------------------------ ---------
        공개 정적 함수 buildCache()
        {
			QRtools::markTime('before_build_cache');
			
			$mask = 새로운 QRmask();
            for ($a=1; $a makeMaskNo($maskNo, $width, $frame, $bitMask, true);
            }QRtools::markTime('after_build_cache');
        }

        //------------------------------------------------ ---------
        공개 정적 함수 로그($outfile, $err)
        {
            if (QR_LOG_DIR !== false) {
                if ($err != '') {
                    if ($outfile !== false) {
                        file_put_contents(QR_LOG_DIR.basename($outfile).'-errors.txt', date('Y-m-d H:i:s').': '.$err, FILE_APPEND);
                    } 또 다른 {
                        file_put_contents(QR_LOG_DIR.'errors.txt', date('Y-m-d H:i:s').': '.$err, FILE_APPEND);
                    }
                }    
            }
        }
        
        //------------------------------------------------ ---------
        공개 정적 함수 dumpMask($frame) 
        {
            $너비 = 개수($프레임);
            for($y=0;$y
                    <thead>
<tr style="border-bottom:1px solid silver"><td colspan="2" style="text-align:center">BENCHMARK</td></tr>
                    ';

            foreach($GLOBALS['qr_time_bench'] as $markerId=>$thisTime) {
                if ($p > 0) {
                    echo '<tr>
<th style="text-align:right">till '.$markerId.': </th>
<td>'.number_format($thisTime-$lastTime, 6). 's</td>
</tr>';
                } 또 다른 {
                    $startTime = $thisTime;
                }
                
                $p++;
                $lastTime = $thisTime;
            }
            
            echo '</thead>
<tfoot>
                <tr style="border-top:2px solid black">
<th style="text-align:right">총계: </th>
<td>'.number_format($lastTime-$startTime , 6).'s</td>
</tr>
            </tfoot>
            테이블>';
        }
        
    }//############################################ #########################
    
    QRtools::markTime('시작');
    



//---- qrspec.php ----------------




/*
 * PHP QR 코드 인코더
 *
 * QR코드 사양
 *
 * LGPL 2.1에 배포되는 libqrencode C 라이브러리 기반
 * 저작권(C) 2006, 2007, 2008, 2009 후쿠치 켄타로 <fukuchi>
 *
 * PHP QR 코드는 LGPL 3에 따라 배포됩니다.
 * Copyright (C) 2010 Dominik Dzienia <deltalab at poczta dot fm>
 *
 * 다음 데이터/사양은 다음에서 가져왔습니다.
 * "2차원 기호 - QR 코드 - 기본 사양"(JIS X0510:2004)
 *  또는
 * "자동 식별 및 데이터 캡처 기술 -- 
 * QR Code 2005 바코드 기호 사양"(ISO/IEC 18004:2006)
 *
 * 이 라이브러리는 무료 소프트웨어입니다. 재배포할 수 있으며/또는
 * GNU Lesser General Public의 조건에 따라 수정합니다.
 * 자유 소프트웨어 재단(Free Software Foundation)이 게시한 라이센스입니다. 어느 하나
 * 라이센스 버전 3 또는 이후 버전.
 *
 * 본 라이브러리는 유용하게 활용되길 바라는 마음으로 배포되며,
 * 그러나 어떠한 보증도 제공되지 않습니다. 묵시적인 보증조차 없이
 * 특정 목적에 대한 상품성 또는 적합성. GNU 보기
 * 자세한 내용은 약소 일반 공중 라이선스를 참조하세요.
 *
 * 당신은 GNU Lesser General Public의 사본을 받았어야 합니다.
 * 이 라이브러리와 함께 라이센스를 받습니다. 그렇지 않다면 자유 소프트웨어에 쓰십시오.
 * Foundation, Inc., 51 Franklin St, 5층, Boston, MA 02110-1301 USA
 */
 
    정의('QRSPEC_VERSION_MAX', 40);
    정의('QRSPEC_WIDTH_MAX', 177);

    정의('QRCAP_WIDTH', 0);
    정의('QRCAP_WORDS', 1);
    정의('QRCAP_REMINDER', 2);
    정의('QRCAP_EC', 3);

    클래스 QRspec {
    
        공개 정적 $ 용량 = 배열(
            배열(0, 0, 0, 배열(0, 0, 0, 0)),
            배열( 21, 26, 0, 배열( 7, 10, 13, 17)), // 1
            배열( 25, 44, 7, 배열( 10, 16, 22, 28)),
            배열( 29, 70, 7, 배열( 15, 26, 36, 44)),
            배열( 33, 100, 7, 배열( 20, 36, 52, 64)),
            배열( 37, 134, 7, 배열( 26, 48, 72, 88)), // 5
            배열( 41, 172, 7, 배열( 36, 64, 96, 112)),
            배열(45, 196, 0, 배열(40, 72, 108, 130)),
            배열( 49, 242, 0, 배열( 48, 88, 132, 156)),
            배열( 53, 292, 0, 배열( 60, 110, 160, 192)),
            배열( 57, 346, 0, 배열( 72, 130, 192, 224)), //10
            배열( 61, 404, 0, 배열( 80, 150, 224, 264)),
            배열( 65, 466, 0, 배열( 96, 176, 260, 308)),
            배열( 69, 532, 0, 배열( 104, 198, 288, 352)),
            배열( 73, 581, 3, 배열( 120, 216, 320, 384)),
            배열( 77, 655, 3, 배열( 132, 240, 360, 432)), //15
            배열( 81, 733, 3, 배열( 144, 280, 408, 480)),
            배열( 85, 815, 3, 배열( 168, 308, 448, 532)),
            배열( 89, 901, 3, 배열( 180, 338, 504, 588)),
            배열(93, 991, 3, 배열(196, 364, 546, 650)),
            배열( 97, 1085, 3, 배열( 224, 416, 600, 700)), //20
            배열(101, 1156, 4, 배열(224, 442, 644, 750)),
            배열(105, 1258, 4, 배열(252, 476, 690, 816)),
            배열(109, 1364, 4, 배열(270, 504, 750, 900)),
            배열(113, 1474, 4, 배열(300, 560, 810, 960)),
            배열(117, 1588, 4, 배열( 312, 588, 870, 1050)), //25
            배열(121, 1706, 4, 배열(336, 644, 952, 1110)),
            배열(125, 1828, 4, 배열(360, 700, 1020, 1200)),
            배열(129, 1921, 3, 배열( 390, 728, 1050, 1260)),
            배열(133, 2051, 3, 배열(420, 784, 1140, 1350)),
            배열(137, 2185, 3, 배열( 450, 812, 1200, 1440)), //30
            배열(141, 2323, 3, 배열(480, 868, 1290, 1530)),
            배열(145, 2465, 3, 배열(510, 924, 1350, 1620)),
            배열(149, 2611, 3, 배열(540, 980, 1440, 1710)),
            배열(153, 2761, 3, 배열(570, 1036, 1530, 1800)),
            배열(157, 2876, 0, 배열(570, 1064, 1590, 1890)), //35
            배열(161, 3034, 0, 배열(600, 1120, 1680, 1980)),
            배열(165, 3196, 0, 배열(630, 1204, 1770, 2100)),
            배열(169, 3362, 0, 배열(660, 1260, 1860, 2220)),
            배열(173, 3532, 0, 배열(720, 1316, 1950, 2310)),
            배열(177, 3706, 0, 배열(750, 1372, 2040, 2430)) //40
        );
        
        //------------------------------------------------ ---------
        공개 정적 함수 getDataLength($version, $level)
        {
            return self::$capacity[$version][QRCAP_WORDS] - self::$capacity[$version][QRCAP_EC][$level];
        }//------------------------------------------------ ---------
        공개 정적 함수 getECCLength($version, $level)
        {
            return self::$capacity[$version][QRCAP_EC][$level];
        }
        
        //------------------------------------------------ ---------
        공개 정적 함수 getWidth($version)
        {
            return self::$capacity[$version][QRCAP_WIDTH];
        }
        
        //------------------------------------------------ ---------
        공개 정적 함수 getRemainder($version)
        {
            return self::$capacity[$version][QRCAP_REMINDER];
        }
        
        //------------------------------------------------ ---------
        공개 정적 함수 getMinimumVersion($size, $level)
        {

            for($i=1; $i= $size) 
                    $i를 반환합니다.
            }

            -1을 반환합니다.
        }
    
        //############################################ ######################
        
        공개 정적 $lengthTableBits = 배열(
            배열(10, 12, 14),
            배열(9, 11, 13),
            배열(8, 16, 16),
            배열(8, 10, 12)
        );
        
        //------------------------------------------------ ---------
        공개 정적 함수 길이 표시기($mode, $version)
        {
            if ($mode == QR_MODE_STRUCTURE)
                0을 반환합니다.
                
            if ($version  QRSPEC_VERSION_MAX)
                0을 반환합니다.

            return self::$versionPattern[$version -7];
        }// 형식 정보 --------------------------------- ----
        //tests/test_qrspec.c의 calcFormatInfo를 참조하세요(원본 qrencode c lib)
        
        공개 정적 $formatInfo = 배열(
            배열(0x77c4, 0x72f3, 0x7daa, 0x789d, 0x662f, 0x6318, 0x6c41, 0x6976),
            배열(0x5412, 0x5125, 0x5e7c, 0x5b4b, 0x45f9, 0x40ce, 0x4f97, 0x4aa0),
            배열(0x355f, 0x3068, 0x3f31, 0x3a06, 0x24b4, 0x2183, 0x2eda, 0x2bed),
            배열(0x1689, 0x13be, 0x1ce7, 0x19d0, 0x0762, 0x0255, 0x0d0c, 0x083b)
        );

        공개 정적 함수 getFormatInfo($mask, $level)
        {
            if($mask  7)
                0을 반환합니다.
                
            if($레벨  3)
                0을 반환합니다.                

            return self::$formatInfo[$level][$mask];
        }

        // 액자 ----------------------------------------------- ----------------
        // 초기 프레임의 캐시.
         
        공개 정적 $프레임 = 배열();

        /**------------------------------------- ------------------
         * 파인더 패턴을 넣습니다.
         * @param 프레임
         * @param 너비
         * @param ox,oy 패턴의 왼쪽 위 좌표*/
        공개 정적 함수 putFinderPattern(&$frame, $ox, $oy)
        {
            $파인더 = 배열(
                "xc1xc1xc1xc1xc1xc1xc1",
                "xc1xc0xc0xc0xc0xc0xc1",
                "xc1xc0xc1xc1xc1xc0xc1",
                "xc1xc0xc1xc1xc1xc0xc1",
                "xc1xc0xc1xc1xc1xc0xc1",
                "xc1xc0xc0xc0xc0xc0xc1",
                "xc1xc1xc1xc1xc1xc1xc1"
            );                            
            
            for($y=0; $y= 7) {
                $vinf = self::getVersionPattern($version);

                $v = $vinf;
                
                for($x=0; $x> 1;
                    }
                }

                $v = $vinf;
                for($y=0; $y> 1;
                    }
                }
            }
    
            //그리고 조금...  
            $frame[$width - 8][8] = "x81";
            
            $프레임을 반환합니다.
        }//------------------------------------------------ ---------
        공개 정적 함수 디버그($frame, $binary_mode = false)
        {
            if ($binary_mode) {
            
                    foreach($frame을 &$frameLine으로) {
                        $frameLine = Join('<span class="m">  </span>',explore('0', $frameLine));
                        $frameLine = Join('██', 폭발('1', $frameLine));
                    }
                    
                    ?>
                
                    .m { 배경색: 흰색; }
                스타일>
                <php echo><tt><br><br><br>        ';
                    echo Join("<br>        ", $frame);
                    echo '</tt></php></deltalab></fukuchi></deltalab></deltalab></fukuchi>






'; } 또 다른 { foreach($frame을 &$frameLine으로) { $frameLine = Join(' ',explore("xc0", $frameLine)); $frameLine = Join('?',explore("xc1", $frameLine)); $frameLine = Join(' ',explore("xa0", $frameLine)); $frameLine = Join('?',explore("xa1", $frameLine)); $frameLine = Join('',explore("x84", $frameLine)); //형식 0 $frameLine = Join('',explore("x85", $frameLine)); //형식 1 $frameLine = Join('?',explore("x81", $frameLine)); //특수 비트 $frameLine = Join(' ',explore("x90", $frameLine)); //시계 0 $frameLine = Join('?',explore("x91", $frameLine)); //시계 1 $frameLine = Join(' ',explore("x88", $frameLine)); //버전 $frameLine = Join('?',explore("x89", $frameLine)); //버전 $frameLine = Join('?',Explode("x01", $frameLine)); $frameLine = Join('?',Explode(" ", $frameLine)); } ?> .p { 배경색: 노란색; } .m { 배경색: #00FF00; } .s { 배경색: #FF0000; } .c { 배경색: 아쿠아; } .x { 배경색: 분홍색; } .f { 배경색: 금색; } 스타일> "; echo Join("
", $frame); echo "
"; } } //------------------------------------------------ --------- 공개 정적 함수 직렬($frame) { return gzcompress(join("n", $frame), 9); } //------------------------------------------------ --------- 공개 정적 함수 unserial($code) { returnexplore("n", gzuncompress($code)); }//------------------------------------------------ --------- 공개 정적 함수 newFrame($version) { if($version QRSPEC_VERSION_MAX) null을 반환; if(!isset(self::$frames[$version])) { $fileName = QR_CACHE_DIR.'frame_'.$version.'.dat'; if (QR_CACHEABLE) { if (file_exists($fileName)) { self::$frames[$version] = self::unserial(file_get_contents($fileName)); } 또 다른 { self::$frames[$version] = self::createFrame($version); file_put_contents($fileName, self::serial(self::$frames[$version])); } } 또 다른 { self::$frames[$version] = self::createFrame($version); } } if(is_null(self::$frames[$version])) null을 반환; return self::$frames[$version]; } //------------------------------------------------ --------- 공개 정적 함수 rsBlockNum($spec) { return $spec[0] + $spec[3]; } 공개 정적 함수 rsBlockNum1($spec) { return $spec[0]; } 공개 정적 함수 rsDataCodes1($spec) { return $spec[1]; } 공개 정적 함수 rsEccCodes1($spec) { return $spec[2]; } 공개 정적 함수 rsBlockNum2($spec) { return $spec[3]; } 공개 정적 함수 rsDataCodes2($spec) { return $spec[4]; } 공개 정적 함수 rsEccCodes2($spec) { return $spec[2]; } 공개 정적 함수 rsDataLength($spec) { return ($spec[0] * $spec[1]) + ($spec[3] * $spec[4]); } 공개 정적 함수 rsEccLength($spec) { return ($spec[0] + $spec[3]) * $spec[2]; } } //---- qrimage.php ---------------- /* * PHP QR 코드 인코더 * * GD2를 이용한 코드의 이미지 출력 * * PHP QR 코드는 LGPL 3에 따라 배포됩니다. * Copyright (C) 2010 Dominik Dzienia * * 이 라이브러리는 무료 소프트웨어입니다. 재배포할 수 있으며/또는 * GNU Lesser General Public의 조건에 따라 수정합니다. * 자유 소프트웨어 재단(Free Software Foundation)이 게시한 라이센스입니다. 어느 하나 * 라이센스 버전 3 또는 이후 버전. * * 본 라이브러리는 유용하게 활용되길 바라는 마음으로 배포되며, * 그러나 어떠한 보증도 제공되지 않습니다. 묵시적인 보증조차 없이 * 특정 목적에 대한 상품성 또는 적합성. GNU 보기 * 자세한 내용은 약소 일반 공중 라이선스를 참조하세요. * * 당신은 GNU Lesser General Public의 사본을 받았어야 합니다. * 이 라이브러리와 함께 라이센스를 받습니다. 그렇지 않다면 자유 소프트웨어에 쓰십시오. * Foundation, Inc., 51 Franklin St, 5층, Boston, MA 02110-1301 USA */ 정의('QR_IMAGE', true); 클래스 QRimage { //------------------------------------------------ --------- 공개 정적 함수 png($frame, $filename = false, $pixelPerPoint = 4, $outerFrame = 4,$saveandprint=FALSE) { $image = self::image($frame, $pixelPerPoint, $outerFrame); if ($filename === false) { Header("콘텐츠 유형: 이미지/png"); ImagePng($이미지); } 또 다른 { if($saveandprint===TRUE){ ImagePng($이미지, $파일이름); header("콘텐츠 유형: 이미지/png"); ImagePng($이미지); }또 다른{ ImagePng($이미지, $파일이름); } } ImageDestroy($이미지); } //------------------------------------------------ --------- 공개 정적 함수 jpg($frame, $filename = false, $pixelPerPoint = 8, $outerFrame = 4, $q = 85) { $image = self::image($frame, $pixelPerPoint, $outerFrame); if ($filename === false) { Header("콘텐츠 유형: image/jpeg"); ImageJpeg($image, null, $q); } 또 다른 { ImageJpeg($image, $filename, $q); } ImageDestroy($이미지); }//------------------------------------------------ --------- 개인 정적 함수 이미지($frame, $pixelPerPoint = 4, $outerFrame = 4) { $h = 개수($프레임); $w = strlen($frame[0]); $imgW = $w + 2*$outerFrame; $imgH = $h + 2*$outerFrame; $base_image =이미지 생성($imgW, $imgH); $col[0] = ImageColorAllocate($base_image,255,255,255); $col[1] = ImageColorAllocate($base_image,0,0,0); imagefill($base_image, 0, 0, $col[0]); for($y=0; $y * * PHP QR 코드는 LGPL 3에 따라 배포됩니다. * Copyright (C) 2010 Dominik Dzienia * * 이 라이브러리는 무료 소프트웨어입니다. 재배포할 수 있으며/또는 * GNU Lesser General Public의 조건에 따라 수정합니다. * 자유 소프트웨어 재단(Free Software Foundation)이 게시한 라이센스입니다. 어느 하나 * 라이센스 버전 3 또는 이후 버전. * * 본 라이브러리는 유용하게 활용되길 바라는 마음으로 배포되며, * 그러나 어떠한 보증도 제공되지 않습니다. 묵시적인 보증조차 없이 * 특정 목적에 대한 상품성 또는 적합성. GNU 보기 * 자세한 내용은 약소 일반 공중 라이선스를 참조하세요. * * 당신은 GNU Lesser General Public의 사본을 받았어야 합니다. * 이 라이브러리와 함께 라이센스를 받습니다. 그렇지 않다면 자유 소프트웨어에 쓰십시오. * Foundation, Inc., 51 Franklin St, 5층, Boston, MA 02110-1301 USA */ 정의('STRUCTURE_HEADER_BITS', 20); 정의('MAX_STRUCTURED_SYMBOLS', 16); 클래스 QRinputItem { 공개 $모드; 공개 $ 크기; 공개 $data; 공개 $bstream; 공개 함수 __construct($mode, $size, $data, $bstream = null) { $setData = array_slice($data, 0, $size); if (count($setData) 모드 = $모드; $this->size = $size; $this->data = $setData; $this->bstream = $bstream; } //------------------------------------------------ --------- 공개 함수 encodeModeNum($version) { 노력하다 { $words = (int)($this->size / 3); $bs = 새로운 QRbitstream(); $발 = 0x1; $bs->appendNum(4, $val); $bs->appendNum(QRspec::lengthIndicator(QR_MODE_NUM, $version), $this->size); for($i=0; $idata[$i*3 ]) - ord('0')) * 100; $val += (ord($this->data[$i*3+1]) - ord('0')) * 10; $val += (ord($this->data[$i*3+2]) - ord('0')); $bs->appendNum(10, $val); } if($this->size - $words * 3 == 1) { $val = ord($this->data[$words*3]) - ord('0'); $bs->appendNum(4, $val); } else if($this->size - $words * 3 == 2) { $val = (ord($this->data[$words*3 ]) - ord('0')) * 10; $val += (ord($this->data[$words*3+1]) - ord('0')); $bs->appendNum(7, $val); } $this->bstream = $bs; 0을 반환합니다. } 잡기(예외 $e) { -1을 반환합니다. } }//------------------------------------------------ --------- 공개 함수 encodeModeAn($version) { 노력하다 { $words = (int)($this->size / 2); $bs = 새로운 QRbitstream(); $bs->appendNum(4, 0x02); $bs->appendNum(QRspec::lengthIndicator(QR_MODE_AN, $version), $this->size); for($i=0; $idata[$i*2 ])) * 45; $val += (int)QRinput::lookAnTable(ord($this->data[$i*2+1])); $bs->appendNum(11, $val); } if($this->size & 1) { $val = QRinput::lookAnTable(ord($this->data[$words * 2])); $bs->appendNum(6, $val); } $this->bstream = $bs; 0을 반환합니다. } 잡기(예외 $e) { -1을 반환합니다. } } //------------------------------------------------ --------- 공개 함수 encodeMode8($version) { 노력하다 { $bs = 새로운 QRbitstream(); $bs->appendNum(4, 0x4); $bs->appendNum(QRspec::lengthIndicator(QR_MODE_8, $version), $this->size); for($i=0; $isize; $i++) { $bs->appendNum(8, ord($this->data[$i])); } $this->bstream = $bs; 0을 반환합니다. } 잡기(예외 $e) { -1을 반환합니다. } } //------------------------------------------------ --------- 공용 함수 encodeModeKanji($version) { 노력하다 { $bs = 새로운 QRbitrtream(); $bs->appendNum(4, 0x8); $bs->appendNum(QRspec::lengthIndicator(QR_MODE_KANJI, $version), (int)($this->size / 2)); for($i=0; $isize; $i+=2) { $val = (ord($this->data[$i]) data[$i+1]); if($val > 8) * 0xc0; $val = ($val & 0xff) + $h; $bs->appendNum(13, $val); } $this->bstream = $bs; 0을 반환합니다. } 잡기(예외 $e) { -1을 반환합니다. } } //------------------------------------------------ --------- 공개 함수 encodeModeStructure() { 노력하다 { $bs = 새로운 QRbitstream(); $bs->appendNum(4, 0x03); $bs->appendNum(4, ord($this->data[1]) - 1); $bs->appendNum(4, ord($this->data[0]) - 1); $bs->appendNum(8, ord($this->data[2])); $this->bstream = $bs; 0을 반환합니다. } 잡기(예외 $e) { -1을 반환합니다. } } //------------------------------------------------ --------- 공개 함수 estimateBitStreamSizeOfEntry($version) { $비트 = 0; if($버전 == 0) $버전 = 1; 스위치($this->모드) { 케이스 QR_MODE_NUM: $bits = QRinput::estimateBitsModeNum($this->size); 부서지다; 케이스 QR_MODE_AN: $bits = QRinput::estimateBitsModeAn($this->size); 부서지다; 케이스 QR_MODE_8: $bits = QRinput::estimateBitsMode8($this->size); 부서지다; 사례 QR_MODE_KANJI: $bits = QRinput::estimateBitsModeKanji($this->size);break; 사례 QR_MODE_STRUCTURE: STRUCTURE_HEADER_BITS를 반환합니다. 기본: 0을 반환합니다. } $l = QRspec::lengthIndicator($this->mode, $version); $m = 1 size + $m - 1) / $m); $비트 += $num * (4 + $l); $비트를 반환합니다. }//------------------------------------------------ --------- 공개 함수 encodeBitStream($version) { 노력하다 { unset($this->bstream); $words = QRspec::maximumWords($this->mode, $version); if($this->size > $words) { $st1 = new QRinputItem($this->mode, $words, $this->data); $st2 = new QRinputItem($this->mode, $this->size - $words, array_slice($this->data, $words)); $st1->encodeBitStream($version); $st2->encodeBitStream($version); $this->bstream = 새로운 QRbitstream(); $this->bstream->append($st1->bstream); $this->bstream->append($st2->bstream); 설정 해제($st1); 설정 해제($st2); } 또 다른 { $ret = 0; 스위치($this->모드) { 케이스 QR_MODE_NUM: $ret = $this->encodeModeNum($version); 부서지다; 케이스 QR_MODE_AN: $ret = $this->encodeModeAn($version); 부서지다; 케이스 QR_MODE_8: $ret = $this->encodeMode8($version); 부서지다; 사례 QR_MODE_KANJI: $ret = $this->encodeModeKanji($version);break; 케이스 QR_MODE_STRUCTURE: $ret = $this->encodeModeStructure(); 부서지다; 기본: 부서지다; } if($ret bstream->size(); } 잡기(예외 $e) { -1을 반환합니다. } } }; //############################################ ######################### 클래스 QRinput { 공개 $ 항목; 비공개 $버전; 개인 $수준; //------------------------------------------------ --------- 공개 함수 __construct($version = 0, $level = QR_ECLEVEL_L) { if ($version QRSPEC_VERSION_MAX || $level > QR_ECLEVEL_H) { throw new Exception('잘못된 버전 번호'); NULL을 반환합니다. } $this->버전 = $버전; $this->레벨 = $레벨; } //------------------------------------------------ --------- 공개 함수 getVersion() { $this->버전을 반환합니다. } //------------------------------------------------ --------- 공개 함수 setVersion($version) { if($version QRSPEC_VERSION_MAX) { throw new Exception('잘못된 버전 번호'); -1을 반환합니다. } $this->버전 = $버전; 0을 반환합니다. } //------------------------------------------------ --------- 공용 함수 getErrorCorrectionLevel() { $this->레벨을 반환합니다. } //------------------------------------------------ --------- 공용 함수 setErrorCorrectionLevel($level) { if($level > QR_ECLEVEL_H) { 새로운 예외 발생('잘못된 ECLEVEL'); -1을 반환합니다. } $this->레벨 = $레벨; 0을 반환합니다. } //------------------------------------------------ --------- 공용 함수 AppendEntry(QRinputItem $entry) { $this->items[] = $entry; } //------------------------------------------------ --------- 공용 함수 추가($mode, $size, $data) { 노력하다 { $entry = new QRinputItem($mode, $size, $data); $this->items[] = $entry; 0을 반환합니다. } 잡기(예외 $e) { -1을 반환합니다. } } //------------------------------------------------ --------- 공용 함수 insertStructuredAppendHeader($size, $index, $parity) { if( $size > MAX_STRUCTURED_SYMBOLS ) { 새로운 예외 발생('insertStructuredAppendHeader 잘못된 크기'); }if( $index MAX_STRUCTURED_SYMBOLS ) { 새로운 예외 발생('insertStructuredAppendHeader 잘못된 인덱스'); } $buf = 배열($size, $index, $parity); 노력하다 { $entry = new QRinputItem(QR_MODE_STRUCTURE, 3, buf); array_unshift($this->items, $entry); 0을 반환합니다. } 잡기(예외 $e) { -1을 반환합니다. } } //------------------------------------------------ --------- 공개 함수 calcParity() { $패리티 = 0; foreach($this->항목을 $item으로) { if($item->모드 != QR_MODE_STRUCTURE) { for($i=$item->size-1; $i>=0; $i--) { $패리티 ^= $item->데이터[$i]; } } } $패리티를 반환합니다. } //------------------------------------------------ --------- 공개 정적 함수 checkModeNum($size, $data) { for($i=0; $i ord('9'))){ 거짓을 반환; } } 사실을 반환; } //------------------------------------------------ --------- 공개 정적 함수 estimateBitsModeNum($size) { $w = (int)$size / 3; $비트 = $w * 10; 스위치($size - $w * 3) { 사례 1: $비트 += 4; 부서지다; 사례 2: $비트 += 7; 부서지다; 기본: 부서지다; } $비트를 반환합니다. } //------------------------------------------------ --------- 공개 정적 $anTable = 배열( -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 36, -1, -1, -1, 37, 38, -1, -1, -1, -1, 39, 40, -1, 41, 42, 43, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 44, -1, -1, -1, -1, -1, -1장, 10장, 11장, 12장, 13장, 14장, 15장, 16장, 17장, 18장, 19장, 20장, 21장, 22장, 23장, 24장, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1 ); //------------------------------------------------ --------- 공개 정적 함수 lookAnTable($c) { return (($c > 127)?-1:self::$anTable[$c]); } //------------------------------------------------ --------- 공개 정적 함수 checkModeAn($size, $data) { for($i=0; $i 0x9ffc && $val 0xebf) { 거짓을 반환; } } 사실을 반환; }/**************************************************** ******************* * 검증 ************************************************** ********************/ 공개 정적 함수 검사($mode, $size, $data) { if($size 항목을 $item으로) { $bits += $item->estimateBitStreamSizeOfEntry($version); } $비트를 반환합니다. } //------------------------------------------------ --------- 공개 함수 추정 버전() { $버전 = 0; $이전 = 0; 하다 { $prev = $버전; $bits = $this->estimateBitStreamSize($prev); $version = QRspec::getMinimumVersion((int)(($bits + 7) / 8), $this->level); if ($version $prev); $버전을 반환합니다. } //------------------------------------------------ --------- 공개 정적 함수 lengthOfCode($mode, $version, $bits) { $payload = $bits - 4 - QRspec::lengthIndicator($mode, $version); 스위치($mode) { 케이스 QR_MODE_NUM: $chunks = (int)($payload / 10); $remain = $payload - $chunks * 10; $size = $chunks * 3; if($remain >= 7) { $크기 += 2; } else if($remain >= 4) { $크기 += 1; } 부서지다; 케이스 QR_MODE_AN: $chunks = (int)($payload / 11); $remain = $payload - $chunks * 11; $size = $chunks * 2; if($remain >= 6) $크기++; 부서지다; 케이스 QR_MODE_8: $size = (int)($payload / 8); 부서지다; 사례 QR_MODE_KANJI: $size = (int)(($payload / 13) * 2); 부서지다; 케이스 QR_MODE_STRUCTURE: $size = (int)($payload / 8); 부서지다; 기본: $크기 = 0; 부서지다; } $maxsize = QRspec::maximumWords($mode, $version); if($size $maxsize) $size = $maxsize; $size를 반환합니다. } //------------------------------------------------ --------- 공개 함수 createBitStream() { $to
성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
PHP : 서버 측 스크립팅 언어 소개PHP : 서버 측 스크립팅 언어 소개Apr 16, 2025 am 12:18 AM

PHP는 동적 웹 개발 및 서버 측 응용 프로그램에 사용되는 서버 측 스크립팅 언어입니다. 1.PHP는 편집이 필요하지 않으며 빠른 발전에 적합한 해석 된 언어입니다. 2. PHP 코드는 HTML에 포함되어 웹 페이지를 쉽게 개발할 수 있습니다. 3. PHP는 서버 측 로직을 처리하고 HTML 출력을 생성하며 사용자 상호 작용 및 데이터 처리를 지원합니다. 4. PHP는 데이터베이스와 상호 작용하고 프로세스 양식 제출 및 서버 측 작업을 실행할 수 있습니다.

PHP 및 웹 : 장기적인 영향 탐색PHP 및 웹 : 장기적인 영향 탐색Apr 16, 2025 am 12:17 AM

PHP는 지난 수십 년 동안 네트워크를 형성했으며 웹 개발에서 계속 중요한 역할을 할 것입니다. 1) PHP는 1994 년에 시작되었으며 MySQL과의 원활한 통합으로 인해 개발자에게 최초의 선택이되었습니다. 2) 핵심 기능에는 동적 컨텐츠 생성 및 데이터베이스와의 통합이 포함되며 웹 사이트를 실시간으로 업데이트하고 맞춤형 방식으로 표시 할 수 있습니다. 3) PHP의 광범위한 응용 및 생태계는 장기적인 영향을 미쳤지 만 버전 업데이트 및 보안 문제에 직면 해 있습니다. 4) PHP7의 출시와 같은 최근 몇 년간의 성능 향상을 통해 현대 언어와 경쟁 할 수 있습니다. 5) 앞으로 PHP는 컨테이너화 및 마이크로 서비스와 같은 새로운 도전을 다루어야하지만 유연성과 활발한 커뮤니티로 인해 적응력이 있습니다.

PHP를 사용하는 이유는 무엇입니까? 설명 된 장점과 혜택PHP를 사용하는 이유는 무엇입니까? 설명 된 장점과 혜택Apr 16, 2025 am 12:16 AM

PHP의 핵심 이점에는 학습 용이성, 강력한 웹 개발 지원, 풍부한 라이브러리 및 프레임 워크, 고성능 및 확장 성, 크로스 플랫폼 호환성 및 비용 효율성이 포함됩니다. 1) 배우고 사용하기 쉽고 초보자에게 적합합니다. 2) 웹 서버와 우수한 통합 및 여러 데이터베이스를 지원합니다. 3) Laravel과 같은 강력한 프레임 워크가 있습니다. 4) 최적화를 통해 고성능을 달성 할 수 있습니다. 5) 여러 운영 체제 지원; 6) 개발 비용을 줄이기위한 오픈 소스.

신화를 폭로 : PHP가 실제로 죽은 언어입니까?신화를 폭로 : PHP가 실제로 죽은 언어입니까?Apr 16, 2025 am 12:15 AM

PHP는 죽지 않았습니다. 1) PHP 커뮤니티는 성능 및 보안 문제를 적극적으로 해결하고 PHP7.x는 성능을 향상시킵니다. 2) PHP는 최신 웹 개발에 적합하며 대규모 웹 사이트에서 널리 사용됩니다. 3) PHP는 배우기 쉽고 서버가 잘 수행되지만 유형 시스템은 정적 언어만큼 엄격하지 않습니다. 4) PHP는 컨텐츠 관리 및 전자 상거래 분야에서 여전히 중요하며 생태계는 계속 발전하고 있습니다. 5) Opcache 및 APC를 통해 성능을 최적화하고 OOP 및 설계 패턴을 사용하여 코드 품질을 향상시킵니다.

PHP vs. Python 토론 : 어느 것이 더 낫습니까?PHP vs. Python 토론 : 어느 것이 더 낫습니까?Apr 16, 2025 am 12:03 AM

PHP와 Python에는 고유 한 장점과 단점이 있으며 선택은 프로젝트 요구 사항에 따라 다릅니다. 1) PHP는 웹 개발, 배우기 쉽고 풍부한 커뮤니티 리소스에 적합하지만 구문은 현대적이지 않으며 성능과 보안에주의를 기울여야합니다. 2) Python은 간결한 구문과 배우기 쉬운 데이터 과학 및 기계 학습에 적합하지만 실행 속도 및 메모리 관리에는 병목 현상이 있습니다.

PHP의 목적 : 동적 웹 사이트 구축PHP의 목적 : 동적 웹 사이트 구축Apr 15, 2025 am 12:18 AM

PHP는 동적 웹 사이트를 구축하는 데 사용되며 해당 핵심 기능에는 다음이 포함됩니다. 1. 데이터베이스와 연결하여 동적 컨텐츠를 생성하고 웹 페이지를 실시간으로 생성합니다. 2. 사용자 상호 작용 및 양식 제출을 처리하고 입력을 확인하고 작업에 응답합니다. 3. 개인화 된 경험을 제공하기 위해 세션 및 사용자 인증을 관리합니다. 4. 성능을 최적화하고 모범 사례를 따라 웹 사이트 효율성 및 보안을 개선하십시오.

PHP : 데이터베이스 및 서버 측 로직 처리PHP : 데이터베이스 및 서버 측 로직 처리Apr 15, 2025 am 12:15 AM

PHP는 MySQLI 및 PDO 확장 기능을 사용하여 데이터베이스 작업 및 서버 측 로직 프로세싱에서 상호 작용하고 세션 관리와 같은 기능을 통해 서버 측로 로직을 처리합니다. 1) MySQLI 또는 PDO를 사용하여 데이터베이스에 연결하고 SQL 쿼리를 실행하십시오. 2) 세션 관리 및 기타 기능을 통해 HTTP 요청 및 사용자 상태를 처리합니다. 3) 트랜잭션을 사용하여 데이터베이스 작업의 원자력을 보장하십시오. 4) SQL 주입 방지, 디버깅을 위해 예외 처리 및 폐쇄 연결을 사용하십시오. 5) 인덱싱 및 캐시를 통해 성능을 최적화하고, 읽을 수있는 코드를 작성하고, 오류 처리를 수행하십시오.

PHP에서 SQL 주입을 어떻게 방지합니까? (준비된 진술, pdo)PHP에서 SQL 주입을 어떻게 방지합니까? (준비된 진술, pdo)Apr 15, 2025 am 12:15 AM

PHP에서 전처리 문과 PDO를 사용하면 SQL 주입 공격을 효과적으로 방지 할 수 있습니다. 1) PDO를 사용하여 데이터베이스에 연결하고 오류 모드를 설정하십시오. 2) 준비 방법을 통해 전처리 명세서를 작성하고 자리 표시자를 사용하여 데이터를 전달하고 방법을 실행하십시오. 3) 쿼리 결과를 처리하고 코드의 보안 및 성능을 보장합니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 채팅 명령 및 사용 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

Dreamweaver Mac版

Dreamweaver Mac版

시각적 웹 개발 도구

PhpStorm 맥 버전

PhpStorm 맥 버전

최신(2018.2.1) 전문 PHP 통합 개발 도구

SublimeText3 영어 버전

SublimeText3 영어 버전

권장 사항: Win 버전, 코드 프롬프트 지원!

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.