URL 일치: 포괄적인 정규식 접근 방식
입력에서 URL을 추출할 때 다양한 처리할 수 있는 강력한 정규식을 갖는 것이 중요합니다. 시나리오. 이 경우 제공된 정규식은 "http" 또는 "https" 프로토콜 접두사가 없는 URL과 일치하지 않습니다. 이 문제를 해결하기 위해 우리는 두 가지 대체 정규식을 제안합니다.
HTTP/HTTPS 프로토콜이 필요한 URL의 경우:
https?:\/\/(www\.)?[-a-zA-Z0-9@:%._\+~#=]{1,256}\.[a-zA-Z0-9()]{1,6}\b([-a-zA-Z0-9()@:%_\+.~#?&//=]*)
HTTP가 없는 URL의 경우 /HTTPS 프로토콜 요구 사항:
[-a-zA-Z0-9@:%._\+~#=]{1,256}\.[a-zA-Z0-9()]{1,6}\b([-a-zA-Z0-9()@:%_\+.~#?&//=]*)
다음 정규 표현식 프로토콜 접두사가 있거나 없는 URL을 효과적으로 캡처합니다. 실험 목적으로 http://regexr.com?37i6s(프로토콜 접두사 포함) 및 http://regexr.com/3e6m0(프로토콜 접두사 없음)에서 이러한 표현식을 테스트할 수 있습니다.
다음은 예입니다. 자바스크립트 구현:
const expression = /[-a-zA-Z0-9@:%._\+~#=]{1,256}\.[a-zA-Z0-9()]{1,6}\b([-a-zA-Z0-9()@:%_\+.~#?&//=]*)/gi; const regex = new RegExp(expression); const t = 'www.google.com'; if (t.match(regex)) { alert("Successful match"); } else { alert("No match"); }
위 내용은 프로토콜 접두사가 있거나 없는 URL과 일치하는 강력한 정규식을 어떻게 만들 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!