WebUploader实现图片上传功能

本文实例为大家分享了WebUploader实现图片上传的具体代码,供大家参考,具体内容如下

描述:springmvc 在jsp页面实现 WebUploader插件上传图片, 上传到 oss阿里云存储上。

预览:

理解: 前端 WebUploader插件(这个得去看官网)调起后台,后台 request 接收文件参数,
重新拼装图片url,oss创建连接上传图片提交图片,最后返回图片绝对url和相对url给前端。

先实现前端:1.定义js 2.定义页面

//导入 WebUploader插件js、css 样式
<link rel="stylesheet" type="text/css" href="${ctx}/css/plugins/webuploader/webuploader.css" />
<script type="text/javascript" src="${ctx}/js/plugins/webuploader/webuploader.js"></script>

js定义

//使用WebUploader插件做图片上传
function InfoWebUploaderImg(id, folder, image, imageHidden, queueID, filename){

  // 初始化Web Uploader
  var uploader = WebUploader.create({
    // 选完文件后,是否自动上传。
    auto: true,
    // swf文件路径 下载js 里面有.swf文件
    swf: '/js/plugins/webuploader/Uploader.swf',
    // 文件接收服务端。后台控制层
    server: '/common/upload',
    // 选择文件的按钮。可选。
    // 内部根据当前运行是创建,可能是input元素,也可能是flash.
    pick: id,
    // 只允许选择图片文件。
    accept: {
      title: 'Images',
      extensions: 'gif,jpg,jpeg,bmp,png',
      mimeTypes: 'image/gif,image/jpg,image/jpeg,image/bmp,image/png',
    },
  });
  /**
   * 验证文件格式、数量以及文件大小
   */
  uploader.on("error", function(type) {
    if (type == "Q_TYPE_DENIED") {
      alert("请上传图片格式文件");

    } else if (type == "F_EXCEED_SIZE") {
      alert("文件大小不能超过8M");
    }
  });

  // 文件上传失败,显示上传出错。
  uploader.on( 'uploadError', function( file ) {
    alert("上传失败,请重试!");
  });

  // 文件上传成功,给item添加成功class, 用样式标记上传成功。data回调的js
  uploader.on('uploadSuccess', function(file,data) {
    $(imageHidden).val('/' + data.nname);
    $(image).attr("src", data.src);
    $(image).css("margin-top", "10px");
    $(image).show();
    $(image).removeClass("hide");
  });
}
//jsp页面
<div class="center-block">
        <div class="btn-group col-sm-12">
          <div class="fl">
           <div id="fileInput">选择图片</div>
           <img src=""
           class="wd200 mt10"
           id="image" width="200"/>
        </div>
    <span class="help-block m-b-none">图片大小:510x294</span>
    <input class="form-control" id="imageHidden" name="cover" type="text"/>
    </div>
</div>
 //引用 js初始化插件
  InfoWebUploaderImg("#fileInput", "spvideoimg", "#image", "input[name=cover]", "singleDiv");

java 后台

//上传图片(阿里云) 控制层
@ResponseBody
  @RequestMapping(value = "/upload", method = RequestMethod.POST)
  public String upload(@RequestParam(value = "f", required = false, defaultValue = "") String f,
             String folder,
             MultipartHttpServletRequest request, HttpServletResponse response) {
    return commonService.upload(folder, f, request, response);
  }

//业务处理
 public String upload(String folder, String f, MultipartHttpServletRequest request, HttpServletResponse response) {
    log.info("CommonService上传图片(腾讯云):newFilename11:" + f);
    JSONObject jsonObject = new JSONObject();
    String result = "";
    try {
      Iterator<String> itr = request.getFileNames();
      MultipartFile file = null;
      String name = "";
      while (itr.hasNext()) {
        file = request.getFile(itr.next());
        name = file.getOriginalFilename();
        String newFilenameBase = UUID.randomUUID().toString().replace("-", "");
        String originalFileExtension = file.getOriginalFilename().substring(file.getOriginalFilename().lastIndexOf("."));
        String newFilename = newFilenameBase + originalFileExtension;
        if (!StringUtils.isBlank(f)) {
          if (f.startsWith(","))
            f.substring(1);
          newFilename = (f.contains(".") ? f.substring(0, f.lastIndexOf(".")) : f) + ".jpg";
        }
        newFilename = "img/" + newFilename;
        AliyunOssUtils.upLoadFile(newFilename,PropertyUtil.getValue("folder"),file);

        //TentunOssUtils.uploadImage(file, newFilename);
        /*if (PropertyUtil.getValue("pic_url").endsWith("/")) {
          jsonObject.put("src", PropertyUtil.getValue("pic_url") + newFilename);
        } else {
          jsonObject.put("src", PropertyUtil.getValue("pic_url") + "/" + newFilename);
        }*/
        jsonObject.put("src",CommonUtils.setImageVideoUrlSign(newFilename));

            jsonObject.put("oname", name);
        jsonObject.put("nname", newFilename);
        //删除暂存在root里的图片
        File tempFile = new File(name);
        if (tempFile != null && tempFile.exists()) {
          tempFile.delete();
        }
      }
    } catch (Exception e) {
      log.error("上传图片异常", e);
      jsonObject.put("e", e.getMessage());
    }
    result = jsonObject.toString();
    return result;
  }

