찾다
백엔드 개발PHP 튜토리얼PHP를 통해 mysql 데이터를 백업하는 코드

  1. ##################
  2. //구성
  3. ###################
  4. // 백업 디렉터리 이름 정의
  5. define('BACKUP_DIR', './myBackups' ) ;
  6. // 데이터베이스 자격 증명 정의
  7. define('HOST', 'localhost' ) ;
  8. define('USER', 'testd!b' ) ;
  9. define('PASSWORD', 'k ^$2y4n9@#VV' ) ;
  10. define('DB_NAME', 'test123' ) ;
  11. /*
  12. SQL 파일의 파일 이름을 정의하세요
  13. 파일을 Amazon의 S3 서비스는 소문자만 사용하세요
  14. */
  15. $fileName = 'mysqlbackup--' . 날짜('d-m-Y') . '@'.date('h.i.s').'.sql' ;
  16. // 실행 시간 제한 설정
  17. if(function_exists('max_execution_time')) {
  18. if( ini_get('max_execution_time') > 0 ) set_time_limit(0) ;
  19. }
  20. #######################
  21. //구성 끝
  22. ########################
  23. // 다음 사항을 확인하세요. 디렉토리가 이미 생성되었으며 적절한 권한이 있습니다
  24. if (!file_exists(BACKUP_DIR)) mkdir(BACKUP_DIR , 0700) ;
  25. if (!is_writable(BACKUP_DIR)) chmod(BACKUP_DIR , 0700) ;
  26. // ".htaccess" 파일을 생성하면 백업 디렉터리에 대한 직접 액세스가 제한됩니다.
  27. $content = 'deny from all' ;
  28. $file = new SplFileObject(BACKUP_DIR . '/.htaccess' , "w") ;
  29. $file->fwrite($content) ;
  30. $mysqli = new mysqli(HOST , USER , PASSWORD , DB_NAME) ;
  31. if (mysqli_connect_errno())
  32. {
  33. printf("연결 실패: %s", mysqli_connect_error());
  34. exit();
  35. }
  36. // 소개 정보
  37. $return .= "-- n";
  38. $return .= "-- MySQL 백업 시스템 n";
  39. $return .= "--n";
  40. $return .= '-- 내보내기 생성됨: ' . 날짜("연/월/일") . ' 에 ' . 날짜("h:i") . "nnn";
  41. $return = "--n";
  42. $return .= "-- 데이터베이스: " . DB_NAME. "n";
  43. $return .= "--n";
  44. $return .= "-- ---------- --------------n";
  45. $return .= "-- ---------- ---------------n";
  46. $return . = '자동 커밋 설정 = 0;' ."n" ;
  47. $return .= 'SET FOREIGN_KEY_CHECKS=0 ;' ."n" ;
  48. $tables = array() ;
  49. // 이 데이터베이스에 어떤 테이블이 있는지 탐색
  50. $result = $mysqli->query('SHOW TABLES' ) ;
  51. // "$result"를 순환하고 콘텐츠를 배열에 넣습니다
  52. while ($row = $result->fetch_row())
  53. {
  54. $tables[] = $row[0] ;
  55. }
  56. // 각 테이블을 순환
  57. foreach($tables as $table)
  58. {
  59. // 각 테이블의 콘텐츠 가져오기
  60. $result = $mysqli->query('SELECT * FROM '.$table) ;
  61. // 각 테이블의 필드(열) 수를 가져옵니다
  62. $num_fields = $mysqli->field_count ;
  63. // 테이블 정보 추가
  64. $return . = "--n" ;
  65. $return .= '-- 테이블 `' 의 테이블 구조. $테이블 . ''' . "n" ;
  66. $return .= "--n" ;
  67. $return.= '존재하는 경우 테이블 삭제 `'.$table.'`;' . "n" ;
  68. // 테이블 셰마 가져오기
  69. $shema = $mysqli->query('SHOW CREATE TABLE '.$table) ;
  70. // 테이블 셰마 추출
  71. $tableshema = $shema->fetch_row() ;
  72. // 코드에 table-shema 추가
  73. $return.= $tableshema[1].";" . "nn" ;
  74. // 각 테이블 행을 순환
  75. while($rowdata = $result->fetch_row())
  76. {
  77. // 테이블에 데이터를 삽입할 코드 준비
  78. $return .= 'INSERT INTO `'.$table .'` VALUES ( ' ;
  79. // 각 행의 데이터 추출
  80. for($i=0; $i{
  81. $return .= '"'.$rowdata[$i] . ""," ;
  82. }
  83. // 마지막 쉼표를 삭제합니다
  84. $return = substr(" $return", 0, -1) ;
  85. $return .= ");" ."n" ;
  86. }
  87. $return .= "nn" ;
  88. }
  89. // 연결을 닫습니다
  90. $mysqli->close() ;
  91. $return . = 'SET FOREIGN_KEY_CHECKS = 1; ' . "n" ;
  92. $return .= '커밋 ; ' . "n" ;
  93. $return .= 'SET AUTOCOMMIT = 1 ; ' . "n" ;
  94. //$file = file_put_contents($fileName , $return) ;
  95. $zip = new ZipArchive() ;
  96. $resOpen = $zip->open(BACKUP_DIR . '/' .$fileName.".zip" , ZIPARCHIVE::CREATE) ;
  97. if( $resOpen ){
  98. $zip->addFromString( $fileName , "$return" ) ;
  99. }
  100. $zip->close() ;
  101. $fileSize = get_file_size_unit(filesize(BACKUP_DIR . "/". $fileName . '.zip')) ;
  102. $message =

    백업 완료 ,


  103. 아카이브 이름은 $fileName 파일 크기는 $fileSize 입니다.
  104. 이 zip 아카이브는 보호된 디렉토리에 저장되어 있으므로 웹 브라우저를 통해 접근할 수 없습니다.
  105. 이 백업을 다른 파일 시스템으로 전송하는 것이 좋습니다. 즐겨 사용하는 FTP 클라이언트를 사용하여 아카이브를 다운로드하세요.
  106. msg;
  107. echo $message ;
  108. // 기능 파일 크기 뒤에 적절한 단위를 추가합니다.
  109. function get_file_size_unit($file_size){
  110. switch (true) {
  111. case ($file_size/1024 return intval($file_size ) . " 바이트" ;
  112. 중단;
  113. 케이스 ($file_size/1024 >= 1 && $file_size/(1024*1024) return intval($file_size/1024) ." KB " ;
  114. break;
  115. 기본값:
  116. return intval($file_size/(1024*1024)) ." MB" ;
  117. }
  118. }
复제代码

PHP, MySQL


성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
PHP 실행 : 실제 예제 및 응용 프로그램PHP 실행 : 실제 예제 및 응용 프로그램Apr 14, 2025 am 12:19 AM

PHP는 전자 상거래, 컨텐츠 관리 시스템 및 API 개발에 널리 사용됩니다. 1) 전자 상거래 : 쇼핑 카트 기능 및 지불 처리에 사용됩니다. 2) 컨텐츠 관리 시스템 : 동적 컨텐츠 생성 및 사용자 관리에 사용됩니다. 3) API 개발 : 편안한 API 개발 및 API 보안에 사용됩니다. 성능 최적화 및 모범 사례를 통해 PHP 애플리케이션의 효율성과 유지 보수 성이 향상됩니다.

PHP : 대화식 웹 컨텐츠를 쉽게 만들 수 있습니다PHP : 대화식 웹 컨텐츠를 쉽게 만들 수 있습니다Apr 14, 2025 am 12:15 AM

PHP를 사용하면 대화식 웹 컨텐츠를 쉽게 만들 수 있습니다. 1) HTML을 포함하여 컨텐츠를 동적으로 생성하고 사용자 입력 또는 데이터베이스 데이터를 기반으로 실시간으로 표시합니다. 2) 프로세스 양식 제출 및 동적 출력을 생성하여 htmlspecialchars를 사용하여 XSS를 방지합니다. 3) MySQL을 사용하여 사용자 등록 시스템을 작성하고 Password_Hash 및 전처리 명세서를 사용하여 보안을 향상시킵니다. 이러한 기술을 마스터하면 웹 개발의 효율성이 향상됩니다.

PHP 및 Python : 두 가지 인기있는 프로그래밍 언어를 비교합니다PHP 및 Python : 두 가지 인기있는 프로그래밍 언어를 비교합니다Apr 14, 2025 am 12:13 AM

PHP와 Python은 각각 고유 한 장점이 있으며 프로젝트 요구 사항에 따라 선택합니다. 1.PHP는 웹 개발, 특히 웹 사이트의 빠른 개발 및 유지 보수에 적합합니다. 2. Python은 간결한 구문을 가진 데이터 과학, 기계 학습 및 인공 지능에 적합하며 초보자에게 적합합니다.

PHP의 지속적인 관련성 : 여전히 살아 있습니까?PHP의 지속적인 관련성 : 여전히 살아 있습니까?Apr 14, 2025 am 12:12 AM

PHP는 여전히 역동적이며 현대 프로그래밍 분야에서 여전히 중요한 위치를 차지하고 있습니다. 1) PHP의 단순성과 강력한 커뮤니티 지원으로 인해 웹 개발에 널리 사용됩니다. 2) 유연성과 안정성은 웹 양식, 데이터베이스 작업 및 파일 처리를 처리하는 데 탁월합니다. 3) PHP는 지속적으로 발전하고 최적화하며 초보자 및 숙련 된 개발자에게 적합합니다.

PHP의 현재 상태 : 웹 개발 동향을 살펴보십시오PHP의 현재 상태 : 웹 개발 동향을 살펴보십시오Apr 13, 2025 am 12:20 AM

PHP는 현대 웹 개발, 특히 컨텐츠 관리 및 전자 상거래 플랫폼에서 중요합니다. 1) PHP는 Laravel 및 Symfony와 같은 풍부한 생태계와 강력한 프레임 워크 지원을 가지고 있습니다. 2) Opcache 및 Nginx를 통해 성능 최적화를 달성 할 수 있습니다. 3) PHP8.0은 성능을 향상시키기 위해 JIT 컴파일러를 소개합니다. 4) 클라우드 네이티브 애플리케이션은 Docker 및 Kubernetes를 통해 배포되어 유연성과 확장 성을 향상시킵니다.

PHP 대 기타 언어 : 비교PHP 대 기타 언어 : 비교Apr 13, 2025 am 12:19 AM

PHP는 특히 빠른 개발 및 동적 컨텐츠를 처리하는 데 웹 개발에 적합하지만 데이터 과학 및 엔터프라이즈 수준의 애플리케이션에는 적합하지 않습니다. Python과 비교할 때 PHP는 웹 개발에 더 많은 장점이 있지만 데이터 과학 분야에서는 Python만큼 좋지 않습니다. Java와 비교할 때 PHP는 엔터프라이즈 레벨 애플리케이션에서 더 나빠지지만 웹 개발에서는 더 유연합니다. JavaScript와 비교할 때 PHP는 백엔드 개발에서 더 간결하지만 프론트 엔드 개발에서는 JavaScript만큼 좋지 않습니다.

PHP vs. Python : 핵심 기능 및 기능PHP vs. Python : 핵심 기능 및 기능Apr 13, 2025 am 12:16 AM

PHP와 Python은 각각 고유 한 장점이 있으며 다양한 시나리오에 적합합니다. 1.PHP는 웹 개발에 적합하며 내장 웹 서버 및 풍부한 기능 라이브러리를 제공합니다. 2. Python은 간결한 구문과 강력한 표준 라이브러리가있는 데이터 과학 및 기계 학습에 적합합니다. 선택할 때 프로젝트 요구 사항에 따라 결정해야합니다.

PHP : 웹 개발의 핵심 언어PHP : 웹 개발의 핵심 언어Apr 13, 2025 am 12:08 AM

PHP는 서버 측에서 널리 사용되는 스크립팅 언어이며 특히 웹 개발에 적합합니다. 1.PHP는 HTML을 포함하고 HTTP 요청 및 응답을 처리 할 수 ​​있으며 다양한 데이터베이스를 지원할 수 있습니다. 2.PHP는 강력한 커뮤니티 지원 및 오픈 소스 리소스를 통해 동적 웹 컨텐츠, 프로세스 양식 데이터, 액세스 데이터베이스 등을 생성하는 데 사용됩니다. 3. PHP는 해석 된 언어이며, 실행 프로세스에는 어휘 분석, 문법 분석, 편집 및 실행이 포함됩니다. 4. PHP는 사용자 등록 시스템과 같은 고급 응용 프로그램을 위해 MySQL과 결합 할 수 있습니다. 5. PHP를 디버깅 할 때 error_reporting () 및 var_dump ()와 같은 함수를 사용할 수 있습니다. 6. 캐싱 메커니즘을 사용하여 PHP 코드를 최적화하고 데이터베이스 쿼리를 최적화하며 내장 기능을 사용하십시오. 7

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.