백엔드 개발 PHP 튜토리얼 thinkphp3.2+cropper는 여러 장의 사진 업로드 및 자르기를 구현합니다(코드 예).

thinkphp3.2+cropper는 여러 장의 사진 업로드 및 자르기를 구현합니다(코드 예).

Nov 22, 2018 pm 02:43 PM
thinkphp3.2 이미지 업로드

이 글의 내용은 여러 장의 사진을 업로드하고 잘라낼 수 있는 thinkphp3.2+cropper(코드 예제)를 소개하는 것입니다. 필요한 친구들이 참고하면 도움이 될 것입니다. 너.

먼저 달성된 효과의 스크린샷을 살펴보겠습니다.

두 번째를 계속 업로드하려면 더하기 기호를 클릭하세요. picture#🎜 🎜#

코드 부분:

프런트 엔드 코드:

<--引入cropper相关文件-->
<link rel="stylesheet" href="/home/style/cropper.css" />
    <link href="/home/tupian/css/bootstrap.min.css" rel="stylesheet">
    <link href="/home/tupian/css/cropper.min.css" rel="stylesheet">
    <link href="/home/tupian/css/main.css" rel="stylesheet">

    <script src="/home/tupian/js/jquery.min.js"></script>
    <script src="/home/tupian/js/bootstrap.min.js"></script>
    <script src="/home/tupian/js/cropper.min.js"></script>
    <script src="/home/tupian/js/main.js"></script>
    <script src="http://www.jq22.com/jquery/jquery-2.1.1.js"></script>
    <div class="form-group">
            <label class="col-sm-3 control-label">照片:</label>
            <div class="col-sm-9">
                    <div class="a-up"> <--是第二张图片加号的效果-->
                            <input type="file" onchange="onChangeFn(this); "name="image[]" accept="image/jpeg,image/png"  required />
                     </div>
               <div class="error">*请添加图片</div>
            </div>
     </div>
    <--模态框-->
     <div class="modal fade" id="modal" tabindex="-1" role="dialog" aria-labelledby="modalLabel" aria-hidden="true">
    <div class="modal-dialog" role="document">
        <div class="modal-content">
            <button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button>
            <div class="modal-header">
                <h5 class="modal-title" id="modalLabel">剪裁图片</h5>
            </div>
            <div class="modal-body">
                <div class="img-container">
                    <img id="image" style="max-width:100%;max-height:350px;"><--这里的最大高度一定要设置-->
                </div>
            </div>
            <div class="modal-footer">
                <button type="button" class="btn btn-primary" id="crop">Crop</button>
            </div>
        </div>
    </div>
</div>   

    function onChangeFn (obj) {
        var _this=$(obj),
            _upload=_this.parent();
        currentUpload=_upload;
        // <img src="images/erweima.png" class="upload-img">
        //截取开始
        var files = obj.files;
        var done = function (url) {
            image.src = url;
            $modal.modal('show');
        };
        var reader;
        var file;
        var url;
        if (files && files.length > 0) {
            file = files[0];
            if (URL) {
                done(URL.createObjectURL(file));
            } else if (FileReader) {
                reader = new FileReader();
                reader.onload = function (e) {
                    done(reader.result);
                };
                reader.readAsDataURL(file);
            }
        }
    }
    var image = document.getElementById('image');
    var $modal = $('#modal');
    var currentUpload;
    var cropper;
    $modal.on('shown.bs.modal', function () {
        cropper = new Cropper(image, {
            aspectRatio: 16/9,
            zoomable:true,
            zoomOnWheel:true,
            viewMode: 0,
        });
    }).on('hidden.bs.modal', function () {
        cropper.destroy();
        cropper = null;
    });

    document.getElementById('crop').addEventListener('click', function () {
        var canvas;
        $modal.modal('hide');
        if (cropper) {
            canvas = cropper.getCroppedCanvas({
                width: 800,
                height: 500,
            });
//            avatar.src = canvas.toDataURL();
        <--读取图片-->

            var reader = new FileReader();
            reader.onload = function(evt) {
                currentUpload.before('<div class="divimg"><img src="&#39; + evt.target.result + &#39;" class="upload-img"><input type="hidden" value="&#39; + evt.target.result + &#39;" name="picc[]"><button type="button" class="close" onclick="closeFun(this,1);"></button></div>');
            }
            canvas.toBlob(function (result) {reader.readAsDataURL(result);},"image/jpeg");
//            console.log(canvas);
            if (currentUpload.next().css('display')=='block') {
                currentUpload.next().css('display','none')
            }
            var strHtml='<div class="a-up"><input type="file" onchange="onChangeFn(this);" name="image[]" accept="image/jpeg,image/png" id="pic" /></div>';
            currentUpload.after(strHtml);
            currentUpload.hide();
        }
    });
