편리

juso.sir.co.kr 도로명 주소 검색 시스템 구축 가이드 - 주소검색

· 11년 전 · 3604

sphinx에서는 searchd 를 이용한 검색 쿼리문과 php 등을 이용한 api 를 제공하고 있습니다.

sphinx 설치를 위해 소스 파일을 압축해제했던 /usr/local/src/sphinx-2.1.4-release/api 경로로

이동해보면 php 등의 api 사용 예제 파일이 존재합니다. juso.sir.co.kr 에서는 php api 를 이용했습니다.

 

아래는 juso.sir.co.kr 에서 사용자의 검색 요청을 받아 검색 요청을 하고 결과를 처리하는 파일의 코드입니다.

 

[code]

<?php

include_once('./_common.php');

 

if(!$q) {

    $juso['error'] = '검색어를 입력해 주십시오.';

 

    echo $_GET['callback'].'('.json_encode($juso).')';

    exit;

}

 

// spninx api load

require ( G5_LIB_PATH.'/sphinx/sphinxapi.php' );

 

$cl = new SphinxClient ();

 

$host = $config['cf_sphinx_host'];

$port = $config['cf_sphinx_port'];

$index = $config['cf_sphinx_index'];

$rows = $config['cf_page_rows'];

 

$cl->SetServer ( $host, $port );

$cl->SetConnectTimeout ( 1 );

$cl->SetArrayResult ( true );

$cl->SetWeights ( array ( 100, 1 ) );

$cl->SetMatchMode ( SPH_MATCH_EXTENDED );

//$cl->setSortMode( SPH_SORT_ATTR_ASC, 'sn' );

 

if ($page == '') $page = 1;

$offset = ($page - 1) * $rows;

$cl->SetLimits ( $offset, $rows, $config['cf_max_rows']);

 

$query = '';

 

if($sido)

    $query .= ' @sido "'.$sido.'" ';

 

if($gugun)

    $query .= ' @gugun "'.$gugun.'" ';

 

$sword = explode(' ', trim($q));

 

$field = '(doro,jibeon)';

 

foreach($sword as $val) {

    $word = trim($val);

    if(!$word)

        continue;

 

    $query .= ' @'.$field.' "'.$word.'*" ';

}

 

$res = $cl->Query ( $query, $index );

 

$error = '';

if ($res === false) {

    $error = '검색실패 : ' . $cl->GetLastError();

} else {

    $total_count = $res['total'];

    $total_page  = ceil($total_count / $rows);  // 전체 페이지 계산

 

    $count = count($res['matches']);

 

    if($_GET['link'] != 'false')

        $link = true;

    else

        $link = false;

 

    ob_start();

?>

 

<div class="result_msg">

    검색결과 <b><?php echo number_format($total_count); ?></b>

</div>

 

<?php

    for($i=0; $i<$count; $i++) {

        $data = $res['matches'][$i]['attrs'];

 

        $eupmyeon = false;

        $zipcode = preg_replace('/([0-9]{3})([0-9]{3})/', '\\1-\\2', $data['zipcode']);

        $zip = explode('-', $zipcode);

        $zip1 = $zip[0];

        $zip2 = $zip[1];

        $addr1 = $data['sido'].' '.$data['gugun'];

        if($data['beopname'] && preg_match('/(읍|면)$/', $data['beopname'])) {

            $addr1 .= ' '.$data['beopname'];

            $eupmyeon = true;

        }

        $addr1 .= ' '.$data['doroname'];

        if($data['jiha'])

            $jiha = ' 지하';

        else

            $jiha = ' ';

        $addr1 .= $jiha.$data['geonbon'];

        if($data['geonbu'])

            $addr1 .= '-'.$data['geonbu'];

 

        $addr3 = '';

        if($data['beopname'] && !$eupmyeon)

            $addr3 = ' ('.$data['beopname'];

        if($data['geonname'] || $data['geonsangse']) {

            if($addr3)

                $addr3 .= ', ';

            else

                $addr3 = ' (';

        }

        if($data['geonname']) {

            $addr3 .= $data['geonname'];

        } else {

            if($data['geonsangse'])

                $addr3 .= $data['geonsangse'];

            else {

                if($data['daryang'] && !$data['geonname2']) {

                    if($addr3)

                        $addr3 .= ', '.$data['daryang'];

                    else

                        $addr3 .= ' ('.$data['daryang'];

                } else if(!$data['daryang'] && $data['geonname2']) {

                    if($addr3)

                        $addr3 .= ', '.$data['geonname2'];

                    else

                        $addr3 .= ' ('.$data['geonname2'];

                }

            }

        }

        if($addr3)

            $addr3 .= ')';

 

        $addr_ji = $data['sido'].' '.$data['gugun'];

        if($data['beopname'])

            $addr_ji .= ' '.$data['beopname'];

        if($data['ri'])

            $addr_ji .= ' '.$data['ri'];

        if($data['san'])

            $san = ' 산';

        else

            $san = ' ';

        $addr_ji .= $san.$data['jibon'];

        if($data['jibu'])

            $addr_ji .= '-'.$data['jibu'];

 

        if($data['geonname']) {

            $addr_ji .= ' '.$data['geonname'];

        } else {

            if($data['geonsangse'])

                $addr_ji .= ' '.$data['geonsangse'];

        }

 

        $addr3 = htmlentities($addr3, ENT_QUOTES, "UTF-8");

        $addr_ji = htmlentities($addr_ji, ENT_QUOTES, "UTF-8");

 

        if($i == 0)

            echo '<ul>'.PHP_EOL;

        echo '<li>'.PHP_EOL;

        echo '<span></span>';

        if($link)

            echo "<a href='#' onclick='put_data(\"".$zip1."\", \"".$zip2."\", \"".trim($addr1)."\", \"".trim($addr3)."\", \"".trim($addr_ji)."\"); return false;'>";

        echo '<strong>'.$zipcode.'</strong>';

        echo ' '.$addr1;

        echo $addr3;

        if($link)

            echo '</a>';

        echo '<div>(지번주소) '.$addr_ji.'</div>';

        echo '</li>'.PHP_EOL;

    }

 

    if($i > 0)

        echo '</ul>';

    else

        echo '<div class="result_msg result_fail">검색결과가 없습니다.</div>';

 

    //echo '<p>실행시간 : '.$res['time'].'</p>';

 

    $pagelist = get_paging($is_mobile ? $config['cf_mobile_list_pages'] : $config['cf_list_pages'], $page, $total_page);

    echo $pagelist;

 

    $contents = ob_get_contents();

    ob_end_clean();

}

 

