6. 자바스크립트와 AJAX

AJAX 처리(assets/js/script.js)

$(document).ready(function(){    // load gallery on page load    loadGallery();    // Form submission for image upload    $(\\'#uploadImage\\').on(\\'submit\\', function(e){        e.preventDefault(); // Prevent default form submission        var file_data = $(\\'#image\\').prop(\\'files\\')[0];        var form_data = new FormData();        form_data.append(\\'file\\', file_data);        //hide upload section        $(\\'#uploadImage\\').hide();        $.ajax({            url: \\'src/upload.php\\', // PHP script to process upload            type: \\'POST\\',            dataType: \\'text\\', // what to expect back from the server            cache: false,            data: new FormData(this), // Form data for upload            processData: false,            contentType: false,            success: function(response){                let jsonData = JSON.parse(response);                if(jsonData.status == 1){                    $(\\'#image\\').val(\\'\\'); // Clear the file input                    loadGallery(); // Fetch and display updated images                    $(\\'#upload-status\\').html(\\'
\\' jsonData.message \\'
\\'); } else { $(\\'#upload-status\\').html(\\'
\\' jsonData.message \\'
\\'); // Display error message } // hide message box autoHide(\\'#upload-status\\'); //show upload section autoShow(\\'#uploadImage\\'); } }); });});// Function to load the gallery from serverfunction loadGallery() { $.ajax({ url: \\'src/fetch-images.php\\', // PHP script to fetch images type: \\'GET\\', success: function(response){ let jsonData = JSON.parse(response); $(\\'#gallery\\').html(\\'\\'); // Clear previous images if(jsonData.status == 1){ $.each(jsonData.data, function(index, image){ $(\\'#gallery\\').append(\\'
\\\"PHP
\\'); // Display each image }); } else { $(\\'#gallery\\').html(\\'

No images found...

\\'); // No images found message } } });}//Auto Hide Divfunction autoHide(idORClass) { setTimeout(function () { $(idORClass).fadeOut(\\'fast\\'); }, 1000);}//Auto Show Elementfunction autoShow(idORClass) { setTimeout(function () { $(idORClass).fadeIn(\\'fast\\'); }, 1000);}

7. 백엔드 PHP 스크립트

이미지 가져오기(src/fetch-images.php)

 0, \\'message\\' => \\'No images found.\\');// Fetching images from the database$query = $pdo->prepare(\\\"SELECT * FROM images ORDER BY uploaded_on DESC\\\");$query->execute();$images = $query->fetchAll(PDO::FETCH_ASSOC);if(count($images) > 0){    $response[\\'status\\'] = 1;    $response[\\'data\\'] = $images; // Returning images data}// Return responseecho json_encode($response);?>?>

이미지 업로드(src/upload.php)

 0, \\'message\\' => \\'Form submission failed, please try again.\\');if(isset($_FILES[\\'image\\'][\\'name\\'])){    // Directory where files will be uploaded    $targetDir = UPLOAD_DIRECTORY;    $fileName = date(\\'Ymd\\').\\'-\\'.str_replace(\\' \\', \\'-\\', basename($_FILES[\\'image\\'][\\'name\\']));    $targetFilePath = $targetDir . $fileName;    $fileType = pathinfo($targetFilePath, PATHINFO_EXTENSION);    // Allowed file types    $allowTypes = array(\\'jpg\\',\\'png\\',\\'jpeg\\',\\'gif\\');    if(in_array($fileType, $allowTypes)){        // Upload file to server        if(move_uploaded_file($_FILES[\\'image\\'][\\'tmp_name\\'], $targetFilePath)){            // Insert file name into database            $insert = $pdo->prepare(\\\"INSERT INTO images (file_name, uploaded_on) VALUES (:file_name, NOW())\\\");            $insert->bindParam(\\':file_name\\', $fileName);            $insert->execute();            if($insert){                $response[\\'status\\'] = 1;                $response[\\'message\\'] = \\'Image uploaded successfully!\\';            }else{                $response[\\'message\\'] = \\'Image upload failed, please try again.\\';            }        }else{            $response[\\'message\\'] = \\'Sorry, there was an error uploading your file.\\';        }    }else{        $response[\\'message\\'] = \\'Sorry, only JPG, JPEG, PNG, & GIF files are allowed to upload.\\';    }}// Return responseecho json_encode($response);?>

6. CSS 스타일링

CSS 스타일링(assets/css/style.css)

body {    background-color: #f8f9fa;}#gallery .col-md-4 {    margin-bottom: 20px;}#gallery img {    display: block;    width: 200px;    height: auto;    margin: 10px;}

문서 및 설명

이 솔루션에는 프로젝트 설정, 데이터베이스 구성, HTML 구조, CSS를 사용한 스타일 지정, AJAX를 사용한 이미지 업로드 처리, PHP PDO를 사용하여 데이터베이스에 이미지 데이터 저장이 포함됩니다. 각 코드 줄에는 목적과 기능을 설명하는 주석이 달려 있어 업로드 기능이 있는 이미지 갤러리를 구축하기 위한 포괄적인 튜토리얼이 됩니다.

링크 연결

이 시리즈가 도움이 되었다면 GitHub에서 저장소에 별표를 표시하거나 즐겨찾는 소셜 네트워크에서 게시물을 공유해 보세요. 여러분의 지원은 저에게 큰 의미가 될 것입니다!

이와 같이 더 유용한 콘텐츠를 원하시면 언제든지 저를 팔로우하세요.

소스 코드

","image":"http://www.luping.net/uploads/20240901/172516968466d400142d2f9.jpg","datePublished":"2024-09-01T13:48:04+08:00","dateModified":"2024-09-01T13:48:04+08:00","author":{"@type":"Person","name":"luping.net","url":"https://www.luping.net/articlelist/0_1.html"}}
"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > PHP 집중 강좌: 단순 이미지 갤러리

PHP 집중 강좌: 단순 이미지 갤러리

2024-09-01에 게시됨
검색:242

PHP crash course: Simple Image Gallery

PHP, HTML, jQuery, AJAX, JSON, Bootstrap, CSS 및 MySQL을 사용하여 업로드 기능을 갖춘 완전한 기능의 이미지 갤러리입니다. 이 프로젝트에는 코드 설명과 문서가 포함된 상세한 단계별 솔루션이 포함되어 있어 학습을 위한 포괄적인 튜토리얼이 됩니다.

주제: php, mysql, 블로그, ajax, 부트스트랩, jquery, CSS, 이미지 갤러리, 파일 업로드

단계별 솔루션

1. 디렉터리 구조

simple-image-gallery/
│
├── index.html
├── db/
│   └── database.sql
├── src/
│   ├── fetch-image.php
│   └── upload.php
├── include/
│   ├── config.sample.php
│   └── db.php
├── assets/
│   ├── css/
│   │   └── style.css
│   ├── js/
│   │   └── script.js
│   └── uploads/
│   │   └── (uploaded images will be stored here)
├── README.md
└── .gitignore

2. 데이터베이스 스키마

db/database.sql:

CREATE TABLE IF NOT EXISTS `images` (
    `id` int(11) NOT NULL AUTO_INCREMENT,
    `file_name` varchar(255) NOT NULL,
    `uploaded_on` datetime NOT NULL,
    PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

3. 구성 파일

구성 설정(include/config.sample.php)

4. 데이터베이스 연결 구성

데이터베이스 연결 설정 중(include/db.php)

 PDO::ERRMODE_EXCEPTION,
    PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC,
];

// Create a new PDO instance
try {
    $pdo = new PDO($dsn, DB_USER, DB_PASS, $options);
    $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); // Set error mode to exception
} catch (PDOException $e) {
    echo 'Connection failed: ' . $e->getMessage(); // Display error message if connection fails
}
?>

5. HTML과 PHP 구조

HTML 구조(index.html)



    Image Gallery Upload

Image Gallery


6. 자바스크립트와 AJAX

AJAX 처리(assets/js/script.js)

$(document).ready(function(){
    // load gallery on page load
    loadGallery();

    // Form submission for image upload
    $('#uploadImage').on('submit', function(e){
        e.preventDefault(); // Prevent default form submission
        var file_data = $('#image').prop('files')[0];
        var form_data = new FormData();
        form_data.append('file', file_data);
        //hide upload section
        $('#uploadImage').hide();
        $.ajax({
            url: 'src/upload.php', // PHP script to process upload
            type: 'POST',
            dataType: 'text', // what to expect back from the server
            cache: false,
            data: new FormData(this), // Form data for upload
            processData: false,
            contentType: false,
            success: function(response){
                let jsonData = JSON.parse(response);
                if(jsonData.status == 1){
                    $('#image').val(''); // Clear the file input
                    loadGallery(); // Fetch and display updated images
                    $('#upload-status').html('
' jsonData.message '
'); } else { $('#upload-status').html('
' jsonData.message '
'); // Display error message } // hide message box autoHide('#upload-status'); //show upload section autoShow('#uploadImage'); } }); }); }); // Function to load the gallery from server function loadGallery() { $.ajax({ url: 'src/fetch-images.php', // PHP script to fetch images type: 'GET', success: function(response){ let jsonData = JSON.parse(response); $('#gallery').html(''); // Clear previous images if(jsonData.status == 1){ $.each(jsonData.data, function(index, image){ $('#gallery').append('
PHP 집중 강좌: 단순 이미지 갤러리
'); // Display each image }); } else { $('#gallery').html('

No images found...

'); // No images found message } } }); } //Auto Hide Div function autoHide(idORClass) { setTimeout(function () { $(idORClass).fadeOut('fast'); }, 1000); } //Auto Show Element function autoShow(idORClass) { setTimeout(function () { $(idORClass).fadeIn('fast'); }, 1000); }

7. 백엔드 PHP 스크립트

이미지 가져오기(src/fetch-images.php)

 0, 'message' => 'No images found.');

// Fetching images from the database
$query = $pdo->prepare("SELECT * FROM images ORDER BY uploaded_on DESC");
$query->execute();
$images = $query->fetchAll(PDO::FETCH_ASSOC);

if(count($images) > 0){
    $response['status'] = 1;
    $response['data'] = $images; // Returning images data
}

// Return response
echo json_encode($response);
?>
?>

이미지 업로드(src/upload.php)

 0, 'message' => 'Form submission failed, please try again.');

if(isset($_FILES['image']['name'])){
    // Directory where files will be uploaded
    $targetDir = UPLOAD_DIRECTORY;
    $fileName = date('Ymd').'-'.str_replace(' ', '-', basename($_FILES['image']['name']));
    $targetFilePath = $targetDir . $fileName;
    $fileType = pathinfo($targetFilePath, PATHINFO_EXTENSION);

    // Allowed file types
    $allowTypes = array('jpg','png','jpeg','gif');
    if(in_array($fileType, $allowTypes)){
        // Upload file to server
        if(move_uploaded_file($_FILES['image']['tmp_name'], $targetFilePath)){
            // Insert file name into database
            $insert = $pdo->prepare("INSERT INTO images (file_name, uploaded_on) VALUES (:file_name, NOW())");
            $insert->bindParam(':file_name', $fileName);
            $insert->execute();
            if($insert){
                $response['status'] = 1;
                $response['message'] = 'Image uploaded successfully!';
            }else{
                $response['message'] = 'Image upload failed, please try again.';
            }
        }else{
            $response['message'] = 'Sorry, there was an error uploading your file.';
        }
    }else{
        $response['message'] = 'Sorry, only JPG, JPEG, PNG, & GIF files are allowed to upload.';
    }
}

// Return response
echo json_encode($response);
?>

6. CSS 스타일링

CSS 스타일링(assets/css/style.css)

body {
    background-color: #f8f9fa;
}

#gallery .col-md-4 {
    margin-bottom: 20px;
}

#gallery img {
    display: block;
    width: 200px;
    height: auto;
    margin: 10px;
}

문서 및 설명

  • config.php: 데이터베이스 구성이 포함되어 있으며 PDO를 사용하여 MySQL에 연결합니다.
  • index.php: HTML 구조의 메인 페이지에는 스타일 지정을 위한 부트스트랩과 게시물 추가/편집을 위한 모달이 포함되어 있습니다.
  • assets/js/script.js: 게시물 로드 및 저장에 대한 AJAX 요청을 처리합니다. DOM 조작 및 AJAX에 jQuery를 사용합니다.
  • src/fetch-images.php: 데이터베이스에서 게시물을 가져와 JSON으로 반환합니다.
  • src/upload.php: ID 존재 여부에 따라 게시물 생성 및 업데이트를 처리합니다.

이 솔루션에는 프로젝트 설정, 데이터베이스 구성, HTML 구조, CSS를 사용한 스타일 지정, AJAX를 사용한 이미지 업로드 처리, PHP PDO를 사용하여 데이터베이스에 이미지 데이터 저장이 포함됩니다. 각 코드 줄에는 목적과 기능을 설명하는 주석이 달려 있어 업로드 기능이 있는 이미지 갤러리를 구축하기 위한 포괄적인 튜토리얼이 됩니다.

링크 연결

이 시리즈가 도움이 되었다면 GitHub에서 저장소에 별표를 표시하거나 즐겨찾는 소셜 네트워크에서 게시물을 공유해 보세요. 여러분의 지원은 저에게 큰 의미가 될 것입니다!

이와 같이 더 유용한 콘텐츠를 원하시면 언제든지 저를 팔로우하세요.

  • 링크드인
  • GitHub

소스 코드

릴리스 선언문 이 글은 https://dev.to/mdarifulhaque/php-crash-course-simple-image-gallery-h4l?1에서 복제됩니다.1 침해 내용이 있는 경우, [email protected]으로 연락하여 삭제하시기 바랍니다.
최신 튜토리얼 더>
  • 간단한 예제를 통해 JavaScript의 호출, 적용 및 바인딩 이해
    간단한 예제를 통해 JavaScript의 호출, 적용 및 바인딩 이해
    간단한 예제를 통해 JavaScript의 호출, 적용 및 바인딩 이해 JavaScript로 작업할 때 호출, 적용, 바인딩이라는 세 가지 강력한 방법을 접할 수 있습니다. 이러한 메서드는 함수에서 this의 값을 제어하는 ​​데 사용되어 개체 작업을 더...
    프로그램 작성 2024-11-08에 게시됨
  • 중괄호 배치가 JavaScript 실행에 어떤 영향을 미치나요?
    중괄호 배치가 JavaScript 실행에 어떤 영향을 미치나요?
    중괄호 배치 및 JavaScript 실행JavaScript에서 중괄호 배치는 코드의 동작과 출력을 크게 변경할 수 있습니다. 제공된 코드 조각에서 볼 수 있듯이 중괄호 배치를 한 번만 변경해도 결과가 크게 달라질 수 있습니다.자동 세미콜론 삽입 및 정의되지 않은 반환여...
    프로그램 작성 2024-11-08에 게시됨
  • Elasticsearch 알아보기
    Elasticsearch 알아보기
    Elasticsearch는 Apache Lucene 라이브러리를 기반으로 구축된 강력한 오픈 소스 검색 및 분석 엔진입니다. 대용량 데이터를 처리하고 복잡한 검색을 효율적으로 수행하도록 설계되었습니다. Elasticsearch의 주요 기능은 다음과 같습니다: 분산 아키...
    프로그램 작성 2024-11-08에 게시됨
  • 배당률: Python 기반 금융 프로젝트의 중요한 지표
    배당률: Python 기반 금융 프로젝트의 중요한 지표
    배당률: Python 기반 금융 프로젝트의 중요한 지표 재무 분석 영역에서 배당금은 많은 투자자들에게 매우 중요합니다. 특히 재무 데이터를 처리하거나 투자 전략을 자동화하는 Python 프로젝트를 개발하는 경우 배당률을 계산하고 분석하는 것이 핵심 요소...
    프로그램 작성 2024-11-08에 게시됨
  • 병렬 또는 분산 테스트를 통해 여러 브라우저에서 WebUI 기능 파일을 실행하는 방법은 무엇입니까?
    병렬 또는 분산 테스트를 통해 여러 브라우저에서 WebUI 기능 파일을 실행하는 방법은 무엇입니까?
    병렬 또는 분산 테스트를 사용하여 여러 브라우저에서 WebUI 기능 파일 실행병렬 테스트를 사용하여 여러 브라우저(Zalenium)에 대해 WebUI 기능 파일을 실행하려면 실행기 또는 분산 테스트의 경우 다음 접근 방식을 활용합니다.병렬 실행기 및 시나리오 개요:시나...
    프로그램 작성 2024-11-08에 게시됨
  • SOAP와 REST API: 주요 차이점 이해
    SOAP와 REST API: 주요 차이점 이해
    웹 서비스 세계에서 SOAP(Simple Object Access Protocol)와 REST(Representational State Transfer)는 널리 사용되는 두 가지(Soap 대 Rest API) 아키텍처입니다. 둘 다 시스템 간의 통신 프로토콜 역할을 ...
    프로그램 작성 2024-11-08에 게시됨
  • CSS로 텍스트 밑줄 색상을 사용자 정의하는 방법은 무엇입니까?
    CSS로 텍스트 밑줄 색상을 사용자 정의하는 방법은 무엇입니까?
    CSS를 사용하여 텍스트 밑줄 색상 사용자 정의웹 디자인에서 텍스트에 밑줄을 추가하는 것은 정보를 강조하거나 강조하는 일반적인 방법입니다. 하지만 밑줄 색상을 변경하여 독특한 느낌을 더하고 싶다면 어떻게 해야 할까요? 가능합니까?예, CSS를 사용하여 텍스트 아래 줄의...
    프로그램 작성 2024-11-08에 게시됨
  • JavaScript로 클릭재킹 방어 기술 구현
    JavaScript로 클릭재킹 방어 기술 구현
    클릭재킹과 같은 정교한 공격의 출현으로 인해 보안이 오늘날 온라인 세계의 주요 문제가 되었습니다. 공격자는 소비자가 처음에 본 것과 다른 것을 클릭하도록 속임으로써 비참한 결과를 초래할 수 있는 "클릭재킹"이라는 사악한 방법을 배포합니다. 이러한 종류...
    프로그램 작성 2024-11-08에 게시됨
  • 플로팅된 Div가 후속 Div의 크기를 조정하지 않는 이유는 무엇입니까?
    플로팅된 Div가 후속 Div의 크기를 조정하지 않는 이유는 무엇입니까?
    Float 크기가 조정되지 않는 Div의 미스터리CSS float를 사용할 때 후속 요소가 새 요소로 흘러가는 대신 왼쪽에 정렬된다고 가정합니다. 선. 그러나 제공된 예시와 같은 일부 시나리오에서는 다음 div가 첫 번째 div의 오른쪽에서 시작하는 대신 계속해서 전체...
    프로그램 작성 2024-11-08에 게시됨
  • PYTHON을 사용하여 MySQL로 데이터 가져오기
    PYTHON을 사용하여 MySQL로 데이터 가져오기
    소개 특히 테이블 수가 많은 경우 데이터베이스로 데이터를 수동으로 가져오는 것은 번거로울 뿐만 아니라 시간도 많이 소요됩니다. Python 라이브러리를 사용하면 더 쉽게 만들 수 있습니다. kaggle에서 그림 데이터세트를 다운로드하세요. 그림 데이터 ...
    프로그램 작성 2024-11-08에 게시됨
  • 필수 MySQL 연산자 및 해당 애플리케이션
    필수 MySQL 연산자 및 해당 애플리케이션
    MySQL 연산자는 정확한 데이터 조작 및 분석을 가능하게 하는 개발자를 위한 핵심 도구입니다. 값 할당, 데이터 비교 및 ​​복잡한 패턴 일치를 포함한 다양한 기능을 다룹니다. JSON 데이터를 처리하든 조건에 따라 레코드를 필터링하든 효율적인 데이터베이스 관리를 위...
    프로그램 작성 2024-11-08에 게시됨
  • 크론 작업 테스트 방법: 전체 가이드
    크론 작업 테스트 방법: 전체 가이드
    Cron 작업은 작업 예약, 프로세스 자동화, 지정된 간격으로 스크립트 실행을 위한 많은 시스템에서 필수적입니다. 웹 서버를 유지 관리하든, 백업을 자동화하든, 일상적인 데이터 가져오기를 실행하든 크론 작업은 작업을 원활하게 실행합니다. 그러나 다른 자동화된 작업과 ...
    프로그램 작성 2024-11-08에 게시됨
  • Next.js 미들웨어 소개: 예제와 함께 작동하는 방법
    Next.js 미들웨어 소개: 예제와 함께 작동하는 방법
    Nextjs의 라우팅에 대해 이야기해 보겠습니다. 오늘은 가장 강력한 미들웨어 중 하나에 대해 이야기해보겠습니다. Nextjs의 미들웨어는 서버의 요청을 가로채고 요청 흐름(리디렉션, URL 재작성)을 제어하고 인증, 헤더, 쿠키 지속성과 같은 기능을 전체적으로 향상시...
    프로그램 작성 2024-11-08에 게시됨
  • 소품 기본 사항: 1부
    소품 기본 사항: 1부
    초보자 친화적인 소품 사용법 튜토리얼입니다. 읽기 전에 구조 분해가 무엇인지, 구성 요소를 사용/생성하는 방법을 이해하는 것이 중요합니다. 속성(property)의 약자인 props를 사용하면 상위 구성 요소에서 하위 구성 요소로 정보를 보낼 수 있으며, 모든 데이터...
    프로그램 작성 2024-11-08에 게시됨
  • Hibernate는 Spring Boot와 어떻게 다른가요?
    Hibernate는 Spring Boot와 어떻게 다른가요?
    Hibernate는 Spring Boot와 어떻게 다른가요? Hibernate와 Spring Boot는 둘 다 Java 생태계에서 널리 사용되는 프레임워크이지만 서로 다른 용도로 사용되며 고유한 기능을 가지고 있습니다. 최대 절전 모드 H...
    프로그램 작성 2024-11-08에 게시됨

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3