工具类:

/**
   * 文件上传
   * @param filename
   * @param file
*/
  public static void upLoadFile(String filename,String folder, MultipartFile file) {
   try {
   // Endpoint以杭州为例,其它Region请按实际情况填写。
     String endpoint = UPLOAD_HOST;
     // 阿里云主账号AccessKey拥有所有API的访问权限,风险很高。强烈建议您创建并使用RAM账号进行API访问或日常运维
     String accessKeyId = ACCESS_KEY_ID;
     String accessKeySecret = ACCESS_KEY_SECRET;

     // 创建OSSClient实例。
     OSS ossClient = new OSSClientBuilder().build(endpoint, accessKeyId, accessKeySecret);

     // 创建PutObjectRequest对象。
     PutObjectRequest putObjectRequest = new PutObjectRequest(folder, filename, multipartFileToFile(file));

     // 如果需要上传时设置存储类型与访问权限,请参考以下示例代码。
     // ObjectMetadata metadata = new ObjectMetadata();
     // metadata.setHeader(OSSHeaders.OSS_STORAGE_CLASS, StorageClass.Standard.toString());
     // metadata.setObjectAcl(CannedAccessControlList.Private);
     // putObjectRequest.setMetadata(metadata);

     // 上传文件。
     ossClient.putObject(putObjectRequest);

     // 关闭OSSClient。
     ossClient.shutdown();
   } catch (Exception e) {
      e.printStackTrace();
    }
  }

  public static String setImageVideoUrlSign(String cover) {
    if (cover.startsWith("/")) cover = cover.substring(1);
      String host = PropertyUtil.getValue("pic_url");
    if (!host.endsWith("/")) host = host + "/";
    if (cover.startsWith("http") && cover.contains(host)) {
      cover = host + cover + "?" + TentunOssUtils.getSigne(cover.replace(host, ""));
    } else if (!cover.startsWith("http")) {
      cover = host + cover + "?" + TentunOssUtils.getSigne(cover);
    }
    return cover;
  }

  public static String getSigne(String key) {
    if (!key.startsWith("/")) key = "/" + key;
    String sign = "";
    String secretId = SECRET_ID;
    String secretKey = SECRET_KEY;
    COSCredentials cred = new BasicCOSCredentials(secretId, secretKey);
    COSSigner signer = new COSSigner();
    // 设置过期时间为1个小时
    Date expiredTime = new Date(System.currentTimeMillis() + 3600L * 1000L);
    // 要签名的 key, 生成的签名只能用于对应此 key 的下载
//    String key = "/exampleobject";
    sign = signer.buildAuthorizationStr(HttpMethodName.GET, key, cred, expiredTime);
    return sign;
  }

xml包:

<!-- 阿里云oss -->
<dependency>
  <groupId>com.aliyun.oss</groupId>
   <artifactId>aliyun-sdk-oss</artifactId>
   <version>3.8.0</version>
