整合營銷服務商

          電腦端+手機端+微信端=數據同步管理

          免費咨詢熱線:

          html5多圖上傳插件 支持拖拽-zyUpload

          html5多圖上傳插件 支持拖拽-zyUpload

          插件基于jquery,所以必須引入jquery包.

          先看預覽圖:

          1 引入js和css

          servlet后臺需要的包:

          2 html中放置按鈕3 寫js代碼
          $("#zyupload").zyUpload({ width: "650px", // 寬度 height: "400px", // 寬度 itemWidth: "140px", // 文件項的寬度 itemHeight: "115px", // 文件項的高度 url: "servlet/uploadAction", // 上傳文件的路徑 fileType: ["jpg", "png", "txt", "js"], // 上傳文件的類型 fileSize: 51200000, // 上傳文件的大小 multiple: true, // 是否可以多個文件上傳 dragDrop: true, // 是否可以拖動上傳文件 tailor: true, // 是否可以裁剪圖片 del: true, // 是否可以刪除文件 finishDel: false, // 是否在上傳文件完成后刪除預覽 /* 外部獲得的回調接口 */ onSelect: function(selectFiles, allFiles) { // 選擇文件的回調方法 selectFile:當前選中的文件 allFiles:還沒上傳的全部文件 console.info("當前選擇了以下文件:"); console.info(selectFiles); }, onDelete: function(file, files) { // 刪除一個文件的回調方法 file:當前刪除的文件 files:刪除之后的文件 console.info("當前刪除了此文件:"); console.info(file.name); }, onSuccess: function(file, response) { // 文件上傳成功的回調方法 console.info("此文件上傳成功:"); console.info(file.name); console.info("此文件上傳到服務器地址:"); console.info(response); $("#uploadInf").append("<p>上傳成功,文件地址是:" + response + "</p>"); }, onFailure: function(file, response) { // 文件上傳失敗的回調方法 console.info("此文件上傳失敗:"); console.info(file.name); }, onComplete: function(response) { // 上傳完成的回調方法 console.info("文件上傳完成"); console.info(response); } });
          4 后臺servlet或者Struts2或者SpringMVC都可以.這里使用servlet代碼,使用common第三方包
          public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { DiskFileItemFactory factory=new DiskFileItemFactory(); ServletFileUpload upload=new ServletFileUpload(factory); List<FileItem> list=null ; try { list=upload.parseRequest(request); } catch (FileUploadException e) { e.printStackTrace(); } String id=request.getParameter("id"); TGreens t=null; try { t=service.getTGreens(id); } catch (SQLException e) { e.printStackTrace(); } for(int i=0;i<list.size();i++){ FileItem item=list.get(i); if(item.isFormField()){ }else{ InputStream is=item.getInputStream(); String path=getServletContext().getRealPath("/upload"); //保存到tomcat安裝目錄 String fileName=item.getName(); //文件名 System.out.println("======================="+fileName); String hz=fileName.substring(fileName.lastIndexOf("."));//取后綴 String uuid=UUID.randomUUID().toString(); OutputStream os=new FileOutputStream(path+"http://"+uuid+""+hz); int len=0; byte[] b=new byte[1024]; while((len=is.read(b))>-1){ os.write(b, 0, len); } os.close(); t.setGimg("upload/"+uuid+""+hz); try { service.update(t); //插入數據庫 } catch (SQLException e) { e.printStackTrace(); } PrintWriter out=response.getWriter(); out.print(path+"/"+uuid+hz); out.close(); } } }


          資源下載和demo演示地址:http://demo.sucaihuo.com/1085/程序員都懂的,右鍵查看源代碼即可下載css和js了

          傳、預覽、下載圖片是app常用的功能之一,一般的做法是建立一個圖片存儲服務器,再開發一個接收前端上傳文件的后端服務,接收到前端上傳的圖片文件,然后再調用存儲服務器的接口完成圖片文件的存儲。

          現在阿里云提供了對象存儲云服務(OSS),非常方便APP直接將圖片等文件上傳上去,并提供了多種瀏覽、下載的方式,不僅操作簡單、而且效率高、速度快,本文介紹三種使用方式,希望能夠讓工程師少走彎路。

          傳統模式

          這種方式只是把OSS作為文件存儲體替代了自建存儲器,上傳邏輯和路徑還是和傳統的方式一致,后端服務給前端提供上傳接口,在收到前端上傳的文件后,再調用阿里云的OSS SDK的API將文件上傳到阿里云的OSS存儲桶中。

          上傳流程

          詳細說明及相關代碼請參考《云平臺對象存儲OSS》

          直接表單方式

          這種方式更加的便捷、快速,無需開發接收后端服務,而是前端直接將文件上傳到OSS,這種方式就要求前端按照約定的參數訪問OSS API,為了安全起見要按照阿里云SDK的方式生成相應的簽名并提供給前端。

          FORM表單直接上傳流程

          這里要求提前生成簽名串,生成算法如下:

          package aliyun;
          
          import aliyun.pojo.ResultData;
          import aliyun.pojo.SignatureData;
          import com.alibaba.fastjson.JSONObject;
          import org.apache.commons.codec.binary.Base64;
          
          public class Controller {
              private final static String POLICY="{\"expiration\":\"2025-12-31T23:59:59Z\",\"conditions\":[[\"content-length-range\",0,104857600]]}";
              private String accessKeySecret=System.getenv("ACCESS_SECRET_CODE");
          
              public String signatureCode(int times) throws Exception {
                  ResultData resultData=new ResultData();
          
                  //約束規則
                  String encodePolicy=new String(Base64.encodeBase64(POLICY.getBytes()));
                  // 生成簽名。
                  String signatureCom=com.aliyun.oss.common.auth.ServiceSignature.create().computeSignature(accessKeySecret, encodePolicy);
          
                  SignatureData signatureData=new SignatureData(encodePolicy,signatureCom);
                  resultData.setData(signatureData);
          
                  return JSONObject.toJSONString(resultData);
              }
          }

          其中:POLICY定義了上傳有效時間和文件大小約束,簽名要用到阿里云賬號的Access Key Secret。這里的簽名是有時效性的,有效期內不會改變,如果對安全要求很高,可以將該簽名過程作為服務發布,讓前端每次在上傳的時候調用服務獲取實時的簽名數據。

          前端form表單的構成如下:

          <div id="upload">
              <form  action="http://mybucket.oss-cn-beijing.aliyuncs.com" method="post" enctype="multipart/form-data">
                  <p>阿里云AccessKeyID:<input type="text" name="OSSAccessKeyId" value="LTAI8N5***XX8cr"></p>
                  <p>約束規則base64:<input type="text" name="policy" value='eyJleHBpcmF0aW9uI*********zMVQyMzo1OTo1OVoiLCJjb25kaXRpb25zIjpbWyJjb250ZW50LWxlbmd0aC1yYW5nZSIsMCwxMDQ4NTc2MDBdXX0='></p>
                  <p>約束規則簽名:<input type="text" name="Signature" value="pgxE8VnN8kSJEWz*****QV7uBE="></p>
                  <p>OSS存儲文件名:<input type="text" name="key" value="upload/lee.jpg"></p>
                  <p>選擇上傳文件:<input name="file" type="file" id="file"></p>
                  <input name="submit" value="上傳" type="submit">
              </form>
          </div>

          其中:action是你賬號下OSS存儲桶的endpoint URL,OSSAccessKeyId是你賬號下的AccessKey ID,policy是對上傳規則約束的base64編碼(這里千萬不能直接使用你定義的policy字符串,而是該字符串的字節碼的base64編碼后的結果,即由上面的計算結果提供),Signature就是對policy的簽名結果,key是存儲到你指定bucket的目錄和文件名。

          ajax方式

          通過這種方式可以不刷新頁面完成文件直接上傳到OSS,建議采用plupload.js插件實現。

          <!DOCTYPE html>
          <html>
          <head>
          	<meta http-equiv="content-type" content="text/html; charset=UTF-8"/>
          	<title>OSS web直傳</title>
          	<link rel="stylesheet" type="text/css" href="style.css"/>
          	<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no">
          </head>
          <body>
          
          <h2>OSS web直傳---直接在JS簽名</h2>
          <ol>
          <li>基于plupload封裝 </li>
          <li>支持html5,flash,silverlight,html4 等協議上傳</li>
          <li>可以運行在PC瀏覽器,手機瀏覽器,微信</li>
          <li>可以選擇多文件上傳</li>
          <li>顯示上傳進度條</li>
          <li>可以控制上傳文件的大小</li>
          <li>最關鍵的是,讓你10分鐘之內就能移植到你的系統,實現以上牛逼的功能!</li>
          <li>注意一點,bucket必須設置了Cors(Post打勾),不然沒有辦法上傳</li>
          <li>注意一點,把upload.js 里面的host/accessid/accesskey改成您上傳所需要的信息即可</li>
          <li>此方法是直接在前端簽名,有accessid/accesskey泄漏的風險, 線上生產請使用后端簽名例子<a href="https://help.aliyun.com/document_detail/oss/practice/pc_web_upload/js_php_upload.html">點擊查看詳細文檔</a></li>
          </ol>
          <br>
          <form name="theform">
            <input type="radio" name="myradio" value="local_name" checked=true/> 上傳文件名字保持本地文件名字
            <input type="radio" name="myradio" value="random_name" /> 上傳文件名字是隨機文件名
          <br/>
          上傳到指定目錄:<input type="text" id='dirname' placeholder="如果不填,默認是上傳到根目錄" size=50>
          </form>
          
          <h4>您所選擇的文件列表:</h4>
          <div id="ossfile">你的瀏覽器不支持flash,Silverlight或者HTML5!</div>
          
          <br/>
          
          <div id="container">
          	<a id="selectfiles" href="javascript:void(0);" class='btn'>選擇文件</a>
          	<a id="postfiles" href="javascript:void(0);" class='btn'>開始上傳</a>
          </div>
          
          <pre id="console"></pre>
          
          <p> </p>
          
          </body>
          <script type="text/javascript" src="lib/plupload-2.1.2/js/plupload.full.min.js"></script>
          <script type="text/javascript" src="upload.js"></script>
          </html>

          upload.js代碼如下:

          host='http://mybucket.oss-cn-beijing.aliyuncs.com';
          accessid='LTAI8N***mXX8cr';
          signature="pgxE8V******Wz1jKv7cQV7uBE=";
          policyBase64="eyJleHBpcmF0aW9uIjoiMjAyNS0xMi0zMVQyMzo1OTo1OVoiLCJjb25kaXRpb25zIjpbWyJjb250ZW50LWxlbmd0aC1yYW5nZSIsMCwxMDQ4NTc2MDBdXX0=";
          
          g_dirname=''
          g_object_name=''
          g_object_name_type=''
          now=timestamp=Date.parse(new Date()) / 1000; 
          
          function check_object_radio() {
              var tt=document.getElementsByName('myradio');
              for (var i=0; i < tt.length ; i++ )
              {
                  if(tt[i].checked)
                  {
                      g_object_name_type=tt[i].value;
                      break;
                  }
              }
          }
          
          function get_dirname()
          {
              dir=document.getElementById("dirname").value;
              if (dir !='' && dir.indexOf('/') !=dir.length - 1)
              {
                  dir=dir + '/'
              }
              //alert(dir)
              g_dirname=dir
          }
          
          function random_string(len) {
            len=len || 32;
            var chars='ABCDEFGHJKMNPQRSTWXYZabcdefhijkmnprstwxyz2345678';   
            var maxPos=chars.length;
            var pwd='';
            for (i=0; i < len; i++) {
                pwd +=chars.charAt(Math.floor(Math.random() * maxPos));
              }
              return pwd;
          }
          
          function get_suffix(filename) {
              pos=filename.lastIndexOf('.')
              suffix=''
              if (pos !=-1) {
                  suffix=filename.substring(pos)
              }
              return suffix;
          }
          
          function calculate_object_name(filename)
          {
              if (g_object_name_type=='local_name')
              {
                  g_object_name +="${filename}"
              }
              else if (g_object_name_type=='random_name')
              {
                  suffix=get_suffix(filename)
                  g_object_name=g_dirname + random_string(10) + suffix
              }
              return ''
          }
          
          function get_uploaded_object_name(filename)
          {
              if (g_object_name_type=='local_name')
              {
                  tmp_name=g_object_name
                  tmp_name=tmp_name.replace("${filename}", filename);
                  return tmp_name
              }
              else if(g_object_name_type=='random_name')
              {
                  return g_object_name
              }
          }
          
          function set_upload_param(up, filename, ret)
          {
              g_object_name=g_dirname;
              if (filename !='') {
                  suffix=get_suffix(filename)
                  calculate_object_name(filename)
              }
              new_multipart_params={
                  'key' : g_object_name,
                  'policy': policyBase64,
                  'OSSAccessKeyId': accessid, 
                  'success_action_status' : '200', //讓服務端返回200,不然,默認會返回204
                  'signature': signature,
              };
          
              up.setOption({
                  'url': host,
                  'multipart_params': new_multipart_params
              });
          
              up.start();
          }
          
          var uploader=new plupload.Uploader({
          	runtimes : 'html5,flash,silverlight,html4',
          	browse_button : 'selectfiles', 
          	container: document.getElementById('container'),
          	flash_swf_url : 'lib/plupload-2.1.2/js/Moxie.swf',
          	silverlight_xap_url : 'lib/plupload-2.1.2/js/Moxie.xap',
              url : 'http://oss.aliyuncs.com',
          
          	init: {
          		PostInit: function() {
          			document.getElementById('ossfile').innerHTML='';
          			document.getElementById('postfiles').onclick=function() {
                      set_upload_param(uploader, '', false);
                      return false;
          			};
          		},
          
          		FilesAdded: function(up, files) {
          			plupload.each(files, function(file) {
          				document.getElementById('ossfile').innerHTML +='<div id="' + file.id + '">' + file.name + ' (' + plupload.formatSize(file.size) + ')<b></b>'
          				+'<div class="progress"><div class="progress-bar" style="width: 0%"></div></div>'
          				+'</div>';
          			});
          		},
          
          		BeforeUpload: function(up, file) {
                      check_object_radio();
                      get_dirname();
                      set_upload_param(up, file.name, true);
                  },
          
          		UploadProgress: function(up, file) {
          			var d=document.getElementById(file.id);
          			d.getElementsByTagName('b')[0].innerHTML='<span>' + file.percent + "%</span>";
                      var prog=d.getElementsByTagName('div')[0];
          			var progBar=prog.getElementsByTagName('div')[0]
          			progBar.style.width=2*file.percent+'px';
          			progBar.setAttribute('aria-valuenow', file.percent);
          		},
          
          		FileUploaded: function(up, file, info) {
                      if (info.status==200)
                      {
                          document.getElementById(file.id).getElementsByTagName('b')[0].innerHTML='upload to oss success, object name:' + get_uploaded_object_name(file.name);
                      }
                      else
                      {
                          document.getElementById(file.id).getElementsByTagName('b')[0].innerHTML=info.response;
                      } 
          		},
          
          		Error: function(up, err) {
          			document.getElementById('console').appendChild(document.createTextNode("\nError xml:" + err.response));
          		}
          	}
          });
          
          uploader.init();

          其中:host為OSS存儲桶endpoint地址、accessid為阿里云賬號ID、signature為后端生成的簽名、policyBase64為規則json串的base64編碼

          訪問上傳的文件

          有多種方式可以查看你上傳的文件,詳細操作見阿里云OSS操作手冊。這里只說明一種直接通過URL訪問的方式。

          針對該bucket設置為開通“靜態頁面”、權限管理設置為“公共可讀”、防盜鏈設置“referer”等安全選項,然后就可以通過類似

          http://mybucket.oss-cn-beijing.aliyuncs.com/upload/lee

          的方式訪問你上傳的圖片等文件了。

          TML5實現頭像的上傳

          這是利用form-data給后臺傳輸數據,來實現頭像的上傳加載!

          1. html代碼
          <!DOCTYPE html>
          <html lang="en">
          <head>
              <meta charset="UTF-8">
              <meta name="viewport" content="width=, initial-scale=1.0">
              <meta http-equiv="X-UA-Compatible" content="ie=edge">
              <title>Document</title>
              </head>
          <body>
              <div class="container">
                  <input enctype="multipart/form-data" type="file">
                  <input id="Susername"  type="text" placeholder="用戶名">
                  <input id="Ssex" type="number" placeholder="年齡">
                  <input id="Sage" type="text" placeholder="專業">
                  <input id="Smajor" type="text" placeholder="學校">
                  <input id="Sschool" type="text" placeholder="QQ">
                  <input id="Sqq" type="text" placeholder="地址">
                  <input id="Saddress" type="text" placeholder="座右銘">
                  <input id="Smotto" type="button" value="上傳">
                 
                  <div style="clear: both;"></div>
                       <progress value="0" max="100"></progress>
              </div>
              <div class="showarea">
                  <h3>顯示區域</h3>
              </div>
              </body>
          </html>
          
          1. 樣式代碼
           .container{
                      box-sizing: border-box;
                      width: 404px;
                      height: 100px;
                      border: 1px solid #ccc;
                      border-radius: 5px;
                      padding-top: 20px;
                      background: linear-gradient(to bottom,#0ff,#0ff 20px,transparent 0);
                      margin: 0 auto;
                  }
                  input{
                      padding: 0;
                      margin: 0;
                    
                  }
                  .container input[type=file]{
                      width: 300px;
                      height: 30px;
                      border: 1px solid #ccc;
                      background: #7FFFD4;
                      color: #133131;
                      float: left;
                  }
                  .container input[typr=button]{
                      width: 100px;
                      height: 32px;
                      float: left;
                      border: 1px solid #ccc;
                      color:  #133131;
                  }
                  progress{
                      display: none;
                      width: 400px;
                      height: 30px;
                      margin-top: 7px;
                  }
                  .showarea{
                      width: 600px;
                      min-height: 200px;
                      border: 1px solid #ccc;
                      margin: 30px auto;
                  }
                  .showarea h3{
                      widows: 100px;
                      margin: 0 auto;
                      line-height: 60px;
                      text-align: center;
                      border-bottom: 1px solid #cccc;
                      color: #133131;
                      
                  }
                  .showareaimg{
                      max-width: 1000%;
                  }
          
          1. javescript代碼

          主站蜘蛛池模板: 中文人妻无码一区二区三区| 久久精品视频一区| 日韩电影一区二区| 日日摸夜夜添一区| 日韩精品一区二区三区影院| 无码AV中文一区二区三区| 亚洲国产AV无码一区二区三区| 国偷自产视频一区二区久| 午夜福利av无码一区二区 | 无码人妻AⅤ一区二区三区| 精品无码人妻一区二区三区品| 亚洲av成人一区二区三区在线观看 | 亚洲乱码av中文一区二区 | 黄桃AV无码免费一区二区三区| 亚洲欧美日韩中文字幕在线一区 | 午夜影院一区二区| 无码国产精品一区二区免费3p| 夜夜添无码一区二区三区| 偷拍精品视频一区二区三区| 波多野结衣一区二区三区高清在线| 无码免费一区二区三区免费播放| 亚洲乱色熟女一区二区三区丝袜| 国产观看精品一区二区三区| 亚洲国产一区二区三区| 精品一区二区三区色花堂| 激情内射日本一区二区三区| 国精品无码A区一区二区| 亚洲av日韩综合一区在线观看| 日本一区二区三区高清| 精品一区二区三区四区在线播放| 人妻久久久一区二区三区| 日本一道一区二区免费看| 国产免费播放一区二区| 中文字幕Av一区乱码| 国内自拍视频一区二区三区| 中文无码AV一区二区三区| 国产精品视频一区二区三区| 亚洲av午夜精品一区二区三区| 无码国产精成人午夜视频一区二区| 在线电影一区二区| 国产成人AV一区二区三区无码 |