찾다
백엔드 개발PHP 튜토리얼PHP 구문 분석 URL 함수에 대한 간략한 토론입니다.

PHP에는 URL을 구문 분석하는 데 사용할 수 있는 두 가지 메소드(parse_url 및parse_str)가 있습니다.

parse_url
URL을 구문 분석하여 해당 구성 요소를 반환합니다.

혼합된 구문 분석 URL( string $url [, int $comComponent = -1 ] )

이 함수는 URL을 구문 분석하고 URL에 나타나는 다양한 구성 요소가 포함된 연관 배열을 반환합니다.

이 기능은 제공된 URL의 유효성을 확인하는 데 사용되는 것이 아니라 URL을 아래 나열된 부분으로 분류하는 데 사용됩니다. 불완전한 URL도 허용되며,parse_url()은 이를 가능한 한 정확하게 구문 분석하려고 시도합니다.

매개변수

url 구문 분석할 URL입니다. 유효하지 않은 문자는 _로 대체됩니다.

구성요소 PHP_URL_SCHEME, PHP_URL_HOST, PHP_URL_PORT, PHP_URL_USER, PHP_URL_PASS, PHP_URL_PATH, PHP_URL_QUERY 또는 PHP_URL_FRAGMENT 중 하나를 지정하여 URL의 지정된 부분에 대한 문자열을 가져옵니다. (PHP_URL_PORT로 지정한 경우를 제외하면 정수값이 반환됩니다.)

반환값

심각하게 자격이 없는 URL의 경우,parse_url()이 FALSE를 반환할 수 있습니다.

구성요소 매개변수를 생략하면 연관 배열 배열이 반환되며, 현재 배열에 최소한 하나의 요소가 포함됩니다. 배열에 가능한 키는 다음과 같습니다:

구성표 - http와 유사
호스트
항구
사용자
합격
경로
쿼리 - 물음표 뒤
조각 - 해시 기호 #
뒤 구성 요소 인수가 지정된 경우,parse_url()은 배열 대신 문자열(또는 PHP_URL_PORT로 지정된 경우 정수)을 반환합니다. URL에 지정된 구성 요소가 없으면 NULL이 반환됩니다.

코드 복사 코드는 다음과 같습니다.

$url = 'http://username:password@hostname/path?arg=value#anchor';
print_r(parse_url($url));
echo pars_url($url, PHP_URL_PATH);
?>
위 루틴은 다음을 출력합니다:

코드 복사 코드는 다음과 같습니다.
배열
(
[구성표] =>http
[호스트] => 호스트 이름
[사용자] => 사용자 이름
[통과] => 비밀번호
[경로] => /경로
[쿼리] => 인수=값
[조각] => 앵커
)
/경로

parse_str

문자열을 여러 변수로 구문 분석

voidpars_str(문자열 $str [, array &$arr ] )

str이 URL로 전달된 쿼리 문자열인 경우 이를 변수로 구문 분석하고 현재 범위로 설정합니다.

현재 QUERY_STRING을 얻으려면 $_SERVER['QUERY_STRING'] 변수를 사용할 수 있습니다.

매개변수

str 입력 문자열입니다.

arr 두 번째 변수 arr이 설정되면 변수는 대신 이 배열에 배열 요소로 저장됩니다. ,

코드 복사 코드는 다음과 같습니다.
$str = "first=value&arr[]=foo bar&arr[]=baz";
pars_str($str);
에코 $first; //값
echo $arr[0]; // foo 바
echo $arr[1] // baz
pars_str($str, $output);
echo $output['first'] // 값
echo $output['arr'][0] // foo 바
echo $output['arr'][1] // baz
?>

얼마 전에 php-resque의 소스 코드를 읽다가 이 두 가지 방법을 적용한 것을 보니 redis 링크의 설정을 파싱하는 데 매우 잘 사용되는 것 같습니다.

redis 링크 형식은 redis://user:pass@host:port/db?option1=val1&option2=val2 URL과 같으니 위의 두 가지 방법을 이용하면 쉽게 파싱할 수 있습니다. .

