php

Description:

Apache2 PHP 엔진 (mod_php7, libphp7.so)
PHP is an HTML-embedded scripting language. PHP attempts to make it easy for developers to write dynamically generated web pages. PHP also offers built-in database integration for several commercial and non-commercial database management systems, so writing a database-enabled web page with PHP is fairly simple. The most common use of PHP coding is probably as a replacement for CGI scripts. The mod_php module enables the Apache web server to understand and process the embedded PHP language in web pages.

Changes on AnNyung:

    1.
    php 7 업데이트
    2.
    성능
      PHP VM type을 GOTO mode로 빌드 (성능 20% 향상)
      realpath_cache_force ini 옵션 제공
        openbase_dir 사용시에, realpath_cache 기능을 강제로 사용하게 하여 30% 정도의 성능을 향상
    3.
    보안
      exec_dir (PHP_INI_SYSTEM) 기능
        PHP의 shell injection을 engine level에서 방어하기 위한 기능
          이 기능은 engine level에서 처리를 하기 때문에, php code 쪽에서는 아무런 영향이 없음.
        2005년 부터 KLDP와 N사 T사의 core system에 적용되어 검증
        PHP 5.4 이전의 safe_mode_exec_dir을 safe_mode가 아닌 경우에도 사용할 수 있도록 수정하고 command 치환 parser를 확장
        기본값 /var/lib/php/bin
          안녕의 PHP 에서 system 함수를 사용하려면 사용하려면 command가 /var/lib/php/bin 에 soft link나 복사 되어야 함.
        system function에 의해서 실행된 command의 경로를 강제로 지정한 값으로 변환
        1
        exec_dir = /path/bin
        2
        system('/some/path/command -option cmd_arg');
        3
        => system('/path/bin/command -option cmd_arg'); 치환됨
        Copied!
        치환 가능 범위
        1
        command; command => /path/bin/command; /path/bin/command
        2
        command $(command) => /path/bin/command $(/path/bin/command)
        3
        command $(command $(command)) => /path/bin/command $(/path/bin/command $(/path/bin/command))
        4
        command $(command `command`) => /path/bin/command $(/path/bin/command `/path/bin/command`)
        5
        command `command` => /path/bin/command `/path/bin/command`
        6
        command | command => /path/bin/command | /path/bin/command
        7
        command && command => /path/bin/command && /path/bin/command
        8
        command || command => /path/bin/command || /path/bin/command
        Copied!
        적용 functions
      disable_functions 기본 적용
        phpinfo
        php_uname
        sys_get_temp_dir
        phpversion
        ini_get
        ini_set
        ini_get_all
        get_cfg_var
        상단의 적용 function들은 함수명 앞에 prefix로 under bar 3개를 붙이면 호출이 가능함.
        1
        <?php
        2
        ___phpinfo();
        3
        ?>
        Copied!
      file upload시 image header의 injection code 여부 검사 기능 추가
        php.ini 에 다음 옵션 추가
          upload_image_check (기본값 On)
            업로드 이미지 헤더에 php code가 포함되었는지 검사
            php code 발견 시에 E_WARNING 발생
          upload_image_check_log (기본값 On) - 업로드 이미지 헤더 검사 관련 로그 기록
          upload_image_check_test (기본값 On)
            검사만 하고, 에러 레벨만 리턴(E_WARNING 발생 안함)
            검사 결과 감지가 되면 UPLOAD_ERR_SEC 반환
          upload_image_check_whitelist - 이미지 헤더 문자열 white list
      allow_url_fopenallow_url_include를 PHP_INI_ALL로 수정
        기본값 OFF이며, php code에서 ini_set으로 변경 가능
      allow_include_extension 옵션 추가 (기본값: .php)
        등록된 확장자만 php compiler에 의해 compile 됨.
        include / require 모두 해당
        등록된 확장자 파일을 upload 할 경우, UPLOAD_ERR_ILL 에러를 반환하고 업로드 되지 않음.
      short_open_tag 기본 값 Off
    4.
    기능

Sub packages:

    php-cli - php7 cli 인터페이스
    php-dba - PHP7 dba 확장
    php-dblib - PHP7 dba 확장
    php-devel - php7 확장 개발을 위한 파일들
    php-extension - php7 shared extension
      php, php-cli, php-fpm 공용으로 사용
      /etc/php.d/{apache,cli,fpm}/SHARED.ini 에서 module loading 설정을 해 주어야 함. 기본으로 loading 하지 않음
      1
      [[email protected] ~]$ cat /etc/php.d/cli/SHARED.ini
      2
      ;
      3
      ; Follow extensions need php-extension package
      4
      ;
      5
      ;extension = bcmath.so
      6
      ;extension = calendar.so
      7
      ;extension = curl.so
      8
      ;extension = exif.so
      9
      ;extension = fileinfo.so
      10
      ;extension = ftp.so
      11
      ;extension = gd.so
      12
      ;extension = gettext.so
      13
      ;extension = imap.so
      14
      ;extension = json.so
      15
      ;extension = ldap.so
      16
      ;extension = libevent.so
      17
      ;extension = mcrypt.so
      18
      ;extension = mysql.so
      19
      ;extension = mysqli.so
      20
      ;extension = pdo_mysql.so
      21
      ;extension = pdo_sqlite.so
      22
      ;extension = snmop.so
      23
      ;extension = snmp.so
      24
      ;extension = soap.so
      25
      ;extension = sqlite3.so
      26
      ;extension = wddx.so
      27
      ;extension = xmlreader.so
      28
      ;extension = xmlwriter.so
      29
      ;extension = zip.so
      30
      ;zend_extension = /usr/lib64/php/extensions/opcache.so
      Copied!
    php-fpm - php7 fpm engine
    php-oci - PHP7 oci8/pdo_oci 확장
    php-odbc - PHP7 odbc, pdo_odbc 확장
    php-pear - PHP 확장및 응용 프로그램 저장소 프레임웍
    php-pgsql - PHP7 pgsql, pdo_pgsql 확장
    php-recode - PHP7 recode 확장
    php-geoip
    php-krisp
    php-nis
Last modified 1yr ago