4. function url_auto_link($str)
이것의 원래 의도는 href 나 src 에 들어가있는 url은 제외하고 http|https|ftp|telnet|news|mms 로 시작되는 url 에 링크를 걸어주는 것입니다.
그러나 이것 역시 이전 것과 마찬가지로 앞부분이 정확히 동작하지 않습니다.
[] 은 문자 하나하나 지정하거나 어디에서 어디까지리 라는 범위를 지정하는 용도로 사용됩니다.
그리고 그것이 포함되지 않는 그 이외의 문자를 표현할때는 [^] 형태와 같이 사용되어집니다.
즉, 문자열을 [] 속에 지정하는 것이 아닙니다.
그리고 [] 속에서는 정규식에서 의미있는 메타 문자라 할지라도 모두 일반문자와 같이 취급됩니다.
일반 문자로 취급되기때문에 정규식 전체를 묶는 " 나 [] 를 제외하고는 \(에스케이프)를 사용하지 않습니다.
결국,
[^(HREF=\"?'?)|(SRC=\"?'?)] 은
[^()=\"'?hrefsrc] 같은 의미가 됩니다.
따라서, href 나 src 가 없을 경우에 매치할려고 하면
[^(HREF=\"?'?)|(SRC=\"?'?)] 이렇게 하는 것이 아니라
(((href|src)\s*=\s*(\"|'|)){0}) 와 같이 사용하여야 합니다.
[a-zA-Z0-9\.-]+ 도메인(서브도메인포함)으로 올수 있는 문자가 하나 이상 있다는 의미입니다.
사실, 도메인이 한자로 이루어 질수 없기 때문에 + 대신에 {4,} 이런식으로 네자 이상이라고 붙여 주는것이 더 좋을것 같습니다.
a.co 라고 해도 4자가 되니까 말입니다.
[가-힣\xA1-\xFEa-zA-Z0-9\.:&#=_\?\/~\+%@;\-\|\,\(\)]+
이부분은 도메인을 제외한 url 부분에 올수 있는 문자들을 나열하고
그것이 하나 이상인것을 의미합니다.
그러나 이부분 역시 검색어 stx=<> 나 다른 특수문자를 걸었을수도 있기 때문에 딱 맞다고는 할수 없습니다.
그리고, 완벽하게 패턴을 만들수도 없는 부분입니다.
원래 원하는 패턴이 href 나 src 와 붙지 않은 모든 url 이니.....
와 같은 패턴을 제안할수 있습니다.
(다음에 ?: 은 () 은 서브패턴으로 이것은 모두 순서대로 매치된것이 번호가 매겨지는데,
?: 을 사용함으로 해서 그부분은 번호로 매기지 않게 됩니다.
따라서 원래 \\5 로 쓰여야 하지만 \\1 로 쓴것입니다.
이메일은 아이디@도메인 이므로
@를 기준으로 앞부분은 아이디에 대한 패턴이고
뒷부분은 도메인에 대한 패턴입니다.
아이디 부분에 . 이 들어갈 일이 있는지는 모르겟지만
아이디 부분의 패턴은 [0-9a-z_-]+ 정도로 하면 될것 같고,
도메인부분은 [a-z0-9._-]{4,} 정도로 하면 될것 같습니다.
따라서
\\0 은 서브패턴으로 지정된 부분 말고 전체 패턴에 매치되는 부분을 뜻합니다.
이것은 이전에도 나왓듯이 단순 문자열 치환의 반복이므로
$str = preg_replace("/([^(HREF=\"?'?)|(SRC=\"?'?)]|\(|^)((http|https|ftp|telnet|news|mms):\/\/[a-zA-Z0-9\.-]+\.[가-힣\xA1-\xFEa-zA-Z0-9\.:&#=_\?\/~\+%@;\-\|\,\(\)]+)/i", "\\1<A HREF=\"\\2\" TARGET='{$config['cf_link_target']}'>\\2</A>", $str);
이것의 원래 의도는 href 나 src 에 들어가있는 url은 제외하고 http|https|ftp|telnet|news|mms 로 시작되는 url 에 링크를 걸어주는 것입니다.
그러나 이것 역시 이전 것과 마찬가지로 앞부분이 정확히 동작하지 않습니다.
[] 은 문자 하나하나 지정하거나 어디에서 어디까지리 라는 범위를 지정하는 용도로 사용됩니다.
그리고 그것이 포함되지 않는 그 이외의 문자를 표현할때는 [^] 형태와 같이 사용되어집니다.
즉, 문자열을 [] 속에 지정하는 것이 아닙니다.
그리고 [] 속에서는 정규식에서 의미있는 메타 문자라 할지라도 모두 일반문자와 같이 취급됩니다.
일반 문자로 취급되기때문에 정규식 전체를 묶는 " 나 [] 를 제외하고는 \(에스케이프)를 사용하지 않습니다.
결국,
[^(HREF=\"?'?)|(SRC=\"?'?)] 은
[^()=\"'?hrefsrc] 같은 의미가 됩니다.
따라서, href 나 src 가 없을 경우에 매치할려고 하면
[^(HREF=\"?'?)|(SRC=\"?'?)] 이렇게 하는 것이 아니라
(((href|src)\s*=\s*(\"|'|)){0}) 와 같이 사용하여야 합니다.
[a-zA-Z0-9\.-]+ 도메인(서브도메인포함)으로 올수 있는 문자가 하나 이상 있다는 의미입니다.
사실, 도메인이 한자로 이루어 질수 없기 때문에 + 대신에 {4,} 이런식으로 네자 이상이라고 붙여 주는것이 더 좋을것 같습니다.
a.co 라고 해도 4자가 되니까 말입니다.
[가-힣\xA1-\xFEa-zA-Z0-9\.:&#=_\?\/~\+%@;\-\|\,\(\)]+
이부분은 도메인을 제외한 url 부분에 올수 있는 문자들을 나열하고
그것이 하나 이상인것을 의미합니다.
그러나 이부분 역시 검색어 stx=<> 나 다른 특수문자를 걸었을수도 있기 때문에 딱 맞다고는 할수 없습니다.
그리고, 완벽하게 패턴을 만들수도 없는 부분입니다.
원래 원하는 패턴이 href 나 src 와 붙지 않은 모든 url 이니.....
$str = preg_replace("`(?:(?:(?:href|src)\s*=\s*(?:\"|'|)){0})((http|https|ftp|telnet|news|mms)://[^\"'\s()]+)`", "<A HREF=\"\\1\" TARGET='{$config['cf_link_target']}'>\\1</A>", $str);
와 같은 패턴을 제안할수 있습니다.
(다음에 ?: 은 () 은 서브패턴으로 이것은 모두 순서대로 매치된것이 번호가 매겨지는데,
?: 을 사용함으로 해서 그부분은 번호로 매기지 않게 됩니다.
따라서 원래 \\5 로 쓰여야 하지만 \\1 로 쓴것입니다.
$str = preg_replace("/([0-9a-z]([-_\.]?[0-9a-z])*@[0-9a-z]([-_\.]?[0-9a-z])*\.[a-z]{2,4})/i", "<a href='mailto:\\1'>\\1</a>", $str);이것은 이메일이 발견 되면 이메일 링크로 치환 해주는 것입니다.
이메일은 아이디@도메인 이므로
@를 기준으로 앞부분은 아이디에 대한 패턴이고
뒷부분은 도메인에 대한 패턴입니다.
아이디 부분에 . 이 들어갈 일이 있는지는 모르겟지만
아이디 부분의 패턴은 [0-9a-z_-]+ 정도로 하면 될것 같고,
도메인부분은 [a-z0-9._-]{4,} 정도로 하면 될것 같습니다.
따라서
$str = preg_replace("/[0-9a-z_-]+@[a-z0-9._-]{4,}/i", "<a href='mailto:\\0'>\\0</a>", $str);정도로 제안 할수 있습니다.
\\0 은 서브패턴으로 지정된 부분 말고 전체 패턴에 매치되는 부분을 뜻합니다.
$str = preg_replace("/\t_nbsp_\t/", " " , $str);
$str = preg_replace("/\t_lt_\t/", "<", $str);
$str = preg_replace("/\t_gt_\t/", ">", $str);
이것은 이전에도 나왓듯이 단순 문자열 치환의 반복이므로
$str = str_replace(array(), araay(), $str);형태로 사용하는 좋습니다.
댓글 7개
게시글 목록
| 번호 | 제목 |
|---|---|
| 26560 | |
| 24588 | |
| 31642 | |
| 31638 | |
| 31633 | |
| 31630 | |
| 31625 | |
| 19452 | |
| 6719 |
개발자
개발자님 찾아요
|
| 6718 |
개발자
제작자구합니다~
|
| 6717 |
개발자
개발자님 구해요
|
| 6715 |
개발자
비용과 기간문의
1
|
| 27797 | |
| 30907 | |
| 30904 | |
| 6714 | |
| 6713 | |
| 27791 | |
| 19450 |
JavaScript
제니퍼소프트, UI 소스 오픈 하여군요
1
|
| 6712 | |
| 6711 | |
| 6709 | |
| 6708 | |
| 27790 | |
| 19447 |
jQuery
좋은... swipe 스크롤
2
|
| 6706 | |
| 6703 | |
| 6702 | |
| 6701 | |
| 6697 | |
| 6692 | |
| 27783 | |
| 6691 | |
| 6687 | |
| 6685 | |
| 6683 | |
| 6682 | |
| 19446 | |
| 27770 | |
| 19445 | |
| 27768 | |
| 6681 | |
| 6675 | |
| 6674 | |
| 19444 |
jQuery
swipe 좌우스크롤
|
| 6672 | |
| 6671 | |
| 27761 | |
| 6670 | |
| 30900 | |
| 24585 | |
| 6660 | |
| 6655 | |
| 6653 | |
| 31624 |
홈페이지기초
HTML과정 - 20. HTML colors
|
| 6651 | |
| 31623 |
홈페이지기초
HTML과정 - 19. HTML iframes
|
| 31621 |
홈페이지기초
HTML과정 - 18. HTML forms
1
|
| 19443 |
MySQL
MYSQL 오늘 날짜 뽑아오기
|
| 6650 | |
| 31620 |
홈페이지기초
HTML과정 - 17. HTML layout
|
| 31619 |
홈페이지기초
HTML과정 - 16. HTML blocks
|
| 31612 |
홈페이지기초
HTML과정 - 15. HTML lists
6
|
| 31611 |
홈페이지기초
HTML과정 - 14. HTML tables
|
| 27746 | |
| 31605 |
홈페이지기초
HTML과정 - 13. HTML images
5
|
| 6648 | |
| 20781 | |
| 31603 | |
| 31600 |
홈페이지기초
HTML과정 - 11. HTML head
2
|
| 6645 | |
| 6643 | |
| 6642 | |
| 6640 | |
| 20777 | |
| 31597 |
홈페이지기초
HTML과정 - 10. HTML Links
2
|
| 6637 | |
| 19442 | |
| 31594 | |
| 31591 | |
| 31589 | |
| 31586 | |
| 31584 |
홈페이지기초
HTML과정 - 5. HTML 속성
1
|
| 20758 | |
| 19440 | |
| 31575 |
홈페이지기초
HTML과정 - 4. HTML 엘리먼트
8
|
| 31567 |
홈페이지기초
HTML과정 - 3. HTML 기초 예제들
7
|
| 20747 | |
| 6636 | |
| 31563 | |
| 31552 |
홈페이지기초
HTML과정 - 1. HTML이 무엇인가?
10
|
| 27743 | |
| 24579 | |
| 6630 | |
| 6628 | |
| 6620 | |
| 6617 | |
| 27732 | |
| 24577 | |
| 6616 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기