</dependency>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • webuploader 实现图片批量上传功能附实例代码

    1.导入资源 2.JSP代码 <div class="page-container"> <div class="row cl"> <label class="form-label col-xs-4 col-sm-2"><span class="c-red">*</span>项目名称:</label> <div class="formCont

  • webuploader实现上传图片到服务器功能

    本文为大家分享了webuploader实现上传图片到服务器的具体代码,供大家参考,具体内容如下 效果图: 一.引入资源文件 1.1 引入webuploader.css文件 <!--引入CSS--> <link rel="stylesheet" type="text/css" href="../../css/plugins/webuploader/webuploader.css" > 1.2 引入webuploader.mi

  • webuploader+springmvc实现图片上传功能

    本文为大家分享了webuploader springmvc实现图片上传的具体代码,供大家参考,具体内容如下 jsp文件 <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN&qu

  • WebUploader客户端批量上传图片 后台使用springMVC

    本文为大家讲解了如何使用WebUploader客户端批量上传图片,供大家参考,具体内容如下 因为最近主管让用webUploader写客户端,但是在网上找了很多,能够复制就能用的并没有几个,但是经过修改后还可以,为了后面的人在需要使用到的时候可以直接copy我再此将代码和注释共享在这里. <!--需要引入的文件--> <link rel="stylesheet" type="text/css" href="../css/webuploade

  • WebUploader实现图片上传功能

    本文实例为大家分享了WebUploader实现图片上传的具体代码,供大家参考,具体内容如下 描述:springmvc 在jsp页面实现 WebUploader插件上传图片, 上传到 oss阿里云存储上. 预览: 理解: 前端 WebUploader插件(这个得去看官网)调起后台,后台 request 接收文件参数, 重新拼装图片url,oss创建连接上传图片提交图片,最后返回图片绝对url和相对url给前端. 先实现前端:1.定义js 2.定义页面 //导入 WebUploader插件js.cs

  • Spring Boot 利用WebUploader进行文件上传功能

    Web Uploader简介 WebUploader是由Baidu WebFE(FEX)团队开发的一个简单的以HTML5为主,FLASH为辅的现代文件上传组件.在现代的浏览器里面能充分发挥HTML5的优势,同时又不摒弃主流IE浏览器,沿用原来的FLASH运行时,兼容IE6+,iOS 6+, android 4+.两套运行时,同样的调用方式,可供用户任意选用.采用大文件分片并发上传,极大的提高了文件上传效率. 我们这里使用官网的一个例子来实现我们个人头像的上传. 我们的重点是在Spring Boo

  • java使用CKEditor实现图片上传功能

    java如何使用CKEditor实现图片上传功能,具体内容如下 1.根据实际需要下载指定的CKEditor 2.删除文件ckeditor/plugins/image/dialogs/image.js预览框中文本内容,并修改hidden属性值为显示上传选项卡 删除image.js中包含在双引号中的上述文本 将image.js中的hidden属性值改为0 3.修改ckeditor/config.js文件,配置"上传到服务器"按钮调用的controller接口 4."上传到服务器&

  • iOS实现压缩图片上传功能

    本文实例为大家分享了iOS实现压缩图片上传功能,供大家参考,具体内容如下 #pragma mark - 打开相机 -(void)imagePickerController:(UIImagePickerController *)picker didFinishPickingMediaWithInfo:(NSDictionary<NSString *,id> *)info{ UIImage *image = info[UIImagePickerControllerOriginalImage]; s

  • 使用express+multer实现node中的图片上传功能

    下文给大家介绍使用express+multer实现node中的图片上传功能,具体内容介绍如下所示: 在前端中,我们使用ajax来异步上传图片,使用file-input来上传图片,使用formdata对象来处理图片数据,post到服务器中 在node中使用multer中间件来对上传路由接口进行处理 multer文档 package.json html部分 <body> <div class="form-group"> <label>File input

  • 微信小程序基于腾讯云对象存储的图片上传功能

    在使用腾讯云对象存储之前,公司一直使用的是传统的FTP的上传模式,而随着用户量的不断增加,FTP所暴露出来的问题也越来越多,1.传输效率低,上传速度慢.2.时常有上传其他文件来攻击服务器,安全上得不到保障.所以我们在经过慎重考虑觉得使用第三方的云存储服务. 在最开始的时候我们在腾讯云与阿里云中选择,最终我们选择腾讯云,腾讯云在文件上传用时方面的性能比较突出,文件越大表现越好:在下载用时方面表现略优于阿里云:文件删除用时方面总体速度略逊于,但在不同大小文件删除用时上都比较稳定.当然这与我们主要用于

  • vue中利用simplemde实现markdown编辑器(增加图片上传功能)

    前言 最近在搭个人博客网站,需要一个 markdown 编辑器,来进行博客的编写 看了网上的教程,决定使用 simplemde 以为可以直接能拿来用的 不过实际运用的时候发现还是有要完善的地方 比如令人头疼的图片上传 最终效果 安装及初始化 npm install simplemde --save 在html中加入一个textarea <textarea id="simplemde"></textarea> 在vue的生命周期函数 mounted 中,添加 si

  • Vue2.0 实现移动端图片上传功能

    本文主要介绍VUE2.0图片上传功能的实现.原理是通过js控制和input标签的方式完成这一效果,无需加载其他组件. 效果图如下: 1.DOM代码 1.1input标签 由于我们是通过input标签的方式进行图片上传的,但是input标签的样式有点丑,所以我们隐藏该样式display: none <input @change="fileChange($event)" type="file" id="upload_file" multiple

  • 详解vue 图片上传功能

    这次做了vue页面的图片上传功能,不带裁剪功能的! 首先是html代码,在input框上添加change事件,如下: <ul class="clearfix"> <li v-if="imgs.length>0" v-for='(item ,index ) in imgs'> <img :src="item"> </li> <li style="position:relative

随机推荐