텍스트를 링크로 변환할 때 HTML 태그 내의 URL 교체를 방지하는 방법은 무엇입니까?

DDD
풀어 주다: 2024-10-28 12:00:16
원래의
883명이 탐색했습니다.

 How to Avoid Replacing URLs Inside HTML Tags When Converting Text to Links?

HTML 태그에 대한 URL 대체 함정 극복

웹 개발자로서 일반 텍스트 URL을 HTML 앵커 태그 내에 포함된 하이퍼링크로 변환하는 것은 일반적인 일입니다. 일. 그러나 이 프로세스에서는 HTML 태그 내에 있는 URL을 제외하려고 할 때 문제가 발생할 수 있습니다.

이 경우 URL을 링크로 변환하는 초기 정규식은 포괄적이었지만 의도치 않게 꼬리표. 이로 인해 잘못된 HTML이 발생했습니다. 이 문제를 해결하려면 보다 세련된 접근 방식이 필요합니다.

XPath 및 DOM 활용

HTML 태그 외부의 URL을 선택적으로 변환하기 위해 강력한 도구인 XPath를 사용합니다. XML 및 HTML 구조 탐색. XPath를 사용하면 콘텐츠와 컨텍스트를 기반으로 특정 노드를 추출하는 정교한 쿼리가 가능합니다.

XPath를 사용하면 앵커 태그 내의 노드를 제외하면서 URL 패턴이 포함된 텍스트 노드를 대상으로 지정할 수 있습니다.

/html/body//text()[
    not(ancestor::a) and (
        contains(., "http://") or
        contains(., "https://") or
        contains(., "ftp://") )]
로그인 후 복사

이것은 XPath 쿼리는 URL을 포함하고 앵커 요소의 하위 항목이 아닌 텍스트 노드를 효과적으로 격리하여 외부 URL만 수정되도록 합니다.

비표준 문서 조각 조작

다음 , 대상 텍스트 노드를 하이퍼링크로 대체하기 위해 문서 조각을 활용합니다. 이 방법은 표준은 아니지만 원하는 HTML로 새 조각을 생성하고 이를 원본 텍스트 노드 위치에 삽입하여 비파괴적인 교체를 허용합니다.

foreach ($texts as $text) {
    $fragment = $dom->createDocumentFragment();
    $fragment->appendXML(
        preg_replace(
            "~((?:http|https|ftp)://(?:\S*?\.\S*?))(?=\s|\;|\)|\}|\[|\{|\}|\,\&quot;'|:|\<|$|\.\s)~i",
            '<a href=""></a>',
            $text->data
        )
    );
    $text->parentNode->replaceChild($fragment, $text);
}
로그인 후 복사

이 코드는 대상 텍스트 노드를 반복합니다. , preg_replace() 함수를 활용하여 URL을 앵커 태그로 묶고 수정된 HTML이 포함된 문서 조각을 생성한 다음 마지막으로 원본 텍스트 노드를 조각으로 바꿉니다.

정확한 URL 대체

XPath의 강력한 기능과 문서 조각 조작의 유연성을 결합하여 HTML 태그의 무결성을 유지하면서 외부 URL을 하이퍼링크로 효과적으로 변환할 수 있습니다. 이 접근 방식을 사용하면 img 또는 기타 태그 내의 URL이 영향을 받지 않게 됩니다.

위 내용은 텍스트를 링크로 변환할 때 HTML 태그 내의 URL 교체를 방지하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!