url을 찾는 정규식 질문드립니다.
꼬붕
String url = ((http://)|(HTTP://))((WWW\\.)|(www\\.))?([a-zA-Z0-9]+\\.)+[a-zA-Z]{2,4}((/(~[a-zA-Z][a-zA-Z0-9\\.\\-]*[a-zA-Z0-9]/?)?)([a-zA-Z0-9\\.\\-\\_]*/?)*);
패턴을 만들어봤는데요..
몇가지 구분하지 못하는 경우가 있습니다.
아래의 경우는 모두 url로 간주되어야 합니다.
http://www.abc.com
http://WWW.ABC.com/
HTTP://wWw.aBc.COm
http://abc.com
http://abc.com/
http://www.abc.abc.abc.abc.com
http://abc.com/~abc
http://abc.com/~abc/
http://abc.com/abc/abc/index.html
http://abc.com/~abc/ABC/index.pdf
이런식으로 ~ 유저네임이 올수있구요.. 유저네임과 그뒤에 나오는 디렉토리와 파일명들은 대소문자 구분합니다.
도메인은 대소문자 구분없구요.
그리고 .com 이나 .kr 처럼 마지막 최상위 도메인(이라고 하나요?)은 2~4자의 범위를 가지고 있습니다.
아래는 물가능한 url입니다.
http:/abc.com
http://abc.com/~.abc
http://abc.com/~~abc
등입니다.
유저네임은 무조건 ~뒤에 문자[a-zA-Z]로 시작해야 합니다.
제가 위에 만든 패턴은 http://abc.com/~.abc 를 http://abc.com/ 으로 구분해버립니다.
아래는 숙제로 내준 조건입니다.
Valid URLs (Uniform resource locators) which: Always start with http:// May (or may not) contain www after this. After www, it should contain a domain (follow the same rules as in domain for email addresses above). Each domain ends with a 2, 3 or 4 letter top-level domain. After the domain, it may (or may not) contain a user name: ~username. E.g. http://www.cs.uwindsor.ca/~lrueda After the domain or username it may (or may not) contain folders, sub-folder, sub-sub-folder, etc. (a hierarchy with potentially infinite levels) E.g., http://www.cs.uwindsor.ca/~lrueda/teaching/languages http://www2.cs.tum.edu/projects/cup At the end of the URL it may (or may not) contain the name of a web page. E.g. , http://www.cs.uwindsor.ca/~lrueda/teaching/languages/index.html ?xml:namespace prefix = o ns = urn:schemas-microsoft-com:office:office /
-
도손 2024-01-15
답변감사드립니다. 많은 도움이 됐습니다.
숙제는 어찌어찌해서 제출했습니다.(만점받았어요^^) -
앵초 2024-01-15
단일, 텍스트 상에서 URL을 100% 정확하게 매칭 시키는것은 의외로 복잡합니다.
그러다보니 정규식을 이용한 URL 자동 링크의 경우 한글등이 붙으면
꼭 엉뚱하게 링크되는 사이트 들을 간간이 보실 것 입니다.
네이버도 예외는 아니죠^^;;
(바로 위 제 덧글에서 naver들어간 URL보시면 추출이 잘 못 된걸 알 수 있습니다.)
쨌든, 보다 정확하게 하시려면 캡춰와 비 캡춰등을 좀 복잡하게 섞으셔야 할 듯..
(어렴풋한 기억에 Java쪽 정 -
미라 2024-01-15
따라서, 이 경우에는 \로 시작해서 \로 끝나는 범위 안의 문장이 http로 시작되면서
제시한 문법을 충족하는 단어들을 찾아내면 Valid URL로 볼 수 있습니다.
고로, 제시한 HTML 파일에서 문장의 시작과 끝의 기준점을 정할 것인지가 관건일 것입니다.
HTML TAG처럼 단일 또는 이중 따옴표 범위 안으로 정할 것인지..
그렇지 않고 띄워쓰기등의 공백의 전 후로 정할 것인지등..
어떤 제한 조건이 들어가면 좀 더 만족스러우리라 봅니다.
그렇지 -
징징몬 2024-01-15
흠...역시 힘드네요..
그럼 지금과 같은 패턴을 이용하는 방식의 프로그래밍으로는 불가능한가요?
숙제를 저렇게 내줬는데;;ㅜㅜ