백엔드 부분: # 🎜🎜#
<--接收过来的是base64的图片,速度较慢,应该是转成blob图片再传给后台,还没做>
            $base64_image_content = $_POST["picc"];
            foreach($base64_image_content as $k=>$v){
                $imageName = date("His",time())."_".rand(1111,9999).'.png';
                $dir = date('Ymd');
                $path = 'uploads/'.$dir;
                if (!is_dir($path)){ //判断目录是否存在 不存在就创建
                    mkdir($path,0777,true);
                }
                if (strstr($v,",")){
                    $base64_image_contents = explode(',',$v);
                    $base64_image = $base64_image_contents[1];
                    $root = $_SERVER['DOCUMENT_ROOT']."/".$path."/". $imageName;
                    $r = file_put_contents($root, base64_decode($base64_image));//返回的是字节数
                }
                $image[] = '/'.$path.'/'. $imageName;
            }

            foreach ($image as $kk=>$vv) {
                $images[] = json_encode($vv, true);
            }
            $data["image"] = '['.implode(',',$images).']';
rrree# 🎜🎜#요약: 위 내용은 이 글의 전체 내용입니다. 모든 분들의 공부에 도움이 되었으면 좋겠습니다. 더 많은 관련 비디오 튜토리얼을 보려면

php tutorial

을 방문하세요!

위 내용은 thinkphp3.2+cropper는 여러 장의 사진 업로드 및 자르기를 구현합니다(코드 예).의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제

PHP 튜토리얼
1543
276
WeChat 애플릿은 사진 업로드 기능을 구현합니다. WeChat 애플릿은 사진 업로드 기능을 구현합니다. Nov 21, 2023 am 09:08 AM

WeChat 애플릿은 사진 업로드 기능을 구현합니다. 모바일 인터넷의 발전으로 WeChat 애플릿은 사람들의 삶에 없어서는 안될 부분이 되었습니다. WeChat 미니 프로그램은 다양한 애플리케이션 시나리오를 제공할 뿐만 아니라 이미지 업로드 기능을 포함한 개발자 정의 기능도 지원합니다. 이 기사에서는 WeChat 애플릿에서 이미지 업로드 기능을 구현하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 1. 준비 작업 코드 작성을 시작하기 전에 WeChat 개발자 도구를 다운로드하여 설치하고 WeChat 개발자로 등록해야 합니다. 동시에 WeChat도 이해해야 합니다.

CakePHP 프레임워크를 사용하여 이미지 업로드 및 표시를 구현하는 단계 CakePHP 프레임워크를 사용하여 이미지 업로드 및 표시를 구현하는 단계 Jul 29, 2023 pm 04:21 PM

CakePHP 프레임워크를 사용하여 이미지 업로드 및 표시를 구현하는 단계 소개: 최신 웹 애플리케이션에서 이미지 업로드 및 표시는 일반적인 기능 요구 사항입니다. CakePHP 프레임워크는 개발자에게 강력한 기능과 편리한 도구를 제공하여 이미지를 쉽고 효율적으로 업로드하고 표시할 수 있도록 해줍니다. 이 글에서는 CakePHP 프레임워크를 사용하여 이미지를 업로드하고 표시하는 방법을 소개합니다. 1단계: 파일 업로드 양식 만들기 먼저 사용자가 이미지를 업로드할 수 있는 보기 파일에 양식을 만들어야 합니다. 다음은 그 예입니다.

Vue 기술 개발에서 이미지 업로드 및 압축을 처리하는 방법 Vue 기술 개발에서 이미지 업로드 및 압축을 처리하는 방법 Oct 08, 2023 am 10:58 AM

Vue 기술 개발에서 이미지 업로드 및 압축을 처리하는 방법 최신 웹 애플리케이션에서 이미지 업로드는 매우 일반적인 요구 사항입니다. 그러나 네트워크 전송 및 저장상의 이유로 고해상도 원본 이미지를 직접 업로드할 경우 업로드 속도가 느려지고 저장 공간이 크게 낭비될 수 있습니다. 따라서 이미지를 업로드하고 압축하는 것은 매우 중요합니다. Vue 기술 개발에서는 기성 솔루션을 사용하여 이미지 업로드 및 압축을 처리할 수 있습니다. 다음은 vue-upload-comone 사용법을 소개합니다.

