URLs http_build_query

(PHP 5, PHP 7, PHP 8)

http_build_query — URL 인코딩된 쿼리 문자열 생성


설명

http_build_query(
    array|object $data,
    string $numeric_prefix = "",
    ?string $arg_separator = null,
    int $encoding_type = PHP_QUERY_RFC1738
): string
                

제공된 연관(또는 인덱싱된) 배열에서 URL 인코딩된 쿼리 문자열을 생성합니다.


매개변수

data
속성을 포함하는 배열 또는 개체일 수 있습니다.

data가 배열인 경우 단순한 1차원 구조이거나 배열의 배열(다른 배열을 포함할 수 있음)일 수 있습니다.

data가 개체인 경우 공용 속성만 결과에 통합됩니다.

numeric_prefix
숫자 인덱스가 기본 배열에 사용되고 이 매개변수가 제공되면 기본 배열의 요소에 대해서만 숫자 인덱스 앞에 추가됩니다.

이는 나중에 PHP 또는 다른 CGI 응용 프로그램에서 데이터를 디코딩할 때 유효한 변수 이름을 허용하기 위한 것입니다.

arg_separator
arg_separator.output은 인수를 구분하는 데 사용되지만 이 매개변수를 지정하여 재정의할 수 있습니다.
encoding_type
기본적으로 PHP_QUERY_RFC1738입니다.

encoding_typePHP_QUERY_RFC1738인 경우 » RFC 1738application/x-www-form-urlencoded 미디어 유형에 따라 인코딩이 수행되며, 이는 공백이 더하기(+) 기호로 인코딩됨을 의미합니다.

encoding_typePHP_QUERY_RFC3986이면 » RFC 3986에 따라 인코딩이 수행되고 공백은 백분율로 인코딩됩니다(%20).


반환 값

URL로 인코딩된 문자열을 반환합니다.


Examples

예제 #1 http_build_query()의 간단한 사용법

                  
<?php
$data = array(
    'foo' => 'bar',
    'baz' => 'boom',
    'cow' => 'milk',
    'null' => null,
    'php' => 'hypertext processor'
);

echo http_build_query($data) . "\n";
echo http_build_query($data, '', '&amp;');

?>
                  
                

위의 예는 다음을 출력합니다.

foo=bar&baz=boom&cow=milk&php=hypertext+processor
foo=bar&baz=boom&cow=milk&php=hypertext+processor
                

예제 #2 숫자로 인덱스 요소가 있는 http_build_query().

                  
<?php
$data = array('foo', 'bar', 'baz', null, 'boom', 'cow' => 'milk', 'php' => 'hypertext processor');

echo http_build_query($data) . "\n";
echo http_build_query($data, 'myvar_');
?>
                  
                

위의 예는 다음을 출력합니다.

0=foo&1=bar&2=baz&4=boom&cow=milk&php=hypertext+processor
myvar_0=foo&myvar_1=bar&myvar_2=baz&myvar_4=boom&cow=milk&php=hypertext+processor
                

예제 #3 복잡한 배열이 있는 http_build_query()

                  
<?php
$data = array(
    'user' => array(
        'name' => 'Bob Smith',
        'age'  => 47,
        'sex'  => 'M',
        'dob'  => '5/12/1956'
    ),
    'pastimes' => array('golf', 'opera', 'poker', 'rap'),
    'children' => array(
        'bobby' => array('age'=>12, 'sex'=>'M'),
        'sally' => array('age'=>8, 'sex'=>'F')
    ),
    'CEO'
);

echo http_build_query($data, 'flags_');
?>
                  
                

이것은 출력합니다 : (가독성을 위해 줄 바꿈 된 단어)

user%5Bname%5D=Bob+Smith&user%5Bage%5D=47&user%5Bsex%5D=M&
user%5Bdob%5D=5%2F12%2F1956&pastimes%5B0%5D=golf&pastimes%5B1%5D=opera&
pastimes%5B2%5D=poker&pastimes%5B3%5D=rap&children%5Bbobby%5D%5Bage%5D=12&
children%5Bbobby%5D%5Bsex%5D=M&children%5Bsally%5D%5Bage%5D=8&
children%5Bsally%5D%5Bsex%5D=F&flags_0=CEO
                

메모: 기본 배열 "CEO"에서 숫자로 인덱싱된 요소만 접두사를 받았습니다. 오락에서 발견되는 다른 숫자 인덱스는 유효한 변수 이름이 되기 위해 문자열 접두사를 요구하지 않습니다.

예제 #4 객체와 함께 http_build_query() 사용

                  
<?php
class parentClass {
    public    $pub      = 'publicParent';
    protected $prot     = 'protectedParent';
    private   $priv     = 'privateParent';
    public    $pub_bar  = null;
    protected $prot_bar = null;
    private   $priv_bar = null;

    public function __construct(){
        $this->pub_bar  = new childClass();
        $this->prot_bar = new childClass();
        $this->priv_bar = new childClass();
    }
}

class childClass {
    public    $pub  = 'publicChild';
    protected $prot = 'protectedChild';
    private   $priv = 'privateChild';
}

$parent = new parentClass();

echo http_build_query($parent);
?>
                  
                

위의 예는 다음을 출력합니다.

pub=publicParent&pub_bar%5Bpub%5D=publicChild
                

기타

  • parse_str() - 문자열을 변수로 구문 분석
  • parse_url() - URL을 구문 분석하고 해당 구성 요소를 반환합니다.
  • urlencode() - URL 인코딩 문자열
  • array_walk() - 배열의 모든 구성원에 사용자 제공 함수 적용