주소:

https://github.com/chrisboulton/php-resque/blob/master/lib/Resque/Redis.php

코드는 다음과 같습니다.

코드 복사 코드는 다음과 같습니다.

    /**
     * 다음 형식 중 하나를 가질 수 있는 DSN 문자열을 구문 분석합니다.
     *
     * - 호스트:포트
     * - redis://user:pass@host:port/db?option1=val1&option2=val2
     * - tcp://user:pass@host:port/db?option1=val1&option2=val2
     *
     * 참고: DSN의 '사용자' 부분은 사용되지 않습니다.
     *
     * @param string $dsn DSN 문자열
     * @return array 알 수 없는 구성 요소에 대해 'false' 값을 갖는 DSN 구성 요소의 배열입니다. 예:
     *               [호스트, 포트, DB, 사용자, 패스, 옵션]
    */
    공개 정적 함수parseDsn($dsn)
    {
        if ($dsn == '') {
            // 빈 DNS 문자열에 합리적인 기본값을 사용하세요
            $dsn = 'redis://' . self::DEFAULT_HOST;
        }
        $parts=parse_url($dsn);
        // URI 체계를 확인하세요
        $validSchemes = array('redis', 'tcp');
        if (isset($parts['scheme']) && ! in_array($parts['scheme'], $validSchemes)) {
            throw new InvalidArgumentException("잘못된 DSN. 지원되는 구성표는 " . implode(', ', $validSchemes));
        }
        // `parse_url`이 호스트가 아닌 경로로 처리하는 간단한 '호스트 이름' 형식을 허용합니다.
        if ( ! isset($parts['host']) && isset($parts['path'])) {
            $parts['host'] = $parts['path'];
            unset($parts['path']);
        }
        // 포트번호를 정수로 추출
        $port = isset($parts['port']) ? intval($parts['port']) : self::DEFAULT_PORT;
        // URI의 '경로' 부분에서 데이터베이스를 가져옵니다
        $database = 거짓;
        if (isset($parts['path'])) {
            // 경로에서 숫자가 아닌 문자를 제거합니다
            $database = intval(preg_replace('/[^0-9]/', '', $parts['path']));
        }
        // 'user' 및 'pass' 값을 추출합니다
        $user = isset($parts['user']) ? $parts['사용자'] : 거짓;
        $pass = isset($parts['pass']) ? $parts['pass'] : 거짓;
        // 쿼리 문자열을 연관 배열로 변환
        $옵션 = 배열();
        if (isset($parts['query'])) {
            // 쿼리 문자열을 배열로 구문 분석합니다
            pars_str($parts['query'], $options);
        }
        배열 반환(
            $parts['호스트'],
            $포트,
            $데이터베이스,
            $user
            $패스
            $옵션
        );
    }
성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
PHP 세션의 개념을 간단한 용어로 설명하십시오.PHP 세션의 개념을 간단한 용어로 설명하십시오.Apr 26, 2025 am 12:09 AM

phpsessionstrackuserdataacrossmultiplepagerequestsususingauniqueIdStoredInAcookie.here'showtomanagetheMeftically : 1) STARTASESSIONSTART_START () andSTAREDATAIN $ _SESSION.2) RegenerATERATESSESSIDIDAFTERLOGINWITHSESSION_RATERATERATES (True) TopreventSES

PHP 세션에 저장된 모든 값을 어떻게 반복합니까?PHP 세션에 저장된 모든 값을 어떻게 반복합니까?Apr 26, 2025 am 12:06 AM

PHP에서 세션 데이터를 통한 반복은 다음 단계를 통해 달성 할 수 있습니다. 1. Session_start ()를 사용하여 세션을 시작하십시오. 2. $ _session 배열의 모든 키 값 쌍을 통해 Foreach 루프를 통과합니다. 3. 복잡한 데이터 구조를 처리 할 때 is_array () 또는 is_object () 함수를 사용하고 print_r ()를 사용하여 자세한 정보를 출력하십시오. 4. Traversal을 최적화 할 때 페이징을 사용하여 한 번에 많은 양의 데이터를 처리하지 않도록 할 수 있습니다. 이를 통해 실제 프로젝트에서 PHP 세션 데이터를보다 효율적으로 관리하고 사용하는 데 도움이됩니다.