PHP와 Vue를 사용하여 이미지 업로드 기능을 구현하는 방법 PHP와 Vue를 사용하여 이미지 업로드 기능을 구현하는 방법 Sep 25, 2023 pm 03:17 PM

PHP와 Vue를 사용하여 이미지 업로드 기능을 구현하는 방법 현대 웹 개발에서 이미지 업로드 기능은 매우 일반적인 요구 사항입니다. 이 글에서는 PHP와 Vue를 사용하여 이미지 업로드 기능을 구현하는 방법을 자세히 소개하고 구체적인 코드 예제를 제공합니다. 1. 프론트엔드 부분(Vue) 먼저 프론트엔드에 이미지를 업로드하기 위한 폼을 생성해야 합니다. 구체적인 코드는 다음과 같습니다:&lt;template&gt;&lt;div&gt;&lt;inputtype="fil

ThinkPHP6을 사용하여 이미지를 업로드하는 방법 ThinkPHP6을 사용하여 이미지를 업로드하는 방법 Jun 20, 2023 pm 09:25 PM

인터넷이 발달하면서 이미지 업로드는 웹사이트와 애플리케이션 개발에 필수적인 기능이 되었습니다. PHP 분야에서 ThinkPHP6은 매우 인기 있는 개발 프레임워크가 되었습니다. 이번 글에서는 ThinkPHP6를 사용하여 이미지 업로드를 구현하는 방법을 소개하겠습니다. 1. 프로젝트 및 컨트롤러 생성 먼저 새로운 ThinkPHP6 프로젝트를 생성해야 합니다. Composer를 사용하여 설치하거나 공식 웹사이트에서 최신 버전을 다운로드할 수 있습니다. 설치가 완료되면 콘솔에 입력하세요.

PHP를 사용하여 간단한 온라인 이미지 업로드 및 표시 시스템을 구현하는 방법 PHP를 사용하여 간단한 온라인 이미지 업로드 및 표시 시스템을 구현하는 방법 Sep 25, 2023 am 09:21 AM

PHP를 사용하여 간단한 온라인 이미지 업로드 및 표시 시스템을 구현하는 방법 이미지 업로드 및 표시 시스템은 현대 웹사이트에서 일반적으로 사용되는 기능 중 하나입니다. 이 기능은 개발 과정에서 PHP를 사용하여 빠르게 구현할 수 있습니다. 이 기사에서는 PHP를 사용하여 간단한 온라인 이미지 업로드 및 표시 시스템을 작성하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 1. 데이터베이스 및 테이블 생성 먼저 업로드된 이미지 정보를 저장할 데이터베이스와 테이블을 생성해야 합니다. 다음 SQL 문을 사용하여 "images"라는 테이블을 만들고 설정합니다.

Vue 개발 시 이미지 업로드 미리보기 모달 상자 표시 문제를 해결하는 방법 Vue 개발 시 이미지 업로드 미리보기 모달 상자 표시 문제를 해결하는 방법 Jul 01, 2023 pm 01:13 PM

Vue 개발 시 이미지 업로드 미리보기 모달 상자 표시 문제를 해결하는 방법 Vue 개발에서는 이미지를 업로드하고 미리보아야 하는 경우가 종종 있습니다. 이 경우, 이미지를 업로드한 후 모달 상자에 미리보기 이미지를 표시하는 방법에 대한 일반적인 질문이 있습니다. 이 기사에서는 이 문제를 해결하는 방법을 소개합니다. 먼저 업로드할 이미지 파일을 선택하려면 Vue 구성 요소에 파일 업로드 입력 요소를 추가해야 합니다. 파일 업로드의 변경 이벤트를 수신하여 사용자가 선택한 이미지를 얻을 수 있습니다.

Vue 기술 개발에서 이미지 업로드 및 자르기를 구현하는 방법 Vue 기술 개발에서 이미지 업로드 및 자르기를 구현하는 방법 Oct 10, 2023 pm 12:46 PM

Vue 기술 개발에서 이미지 업로드 및 자르기를 구현하는 방법에는 특정 코드 예제가 필요합니다. 최신 웹 개발에서는 이미지 업로드 및 이미지 자르기가 일반적인 요구 사항 중 하나입니다. 널리 사용되는 프런트엔드 프레임워크인 Vue.js는 이러한 기능을 달성하는 데 도움이 되는 풍부한 도구와 플러그인을 제공합니다. 이 글에서는 Vue 기술 개발에서 이미지 업로드 및 자르기를 구현하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 이미지 업로드 구현은 이미지 선택과 이미지 업로드의 두 단계로 나눌 수 있습니다. Vue에서는 타사 플러그인을 사용하여 이를 단순화할 수 있습니다.

See all articles