>  기사  >  웹 프론트엔드  >  spring mvc+localResizeIMG는 H5 이미지 압축 및 업로드를 구현합니다.

spring mvc+localResizeIMG는 H5 이미지 압축 및 업로드를 구현합니다.

php中世界最好的语言
php中世界最好的语言원래의
2018-03-26 13:17:182602검색

이번에는 H5 측 이미지 압축 및 업로드를 구현하는 spring mvc+localResizeIMG를 소개하겠습니다. Spring mvc+localResizeIMG는 H5 측 이미지 압축 및 업로드를 구현합니다. 다음은 실제 사례입니다. 바라보다.

최근에 모바일 HTML5 애플리케이션을 작업하면서 업로드 기능을 사용했습니다. 처음에는 휴대폰으로 찍은 사진을 업로드하는 데 전통적인 업로드 방법을 사용했습니다. 휴대폰으로 찍은 사진은 대개 몇 MB 이므로 업로드 속도는 매우 느립니다.

오랜 시간 동안 온라인으로 검색한 끝에 localResizeIMG 압축 프레임워크를 찾았는데 매우 실용적이라고 생각하여 여기에 공유합니다.

1단계: localResizeIMG 다운로드

localResizeIMG는 github에 있으며 주소는

https://github.com/think2011/localResizeIMG입니다.

2단계: 웹 프로젝트에서 localResizeIMG 관련 js 가져오기

localResizeIMG 압축을 풀고 디렉터리의 dist 폴더를 프로젝트에 복사합니다. 내 파일은 js 디렉터리에 있습니다.

그런 다음 jQuery 및 localResizeIMG의 js를 자신의 js로 가져옵니다. 예:

<span style="white-space:pre">    </span><script src="<c:url value="/js/JQuery/jquery-1.10.0.min.js"/>"></script>  
<span style="white-space:pre">    </span><script type="text/javascript" src="<c:url value="/js/lrz/dist/lrz.bundle.js"/>"></script>

3단계: 업로드된 입력의 파일 상자에 있는 onchange 이벤트에 다음 코드를 추가합니다.

 <input  type="file"  id="payfile" name="myfile" style="display:none;" onchange="fileChange(this)" />
fileChange 메서드에서 코드 압축을 구현하고 이후에 생성된 base64를 비동기적으로 전송합니다. 백그라운드로 압축

function fileChange(that){  
        var filepath=$(that).val();  
        if(filepath=="")  
        {  
            return;  
        }  
        var extStart=filepath.lastIndexOf(".");  
        var ext=filepath.substring(extStart,filepath.length).toUpperCase();  
        if(".jpg|.png|.bmp|.jpeg".toUpperCase().indexOf(ext.toUpperCase())==-1){  
           alert("只允许上传jpg、png、bmp、jpeg格式的图片");  
            return false;  
        }  
     //以图片宽度为800进行压缩  
    lrz(that.files[0], {  
         width: 800  
       })  
    .then(function (rst) {  
            //压缩后异步上传  
            $.ajax({  
            url : "<%=request.getContextPath()%>/common/fileUploadPicture",  
            type: "POST",  
            data : {  
                imgdata:rst.base64//压缩后的base值  
            },  
            dataType:"json",  
            cache:false,  
            async:false,  
            success : function(data) {  
            if(data.success)  
                {  
                    alert(data.message);///data.message为上传成功后的文件路径  
                }else{  
                    alert(data.message);///data.message为上传失败原因  
                }  
                              
                        },  
        error : function(){  
                alert("上传失败");  
                        }  
                    });  
         });  
}

4단계: 스프링 mvc 컨트롤러는 백그라운드에서 기본 값을 받아 파일을 구문 분석하고 저장합니다.

import sun.misc.BASE64Decoder;//导入的base64的类  
/** 
     * 文件上传 
     */  
    @ResponseBody  
    @RequestMapping("common/fileUploadPicture")  
    public Object fileUploadPicture(String imgdata, HttpServletRequest request) {  
        LOGGER.info("[文件上传(fileUploadPicture)][params:imgdata=" + imgdata + "]");  
         BASE64Decoder decoder = new BASE64Decoder();  
        try {  
            String basePath = request.getRealPath("/upload_files");  
            string imgPath=basePath+"/test.jpg";  
            // new一个文件对象用来保存图片,默认保存当前工程根目录  
            File imageFile = new File(imgPath);  
            // 创建输出流  
            FileOutputStream outputStream = new FileOutputStream(imageFile);  
            // 获得一个图片文件流,我这里是从flex中传过来的  
            byte[] result = decoder.decodeBuffer(imgdata.split(",")[1]);//解码  
            for (int i = 0; i < result.length; ++i) {  
                if (result[i] < 0) {// 调整异常数据  
                result[i] += 256;  
            }  
        }  
            outputStream.write(result);  
  
            return new Result(true, imgPath);  
        } catch (AppException e1) {  
            LOGGER.error("[文件上传(fileUpload)-fastdfs][errors:" + e1 + "]");  
            return new Result(false, "文件上传失败");  
        } catch (Exception e) {  
            LOGGER.error("[文件上传(fileUpload)][errors:" + e + "]");  
            return new Result(false, "文件上传失败");  
        }finally{  
        outputStream.flush();   
        outputStream.close();  
          
        }  
    }
결과 클래스:

import java.io.Serializable;  
  
public class Result implements Serializable{  
    private static final long serialVersionUID = 1L;  
    private boolean success;  
    private String message;  
  
    public Result() {  
        success = true;  
    }  
  
    public Result(boolean success, String message) {  
        this.success = success;  
        this.message = message;  
    }  
  
    public boolean isSuccess() {  
        return success;  
    }  
  
    public void setSuccess(boolean success) {  
        this.success = success;  
    }  
  
    public String getMessage() {  
        return message;  
    }  
  
    public void setMessage(String message) {  
        this.message = message;  
    }  
  
    @Override  
    public String toString() {  
        return "Result [success=" + success + ", message=" + message + "]";  
    }  
  
}
을 읽으신 후 메서드를 마스터하신 것 같습니다. 이 기사의 경우 더 흥미로운 정보를 보려면 PHP 중국어 웹사이트의 기타 관련 기사를 주목하세요!

추천 도서:

페이징 쿼리 사용에 대한 자세한 설명

Node.js로 WeChat 월을 개발하는 방법

위 내용은 spring mvc+localResizeIMG는 H5 이미지 압축 및 업로드를 구현합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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