사용자 인증에 세션을 사용하는 방법을 설명하십시오.사용자 인증에 세션을 사용하는 방법을 설명하십시오.Apr 26, 2025 am 12:04 AM

이 세션은 서버 측 상태 관리 메커니즘을 통해 사용자 인증을 인식합니다. 1) 세션 생성 및 고유 ID의 세션 생성, 2) ID는 쿠키를 통해 전달됩니다. 3) ID를 통해 서버 저장 및 세션 데이터에 액세스합니다. 4) 사용자 인증 및 상태 관리가 실현되어 응용 프로그램 보안 및 사용자 경험이 향상됩니다.

PHP 세션에 사용자 이름을 저장하는 방법의 예를 제시하십시오.PHP 세션에 사용자 이름을 저장하는 방법의 예를 제시하십시오.Apr 26, 2025 am 12:03 AM

tostoreauser'snameinaphpsession, startSessionstart_start (), wathsignthenameto $ _session [ 'username']. 1) useSentess_start () toinitializethesession.2) assimeuser'snameto $ _session [ 'username']

PHP 세션이 실패 할 수있는 몇 가지 일반적인 문제는 무엇입니까?PHP 세션이 실패 할 수있는 몇 가지 일반적인 문제는 무엇입니까?Apr 25, 2025 am 12:16 AM

phpsession 실패 이유에는 구성 오류, 쿠키 문제 및 세션 만료가 포함됩니다. 1. 구성 오류 : 올바른 세션을 확인하고 설정합니다. 2. 쿠키 문제 : 쿠키가 올바르게 설정되어 있는지 확인하십시오. 3. 세션 만료 : 세션 시간을 연장하기 위해 세션을 조정합니다 .GC_MAXLIFETIME 값을 조정하십시오.

PHP의 세션 관련 문제를 어떻게 디버그합니까?PHP의 세션 관련 문제를 어떻게 디버그합니까?Apr 25, 2025 am 12:12 AM

PHP에서 세션 문제를 디버그하는 방법 : 1. 세션이 올바르게 시작되었는지 확인하십시오. 2. 세션 ID의 전달을 확인하십시오. 3. 세션 데이터의 저장 및 읽기를 확인하십시오. 4. 서버 구성을 확인하십시오. 세션 ID 및 데이터를 출력, 세션 파일 컨텐츠보기 등을 통해 세션 관련 문제를 효과적으로 진단하고 해결할 수 있습니다.

session_start ()가 여러 번 호출되면 어떻게됩니까?session_start ()가 여러 번 호출되면 어떻게됩니까?Apr 25, 2025 am 12:06 AM

Session_Start ()로 여러 통화를하면 경고 메시지와 가능한 데이터 덮어 쓰기가 발생합니다. 1) PHP는 세션이 시작되었다는 경고를 발행합니다. 2) 세션 데이터의 예상치 못한 덮어 쓰기를 유발할 수 있습니다. 3) Session_status ()를 사용하여 반복 통화를 피하기 위해 세션 상태를 확인하십시오.

PHP에서 세션 수명을 어떻게 구성합니까?PHP에서 세션 수명을 어떻게 구성합니까?Apr 25, 2025 am 12:05 AM

SESSION.GC_MAXLIFETIME 및 SESSION.COOKIE_LIFETIME을 설정하여 PHP에서 세션 수명을 구성 할 수 있습니다. 1) SESSION.GC_MAXLIFETIME 서버 측 세션 데이터의 생존 시간을 제어합니다. 2) 세션 .Cookie_Lifetime 클라이언트 쿠키의 수명주기를 제어합니다. 0으로 설정하면 브라우저가 닫히면 쿠키가 만료됩니다.

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 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

SublimeText3 영어 버전

SublimeText3 영어 버전

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

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기

PhpStorm 맥 버전

PhpStorm 맥 버전

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

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구