수다닷컴

  • 해외여행
    • 괌
    • 태국
    • 유럽
    • 일본
    • 필리핀
    • 미국
    • 중국
    • 기타여행
    • 싱가폴
  • 건강
    • 다이어트
    • 당뇨
    • 헬스
    • 건강음식
    • 건강기타
  • 컴퓨터
    • 프로그램 개발일반
    • C언어
    • 비주얼베이직
  • 결혼생활
    • 출산/육아
    • 결혼준비
    • 엄마이야기방
  • 일상생활
    • 면접
    • 취업
    • 진로선택
  • 교육
    • 교육일반
    • 아이교육
    • 토익
    • 해외연수
    • 영어
  • 취미생활
    • 음악
    • 자전거
    • 수영
    • 바이크
    • 축구
  • 기타
    • 강아지
    • 제주도여행
    • 국내여행
    • 기타일상
    • 애플
    • 휴대폰관련
  • 프로그램 개발일반
  • C언어
  • 비주얼베이직

url을 찾는 정규식 질문드립니다.

꼬붕

2024.01.15

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 /

신청하기





COMMENT

댓글을 입력해주세요. 비속어와 욕설은 삼가해주세요.

  • 도손 2024-01-15

    답변감사드립니다. 많은 도움이 됐습니다.
    숙제는 어찌어찌해서 제출했습니다.(만점받았어요^^)

  • 앵초 2024-01-15

    단일, 텍스트 상에서 URL을 100% 정확하게 매칭 시키는것은 의외로 복잡합니다.
    그러다보니 정규식을 이용한 URL 자동 링크의 경우 한글등이 붙으면
    꼭 엉뚱하게 링크되는 사이트 들을 간간이 보실 것 입니다.
    네이버도 예외는 아니죠^^;;
    (바로 위 제 덧글에서 naver들어간 URL보시면 추출이 잘 못 된걸 알 수 있습니다.)
    쨌든, 보다 정확하게 하시려면 캡춰와 비 캡춰등을 좀 복잡하게 섞으셔야 할 듯..
    (어렴풋한 기억에 Java쪽 정

  • 미라 2024-01-15

    따라서, 이 경우에는 \로 시작해서 \로 끝나는 범위 안의 문장이 http로 시작되면서
    제시한 문법을 충족하는 단어들을 찾아내면 Valid URL로 볼 수 있습니다.

    고로, 제시한 HTML 파일에서 문장의 시작과 끝의 기준점을 정할 것인지가 관건일 것입니다.
    HTML TAG처럼 단일 또는 이중 따옴표 범위 안으로 정할 것인지..
    그렇지 않고 띄워쓰기등의 공백의 전 후로 정할 것인지등..
    어떤 제한 조건이 들어가면 좀 더 만족스러우리라 봅니다.

    그렇지

  • 징징몬 2024-01-15

    흠...역시 힘드네요..
    그럼 지금과 같은 패턴을 이용하는 방식의 프로그래밍으로는 불가능한가요?
    숙제를 저렇게 내줬는데;;ㅜㅜ

번호 제 목 글쓴이 날짜
2700422 버전에 관해 질문 라온제나 2025-07-04
2700393 mysql이 갑자기!!!!!!!!!!!!!!!에러가;; (2) 소미 2025-07-04
2700359 3.0 ) SimpleButton 상태 강제 변경 (3) 희선 2025-07-04
2700304 ie8 전용핵 문의 (3) 여자 2025-07-03
2700281 이런경우 어떻게 코딩해야 표준에 따르는건가요? (6) 늘솜 2025-07-03
2700230 질문이여 ! 뿡뿡몬 2025-07-03
2700205 액션스크립트책 좀 추천해주세요. (10) 화이트캣 2025-07-02
2700173 자바 소스인데 어떤게 에러인지..? (1) 호빵녀 2025-07-02
2700142 하단이 붙어있는 가변 레이아웃구조 질문드립니다. 이플 2025-07-02
2700089 이미지를 사다리꼴로 비틀게 하는 액션코드가 있나요? (4) 여름 2025-07-01
2700033 배경에 그라데이션을 넣으려고 하는데요.. (4) 화이티 2025-07-01
2700005 [질문] TextField 객체의 실제 높이 알아오는 방법 ? 천사의눈물 2025-07-01
2699978 FileReferenceList를 이용하여 업로드시 자꾸 실행속도가 느리다는 팝업이... (10) 데이비드 2025-06-30
2699944 자바스크립트가 많은 사이트는... (6) 희나리 2025-06-30
2699918 브라우저마다 다른 input과 텍스트 정렬 (3) 늘봄 2025-06-30
2699887 동적텍스트를 그래픽으로?? (2) 족장 2025-06-30
2699862 scope넣기 (1) 아인 2025-06-29
2699835 exe로 만드는 방법을....알려주세요.. (5) 방방 2025-06-29
2699809 롤오버할때 백그라운드 이미지로할때 alt설명은 어떻게해야하죠?..ㅠ (4) 반혈 2025-06-29
2699757 리스트뷰에 있는 내용을 랜덤으로 추출 세실 2025-06-28
<<  이전  1 2 3 4 5 6 7 8 9 10  다음  >>

수다닷컴 | 여러분과 함께하는 수다토크 커뮤니티 수다닷컴에 오신것을 환영합니다.
사업자등록번호 : 117-07-92748 상호 : 진달래여행사 대표자 : 명현재 서울시 강서구 방화동 890번지 푸르지오 107동 306호
copyright 2011 게시글 삭제 및 기타 문의 : clairacademy@naver.com