컴퓨터 / Computer

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

공유지기 0 5,639 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

옆트임 롱 데님 스커트 연청 워싱 앞절개 청치마
여성 페이즐리 올림머리 헤어핀 반묶음 스카프 집게핀
2023 긴머리 웨이브 통가발 롱 자연스러운 전체 롱 가
남성가방 클러치백 남성 손가방 가방 CR9330
USB AM-CM 고속충전 케이블 0.5m
자전거 스마트폰 홀더 자전거휴대폰거치대 스마트폰거치대
샤오미호환 미에어2 그레이 헤파필터 공기청정기필터
자석 거치대 보조 철판 스티커 판 56x37mm DD-12028
무타공 면도기 스텐 거치대 걸이
철제 더블 옷장 무타공 튼튼한 스탠드 옷걸이 행거
화장품 수납정리대 파우더룸 메이크업 브러쉬
철제 스탠드 옷걸이 행거 2단 높은 DIY 인테리어 헹거
바르는 비트 220ml 소매찌든때 제거
미니 신가드 유소년 축구 정강이보호대 2P 9.5cm
업소용 스텐 국그릇 배식그릇 24종 소
5P 미용비누(오이)120g

반다이 에그엔젤코코밍 코코밍 스파이 코드네임346
칠성상회
고래상어 대용량 물고기 필통 파우치 상어 고래 귀여운 동물 필통 학용품 필기도구 사무용품 문구
칠성상회

맨위로↑