회원가입아이디/비번찾기
실시간 TV
홈으로
웹사이트 개발시 제가 자주쓰는 클래스 만들어봤습니다
15년 전
상세 설명은 주석문에 자세히 달려 있으니 필요한 함수들만 골라서 사용하세요..


class Func{
    /////////////////// DB 관련 ///////////////////////
    ##############################1###############################
    # DB 접속 정보를 가지고 있는 화일을 인쿠루드 시키고, 그의 변수 값들을
    # 넘기면 된다.
    # DB 접속 부분 성공 1반환, 실패 0반환/ 굳이 처리 하지 않아도 상관없다.
    #############################################################
    function dbConn($HOST, $USER, $PASS, $DBNAME) {
        $connect = @mysql_connect($HOST,$USER,$PASS);
        if(!$connect) $err = @mysql_error();
        $result = @mysql_select_db($DBNAME,$connect);
        if(!$result){
            $err = @mysql_error();
            return 0;
        } else    return 1;
    }

    ##############################2##################################
    # 반복되는 Row와 Fetch가 귀찮다.
    # 종류는 select 시 result, row를 받으면 되고, insert, update, delete
    # 는 exec를 받아서 실행만 하면 땡이다.
    ################################################################
    function sqlrow($query) {
        $result = @mysql_query($query);
        return @mysql_fetch_array($result);
    }

    function sqlresult($query) {return @mysql_query($query);}
    function sqlfetch($result) {return @mysql_fetch_array($result);}
    function sqlexe($query) {return @mysql_query($query);}

    ##############################3##################################
    # Count 수와 컬럼 하나의 값을 얻을수있다.
    ################################################################    
    function sqlcount($sql) {
        $result = @mysql_query($sql);
        $row = @mysql_fetch_array($result);
        return $row[0];
    }

    ##############################4##################################
    # 게시판에서 현재수보다 1큰 수를 반환하다.
    # 보통 mysql auto-increment를 쓰지만..  
    ################################################################    
    function sqlmaxno($sql) {
        $result = @mysql_query($sql);
        $row = @mysql_fetch_array($result);
        return $row[0]+1;
    }

/////////////////// DB 관련 끝///////////////////////


    ##############################5###############################
    # 날짜 구하기이다.. 수시로, 년, 월, 일, 날짜와 시간을 초로 반환한다.
    # 구분자는 $str로 하고 year, month, day, all, time, 현재 년-월-일으로 한다.
    # 사용법은 $str를 넘기면서 return 값을 받으면 된다.
    # 공동구매나 / 호스팅관리 등 날짜에 관련된 사이트 만들때 유용
    #############################################################
    function dateSeek($str) {
        if($str == "year") return date('Y', mktime());
        else if($str == "month") return date('m', mktime());
        else if($str == "day") return date('d', mktime());
        else if($str == "all") return date('Y-m-d', mktime());
        else if($str == "time") return mktime();
        else {
            $tmpArr=explode("-",$str);
            return mktime(0,0,0,$tmpArr[1], $tmpArr[2], $tmpArr[0]);
        }
    }


    ##############################6###############################
    # 한글을 깨지지 않게 자르는 함수이다.
    # 사용법은 함수호출과 더불어 자를 문자열과 길이를 입력하면된다.
    # 한글 자르는 함수는 많이 있지만. PHPSCHOOL에서 가장 호응이 좋은걸로
    # 택했다.
    #############################################################
    function hanCut($str, $len) {
        if ($len >= strlen($str)) return $str;
        $klen = $len - 1;
        while(ord($str[$klen]) & 0x80) $klen--;
        return substr($str, 0, $len - (($len + $klen + 1) % 2)) ."..";
    }


    ##############################7###############################
    # 페이지를 뒤로 강제로 Back 시키고자 할때 사용하면 된다.
    # 사용법은 왜 Back을 시키는지 이유를 인자로 넘기면 된다.
    ##############################################################
// script 오류가 나서.. 몇몇 부분에 "<", ">"를 "{", "}"로 바꿔 났으니까..
//echo 부분에만 고치시면 됩니다.
    function alertBack($msg) {
        echo "{script language=javascript}
        
        {/script}";
        exit;
    }

