파일업로드시 이미지 파일 특정 크기로 미리 줄여서 업로드 하기 > 개발자팁

개발자팁

개발과 관련된 유용한 정보를 공유하세요.
질문은 QA에서 해주시기 바랍니다.

파일업로드시 이미지 파일 특정 크기로 미리 줄여서 업로드 하기 정보

PHP 파일업로드시 이미지 파일 특정 크기로 미리 줄여서 업로드 하기

본문

테스트 코드 입니다.

 

html 스크립트 코드는 아래와 같이 진행하고

서버단에서 썸네일 과정이 없기 때문에 쾌적하게 이용 가능합니다.

여러 사이즈로 resize가 필요한 경우에는 코드는 수정 해주셔야 합니다.

 

upload.php 파일로 저장해 주는 로직 입니다.

 

따로 라이브러리 사용하지 않고 진행 가능합니다.

 

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Image Resize and Upload</title>
</head>
<body>
    <input type="file" id="fileInput" onchange="handleFileSelect(event)"/>
    <button id="uploadButton" onclick="uploadImage()">Upload</button>
    <img src="" id="pre_view" />
    <script>

        let resizedImage;

        function handleFileSelect(event) {
            const file = event.target.files[0];
            if (file && file.type.startsWith('image/')) { // Only process image files
                const reader = new FileReader();
                reader.onload = function(e) {
                    const img = new Image();
                    img.onload = function() {
                        const canvas = document.createElement('canvas');
                        const ctx = canvas.getContext('2d');
                        const MAX_WIDTH = 1000; // 원하는 최대 너비
                        const MAX_HEIGHT = 1000; // 원하는 최대 높이
                        let width = img.width;
                        let height = img.height;

                        // 비율에 맞게 크기 조정
                        if (width > height) {
                            if (width > MAX_WIDTH) {
                                height *= MAX_WIDTH / width;
                                width = MAX_WIDTH;
                            }
                        } else {
                            if (height > MAX_HEIGHT) {
                                width *= MAX_HEIGHT / height;
                                height = MAX_HEIGHT;
                            }
                        }

                        canvas.width = width;
                        canvas.height = height;
                        ctx.drawImage(img, 0, 0, width, height);
                        resizedImage = canvas.toDataURL(file.type, 0.9); // 품질 90%
                    };
                    img.src = e.target.result;
                    document.getElementById('pre_view').src=e.target.result;
                };
                reader.readAsDataURL(file);
            } else {
                console.error('Selected file is not an image.');
            }
        }

        function uploadImage() {
            if (resizedImage) {
                const formData = new FormData();
                formData.append('image', resizedImage);

                fetch('/upload.php', {
                    method: 'POST',
                    body: formData
                })
                .then(response => response.json())
                .then(data => console.log('Success:', data))
                .catch(error => console.error('Error:', error));
            } else {
                console.log('No image selected or image not resized yet.');
            }
        }
    </script>
</body>
</html>

 

upload.php

<?php
if ($_SERVER['REQUEST_METHOD'] === 'POST') {
    $uploadDir = 'uploads/;
    $response = ['status' => 'success'];

    if (isset($_POST['image'])) {
        $data = $_POST['image'];

        if (preg_match('/^data:image\/(\w+);base64,/', $data, $typeMatch)) {
            $data = substr($data, strpos($data, ',') + 1);
            $type = strtolower($typeMatch[1]); // jpg, png, gif 등

            if (!in_array($type, ['jpg', 'jpeg', 'gif', 'png'])) {
                $response['status'] = 'error';
                $response['message'] = 'Invalid image type';
                echo json_encode($response);
                exit;
            }

            $data = base64_decode($data);

            if ($data === false) {
                $response['status'] = 'error';
                $response['message'] = 'Base64 decode failed';
                echo json_encode($response);
                exit;
            }

            $filePath = $uploadDir . uniqid() . '.' . $type;
            if (file_put_contents($filePath, $data)) {
                $response['file'] = $filePath;
            } else {
                $response['status'] = 'error';
                $response['message'] = 'Failed to save file';
            }
        } else {
            $response['status'] = 'error';
            $response['message'] = 'Invalid data URI';
        }
    } else {
        $response['status'] = 'error';
        $response['message'] = 'No image data';
    }


    echo json_encode($response);
}else {
    // Handle invalid request methods
    $response = ['status' => 'error', 'message' => 'Invalid request method'];
    echo json_encode($response);
}
?>

 

추천
0

댓글 0개

전체 5,363
개발자팁 내용 검색

회원로그인

(주)에스아이알소프트 / 대표:홍석명 / (06211) 서울특별시 강남구 역삼동 707-34 한신인터밸리24 서관 1404호 / E-Mail: admin@sir.kr
사업자등록번호: 217-81-36347 / 통신판매업신고번호:2014-서울강남-02098호 / 개인정보보호책임자:김민섭(minsup@sir.kr)
© SIRSOFT