테스트 사이트 - 개발 중인 베타 버전입니다

회원 목록 엑셀 다운로드 HOOK 기능

· 1년 전 · 999 · 7

@매직크레용 님께서 수정 해주신 회원 목록 엑셀 다운로드(https://sir.kr/g5_tip/22583) 소스를 HOOK 기능을 이용해서

파일 하나로 만들어 봤습니다.

 

@미니님a님이 알려주신 adm/view.php 를 통해서도 공부할 겸 제작해 봤습니다.

 

[code] 

// extend/mb_excel_export.extend.php 파일 생성 후 입력 또는 첨부파일 업로드

 

<?php 
if (!defined('_GNUBOARD_')) exit; // 개별 페이지 접근 불가


// 관리자 메뉴 hook
if (!function_exists('admim_menu_mb_excel_export')) {
    add_replace('admin_menu', 'admim_menu_mb_excel_export', G5_HOOK_DEFAULT_PRIORITY, 1);
    function admim_menu_mb_excel_export($menu)
    {
        $menu['menu200'][] = array('200110', '회원목록저장', G5_ADMIN_URL.'/view.php?call=mb_excel_export', 'mb_excel_export');
        return $menu;
    }
}

// 회원 목록 엑셀 저장
if (!function_exists('array_to_excel')) {
    // 엑셀 다운로드 함수
    function array_to_excel($data, $filename){
        header('Content-Type: application/vnd.ms-excel; charset=utf-8');
        header('Content-Disposition: attachment; filename="' . $filename . '.csv"'); // 확장자를 .csv로 변경
        header('Cache-Control: max-age=0');
        $out = fopen('php://output', 'w');
        fputs($out, "\xEF\xBB\xBF"); // UTF-8 with BOM
        fputcsv($out, array_keys($data[0]), ","); // 콤마 구분자 사용
        foreach ($data as $row) {
            fputcsv($out, $row, ","); // 콤마 구분자 사용
        }
        fclose($out);

    }
}
if (!function_exists('mb_excel_export_func')) {
    add_event('admin_request_handler_mb_excel_export', 'mb_excel_export_func', G5_HOOK_DEFAULT_PRIORITY, 2);
    function mb_excel_export_func($arr_query, $token)
    {
        global $g5, $member;
                
        $sql_common = " from {$g5['member_table']} ";
        
        $sql_search = " where (1) ";
        if ($stx) {
            $sql_search .= " and ( ";
            switch ($sfl) {
                case 'mb_point' :
                    $sql_search .= " ({$sfl} >= '{$stx}') ";
                    break;
                case 'mb_level' :
                    $sql_search .= " ({$sfl} = '{$stx}') ";
                    break;
                case 'mb_tel' :
                case 'mb_hp' :
                    $sql_search .= " ({$sfl} like '%{$stx}') ";
                    break;
                default :
                    $sql_search .= " ({$sfl} like '{$stx}%') ";
                    break;
            }
            $sql_search .= " ) ";
        }
        
        if ($is_admin != 'super')
            $sql_search .= " and mb_level <= '{$member['mb_level']}' ";
        
        if (!$sst) {
            $sst = "mb_datetime";
            $sod = "desc";
        }
        
        $sql_order = " order by {$sst} {$sod} ";
        
        $sql = " select * {$sql_common} {$sql_search} {$sql_order} ";
        $result = sql_query($sql);
        
        $data = array(); // Initialize the data array
        $i = 0; // $i 변수를 여기서 초기화
        
        while ($row = sql_fetch_array($result)) {
            $i++; // 각 회원 데이터마다 번호 증가
            // 데이터 가공
            $mb_gender = '';
            if ($row['mb_gender'] == 'M') {
                $mb_gender = '남성';
            } else if ($row['mb_gender'] == 'F') {
                $mb_gender = '여성';
            }
        
            $data[] = array(
                '번호' => $i,
                '아이디' => $row['mb_id'],
                '이름' => $row['mb_name'],
                '닉네임' => $row['mb_nick'],
                'E-MAIL' => $row['mb_email'],
                '전화번호' => $row['mb_tel'],
                '휴대폰번호' => hyphen_hp_number($row['mb_hp']),
                '성별' => $mb_gender,
                '생년월일' => $row['mb_birth'],
                '가입일' => $row['mb_datetime'],
                '최종접속일' => $row['mb_today_login'],
                '권한' => $row['mb_level']
            );
        }

        // HTML 테이블 출력 대신 엑셀 파일로만 출력하도록 수정
        if (count($data) > 0) {
            array_to_excel($data, '회원리스트');        
        } else {
            alert('회원 목록 저장 중 오류가 발생했습니다.');    
        }        
        exit;
    }
}

[/code]

 

 

댓글 작성

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

로그인하기

댓글 7개

1년 전

감사합니다 ^^

1년 전

@민트다이어리 답변 감사합니다.

hook은 아직 개념이 안잡혀서 감이 잘안오는데요 

유용해보입니다.

감사합니다.

1년 전

@김철용 저도 잘은 모르시만 include 의 다른 방식이라고 생각하시면 편하실꺼예요.^^

감사합니다

1년 전

감사합니다.

감사합니다.

게시글 목록

번호 제목
21184
21166
21157
21136
21132
21124
21119
21114
21106
21095
21069
21063
21060
21058
21053
21035
21032
21028
21009
21000
20994
20993
20984
20979
20958
20935
20934
20930
20913
20883