    ##############################8###############################
    # 페이지를 이동시킬때 쓴다.
    # 사용법은 url을 넘기면 끝~
    #############################################################
// script 오류가 나서.. 몇몇 부분에 "<", ">"를 "{", "}"로 바꿔 났으니까..
//echo 부분에만 고치시면 됩니다.

    function goUrl($url, $msg) {
        if(!empty($msg)) {
            echo "
                {script}
                    alert(\"$msg\");
                {/script}
                ";
        }
        echo "{meta http-equiv='refresh' content=\"0;URL=$url\"}";
        exit;
    }


    ############################## 9 ##################################
    # 파일 업로드할때 호출하면 된다.
    # file : form 의 file객체명
    # savedir : 저장할 경로 주의 : 디렉토리는 자동생성되지 않고, 권한 역시 777로 변경
    ################################################################
    function fileUpload($file, $file_name, $savedir) {
        if($file != "none") {
            $pos = strpos($file_name,".");
            $name = substr($file_name,0,$pos);
            $ext = substr($file_name,$pos+1);

            if(strpos($ext,"php") || !strcmp($ext,"php3") || !strcmp($ext,"inc") || !strcmp($ext,"pl") || !strcmp($ext,"cgi") ||    
                !strcmp($ext,"asp") || !strcmp($ext,"") ) {
                $this->alertBack("확장자가 $ext 인 화일은 업로드 하실수 없습니다.");
                exit;
            }
            $filename = $savedir.$file_name;
            $i = 1;
            while(file_exists("$filename")) {
                $filename = $savedir.$name."_".$i.".".$ext;
                $i++;
            }

            if(!copy($file,"$filename")) {
                $this->alertBack("파일 업로드를 실패했습니다.");
                exit;
            }
            if(!unlink($file)) {
                $this->alertBack("임시 파일을 삭제할 수 없습니다.");
                exit;
            }
            $file_name = str_replace($savedir,"",$filename);
            return $file_name;
        }
    }

    ##############################10##################################
    # 파일을 삭제할때 호출하면 된다.
    # file_name : 삭제할 화일명
    # savedir : 저장되어 있는 경로
    ################################################################
    function fileDelete($file_name,$savedir){
        $file = $savedir.$file_name;
        if(file_exists($file)) unlink($file);
    }

    ##############################11###############################
    # 파일을 다운로드 받고자 할때 사용하는 함수이다.
    # 사용법은 자기 자신의 페이지를 리플래쉬 하면서
    # 함수를 호출하는 방식으로 하면된다.
    #############################################################
    function saveFile($filename, $savedir) {
        $filepath = $savedir.$filename;

        if( strstr($_SERVER["HTTP_USER_AGENT"],"MSIE 5.5")){
            header("Content-Type: doesn/matter");
            header("Content-Disposition: filename=$filename");
            header("Content-Transfer-Encoding: binary");
            header("Pragma: no-cache");
            header("Expires: 0");
        } else{
            Header("Content-type: file/unknown");
            Header("Content-Disposition: attachment; filename=$filename");
            header("Content-Transfer-Encoding: binary");
            header("Pragma: no-cache");
            header("Expires: 0");
        }
        @readfile($filepath);
    }


    ##############################12##################################
    # 메일 발송하고자 할때 인수를 넘겨주면 된다. (html, text) 발송
    # to : 받는사람 메일, from : 발송자 메일, from_name : 발송자명
    # subject : 제목, contents : 내용, htmlcheck(y, n) : html발송여부
    ################################################################
    function sendMail($to, $from, $from_name, $subject, $contents, $htmlcheck) {
        $bodytext = $this->htmlText($contents,$htmlcheck);
        $additional = "From:$from_name<$from>"."\nContent-Type:text/html\nReply-To : $from \nX-Mailer: PHP/".phpversion();
        mail($to,$subject,$bodytext,$additional);
    }

    ############################## 13 ##############################
    # HTML 적용되는 컨텐츠..
    # html사용시에는 y, n으로 구분
    ################################################################
    function htmlText($text, $htmlcheck) {
        if($htmlcheck == "n") {
            $text  = stripslashes($text);
            $text = nl2br($text);
        }
        //html을 사용하는 경우
        else {
            $text  = stripslashes($text);
            $text = str_replace("<","<",$text);
            $text = str_replace(">",">",$text);
            $text = str_replace(""","\"",$text);
        }
        return $text;
    }

    ##############################14##################################
    # Paging 함수.. 특정값을 넘겨 받아 함수 호출만으로 페이징 처리를 끝낸다.
    # PageNo : 현재 페이지수
    # PageSize : 라인수
    # totalrows : 총 게시물 수
    # whereqry : 전 검색시에 쿼리값을 SQL 조건문
    # color : 현재 페이지인 경우 색상
    # class : a 로 걸리는 링크에 클래스를 준다.
    ################################################################
    function paging($PageNo, $PageSize, $totalrows, $whereqry, $color, $class) {
        $lastpgno=ceil($totalrows/$PageSize);

        if($lastpgno!=0) {
            if($PageNo>1) echo " ◀ ";
            else echo " ◀ ";

            if($PageNo>10) {
                $prevPage=floor(($PageNo-1)/10)*10;
                echo " ◁ ";
            }
            else echo " ◁ ";

            $i=0;
            $startpage=floor(($PageNo-1)/10)*10+1;
            while($i<10 && $startpage<=$lastpgno){
                if($PageNo<>$startpage) echo " $startpage ";
                else echo " $startpage ";
                $i++;
                $startpage=$startpage+1;
            }

            $nextPage=floor(($PageNo-1)/10)*10+11;
            if($nextPage<$lastpgno) echo " ▷ ";
            else echo " ▷ ";

            if($PageNo<$lastpgno) echo " ▶ ";
            else echo " ▶ ";
        }
    }

    ##############################15##################################
    # 데이타를 가져올 첫 시작 포인트를 반환한다.
    ################################################################
    function getDbStartNo($PageNo, $PageSize) {
        return ($PageNo-1)*$PageSize;
    }

    ##############################15##################################
    # 랜덤 문자열 유일키 발생(상품코드로 사용) / 총 50자인데.. 필요한 만큼만 자르자.
    ################################################################
    function getCode($len) {
        $SID = md5(uniqid(rand()));
        $code = substr($SID, 0, $len);
        return $code;
    }

    ################################################################
    # 세션키 생성 주문번호로 가장 괜찮을거 같아 만들었음
    ################################################################
    function getSession() {
        $SID = microtime();
        $str = str_replace("-","",date("ymdHis", mktime()));
        $session = $str.substr($SID, 4, 3);
        return $session;
    }

    ################################################################
    # 배열값들 살펴 보기(HTTP_POST_VARS, HTTP_GET_VARS, HTTP_SERVER_VARS 등
    # 이외에 가끔씩. 배열값이 제대로 넘어오는지 확인해야할때가 있다.. 있대 사용..^^
    ################################################################
    function arrayView($Value) {
        // 실제로 Array라는 문자열을 뿌려주지면 문자열이 아니여서 다시한번 string 관련함수 하나를 실행해 준다.
        $chkArray = ucfirst($Value); //첫문자를 대문자로 변환
        if($chkArray == "Array") while(list($key,$val)=each($Value)) echo $key." ==> ".$val."\n";
        else echo "배열이 아닙니다.";
        exit;
    }

    ##############################23##################################
    # Flash 코드도 꽤 길다.. 그래서. 함수화 해 버렸다.
    ##################################################################
    function flashLoad($urlpath, $width, $height) {
        echo "
            {object classid=\"clsid:D27CDB6E-AE6D-11cf-96B8-444553540000\" codebase=\"http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=5,0,0,0\"  width=\"$width\" height=\"$height\"}
                {param name=movie value=\"$urlpath\"}
                {param name=quality value=high}
                {embed src=\"$urlpath\" quality=high pluginspage=\"http://www.macromedia.com/shockwave/download/index.cgi?P1_Prod_Version=ShockwaveFlash\" type=\"application/x-shockwave-flash\" width=\"$width\" height=\"$height\"}
                {/embed}
            {/object}
        ";
    }

    /////////// 이하는 빌더형 사이트를  변수를 잘 기억하기 힘들어서 ^^ //////////
    ################################################################
    # 루트 시스템 절대 경로 얻기
    ################################################################
    function getServerSys() {
        return $_SERVER["DOCUMENT_ROOT"];
    }

    ################################################################
    # 루트 Url 얻기(메일 발송할때 사용)
    ################################################################
    function getSeverUrl() {
        return "http://".$_SERVER["HTTP_HOST"];
    }

    ################################################################
    # 현재 시스템 경로 얻기
    ################################################################
    function getSyspath() {
        return $_SERVER["SCRIPT_FILENAME"];
    }

    ################################################################
    # 현재 URL 경로 얻기
    ################################################################
    function getUrlpath() {
        return "http://".$_SERVER["HTTP_HOST"].$_SERVER["SCRIPT_NAME"];
    }

    ################################################################
    # 원격지 아이피 얻기
    ################################################################
    function getIp() {
        return $_SERVER["REMOTE_ADDR"];
    }
}

추천추천 : 245 추천 목록
번호 제목
2,880
 제이쿼리 랜덤으로 배경색 변경
2,879
 preg match에 관한 정규식
2,878
 Stream an audio file with MediaPlayer 오디오 파일 스트리밍 하기
2,877
 Audio Streaming PHP Code
2,876
 PHP $ SERVER 환경 변수 정리
2,875
 Vimeo (비메오) API 를 사용하여 플레이어 컨트롤하기
2,874
 iframe 사용시 하단에 발생하는 공백 제거방법
2,873
 아이프레임(iframe) 전체화면 가능하게 하기
2,872
 부트스트랩(bootstrapk)에서 사용하는 class명 정리
2,871
 부트스트랩 CSS
2,870
 크롬에서 마진 조절
2,869
 PHP 현재 페이지의 도메인명이나 url등의 정보 알아오기
2,868
 PHP preg match all()
2,867
 PHP 로 웹페이지 긁어오기 모든 방법 총정리!
2,866
 [PHP] 원격지 파일 주소 노출 안하고 curl로 다운로드 받기
2,865
 PHP 함수 정리
2,864
 아이프레임(iframe) 비율 유지하면서 크기 조절하는 방법
2,863
 PHP 배열에서 무작위로 하나 뽑아주는 array rand() 함수
2,862
 PHP 정규식 정리
2,861
 PHP 정규식을 활용한 태그 및 특정 문자열 제거 및 추출 방법
2,860
 php 크롤링 또는 파싱 함수, 정규식 모음
2,859
 제이쿼리 기본 명령어
2,858
 웹페이지 가로 모드세로 모드 인식하기
2,857
 모바일 웹 화면 강제 회전(가로모드 고정)
2,856
 [HTML5]에서 frameset 대체 방법과 iframe 속성
2,855
 HTML <Audio> 사용법
2,854
 윈도우10 시스템파일 손상 (초간단 오류 복구방법!!)
2,853
 PHP 파일 존재 여부 파악하기(로컬 파일 존재 및 원격지 파일 존재)
2,852
 [CSS] 박스 세로 가운데 중앙 정렬 6가지
2,851
 CSS Layout 수평 & 수직 정렬
목록
뮤직트로트 부산광역시 부산진구 가야동 ㅣ 개인정보취급방침
Copyright (C) musictrot All rights reserved.