$jusu = array();

$juso['error'] = $error;

$juso['juso'] = $contents;

 

echo $_GET['callback'].'('.json_encode($juso).')';

?> 

[/code]

 

sphinx의 api 관련 자료는 http://sphinxsearch.com/docs/archives/2.1.4/api-reference.html 를 참고하시면 됩니다.

그외 검색관련 query 는 http://sphinxsearch.com/docs/archives/2.1.4/searching.html 를 참고하시면 됩니다.

|
댓글을 작성하시려면 로그인이 필요합니다. 로그인

프로그램

+
제목 글쓴이 날짜 조회
11년 전 조회 1,959
11년 전 조회 801
11년 전 조회 814
11년 전 조회 749
11년 전 조회 1,173
11년 전 조회 810
11년 전 조회 730
11년 전 조회 1,052
11년 전 조회 1,384
11년 전 조회 1,017
11년 전 조회 946
11년 전 조회 979
11년 전 조회 1,814
11년 전 조회 884
11년 전 조회 941
11년 전 조회 2,721
11년 전 조회 2,270
11년 전 조회 1,147
11년 전 조회 1,640
11년 전 조회 1,247
11년 전 조회 1,180
11년 전 조회 1,303
11년 전 조회 1,908
11년 전 조회 932
11년 전 조회 1,950
11년 전 조회 2,177
11년 전 조회 873
11년 전 조회 1,021
11년 전 조회 732
11년 전 조회 1,692
11년 전 조회 1,572
11년 전 조회 1,052
11년 전 조회 930
11년 전 조회 702
11년 전 조회 1,084
11년 전 조회 1,535
11년 전 조회 602
11년 전 조회 802
11년 전 조회 882
11년 전 조회 902
11년 전 조회 1,107
11년 전 조회 2,635
11년 전 조회 2,290
11년 전 조회 1,839
11년 전 조회 1,414
11년 전 조회 1,353
11년 전 조회 2,331
11년 전 조회 1,593
11년 전 조회 2,795
11년 전 조회 3,605
11년 전 조회 3,728
11년 전 조회 3,789
11년 전 조회 3,912
11년 전 조회 2,370
11년 전 조회 1.7만
11년 전 조회 1,352
11년 전 조회 1,100
11년 전 조회 1,038
11년 전 조회 875
11년 전 조회 1,010
11년 전 조회 825
11년 전 조회 664
11년 전 조회 1,059
11년 전 조회 798
11년 전 조회 714
11년 전 조회 1,041
11년 전 조회 926
11년 전 조회 719
11년 전 조회 869
11년 전 조회 890
11년 전 조회 901
11년 전 조회 1,000
11년 전 조회 635
11년 전 조회 689
11년 전 조회 869
11년 전 조회 725
11년 전 조회 757
11년 전 조회 715
11년 전 조회 648
11년 전 조회 716
11년 전 조회 1,329
11년 전 조회 659
11년 전 조회 972
11년 전 조회 861
11년 전 조회 606
11년 전 조회 627
11년 전 조회 712
11년 전 조회 716
11년 전 조회 1,249
11년 전 조회 4,132
11년 전 조회 1,200
11년 전 조회 929
11년 전 조회 1,409
11년 전 조회 7,534
11년 전 조회 1,126
11년 전 조회 2,336
11년 전 조회 1,150
11년 전 조회 1,198
11년 전 조회 1,487
11년 전 조회 988
🐛 버그신고