컴퓨터 / Computer

그누보드에서 인기검색어 특정 글자 수 이상으로 보여주기

공유지기 0 3,911 2018.10.26 23:59


mod_security를 적용한 시스템에서는 SQL_injection 공격을 막기 위해서 특수 문자를 배제시키는데, 이 와중에 입력한 키워드가 아래와 같이 나온다.


 a

 A

 8

 1

 http

 .

 .

 .


정상적인 단어 검색이면 좋겠지만 저런 식으로 철자만 나오면 인기검색어를 보여줄때 문제가 많이 생긴다. 그래서 두 가지 방법을 생각해 보았다.


 1) 입력할때 특정 길이 이하는 버리기

 2) 보여줄때 특정 길이 이상만 보여주기


그런데 1) 방법은 mod_security에서 끊어버리기 때문에 작업을 하기가 애매했다. 그래서 2)를 선택했다. 


 파일 : popular.lib.php

 위치 : /lib


위 파일을 연다. 약 15라인 쯤에 아래 sql 문이 있다.


 $sql = " select pp_word, count(*) as cnt from {$g5['popular_table']} where pp_date between '$date_gap' and '".G5_TIME_YMD."'  group by pp_word order by cnt desc, pp_word limit 0, $pop_cnt ";


위를 아래와 같이 바꾼다. 


 $sql = " select pp_word, count(*) as cnt from {$g5['popular_table']} where pp_date between '$date_gap' and '".G5_TIME_YMD."'  AND CHAR_LENGTH(pp_word) > 1 group by pp_word order by cnt desc, pp_word limit 0, $pop_cnt ";


즉 "AND CHAR_LENGTH(pp_word) > 1" 이 조건을 하나 더 넣어서 최소 2 글자 이상 있는 검색어만 노출시키도록 했다. 사이트 특징에 따라서 2나 3을 쓸 수도 있다.

Comments

여성 여름 시원한 캐주얼 끈 스니커즈 LK-L2
여성 바다 여행 여름모자 여자썬캡 UV 자외선차단
카피바라 인형 키링 키홀더 가방고리 열쇠고리 우정템
남자장화 레인부츠 낚시신발 장마 작업화 첼시부츠 고무신발 레인13
LG V50 IS 투명 젤리 케이스 V500
갤럭시 노트20 빨강머리앤v1 wk플립 N981 케이스
조아스 충전식 면도기 JS-5715 망날1세트추가구성 전
(2매)갤럭시탭 액티브3 8.0 고투명 액정보호필름
복주머니 파우치 외국인 선물 기념품
이케아 FINSMAK 핀스마크 미니 양초 캔들 유리 홀더
이케아 GLASIG글라시그 미니양초홀더 유리5x5cm 5개입
이케아 YLLEVAD 윌레바드 미니액자 화이트13x18cm
광천 우리맛김 재래 전장김 10봉
플라스틱 사각 다육이 화분(9 X 9cm)
소피 내몸에순한면 울트라 날개 대형 19+19P x 2개
FROG 이태리 천연 호두껍질 수세미(2P) 무흠집수세미

근영사 고급형 모조 대체전표 10개입
바이플러스
자동차 강아지 흔들이 인형 장식품 노호혼 닥스훈트
칠성상회

맨위로↑