图片的上传 下载 js html file 打包下载 .zip
2018-03-26 13:46
537 查看
记得以前做网站时,曾经需要实现一个图片上传到服务器前,先预览的功能。当时用html的<input type="file"/>标签一直实现不了,最后舍弃了这个标签,使用了其他方式来实现了这个功能。
今天无意发现了一个知识点,用html的file标签就能实现图片上传前预览,感觉很棒,记录一下!就是通过file标签和js的FileReader接口,把选择的图片文件调用readAsDataURL方法,把图片数据转成base64字符串形式显示在页面上。1、闲话少说,测试一下,图片上传前预览(选择图片):
实现代码:
------------------------------- end ----------------------------- 2、另外 FileReader除了有函数readAsDataURL,另外还有另外两个函数readAsBinaryString 和 readAsText,分别可以将选择的文件读取成二进制和文本格式 测试一下,选择文本(txt、cs、html、js、css、xml),读取成二进制或者文本:选择文件: 实现代码:
---------------------------3、----------- a标签之download属性 ------------- 设置a标签href为图片链接,再设置download属性,点此链接可以直接下载图片
原文链接:http://www.cnblogs.com/tandaxia/p/5125275.html 多图片根据 url 打包下载 .zippublic void download(HttpServletRequest request, HttpServletResponse response){
try {
String downloadFilename = "中文.zip";//文件的名称
downloadFilename = URLEncoder.encode(downloadFilename, "UTF-8");//转换中文否则可能会产生乱码
response.setContentType("application/octet-stream");// 指明response的返回对象是文件流
response.setHeader("Content-Disposition", "attachment;filename=" + downloadFilename);// 设置在下载框默认显示的文件名
ZipOutputStream zos = new ZipOutputStream(response.getOutputStream());
String[] files = new String[]{"http://xxxx/xx.jpg","http://xxx/xx.jpg"};
for (int i=0;i<files.length;i++) {
URL url = new URL(files[i]);
zos.putNextEntry(new ZipEntry(i+".jpg"));
//FileInputStream fis = new FileInputStream(new File(files[i]));
InputStream fis = url.openConnection().getInputStream();
byte[] buffer = new byte[1024];
int r = 0;
while ((r = fis.read(buffer)) != -1) {
zos.write(buffer, 0, r);
}
fis.close();
}
zos.flush();
zos.close();
} catch (UnsupportedEncodingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
今天无意发现了一个知识点,用html的file标签就能实现图片上传前预览,感觉很棒,记录一下!就是通过file标签和js的FileReader接口,把选择的图片文件调用readAsDataURL方法,把图片数据转成base64字符串形式显示在页面上。1、闲话少说,测试一下,图片上传前预览(选择图片):
实现代码:
<div style="border:2px dashed red;"> <p> 图片上传前预览:<input type="file" id="xdaTanFileImg" onchange="xmTanUploadImg(this)" accept="image/*"/> <input type="button" value="隐藏图片" onclick="document.getElementById('xmTanImg').style.display = 'none';"/> <input type="button" value="显示图片" onclick="document.getElementById('xmTanImg').style.display = 'block';"/> </p> <img id="xmTanImg"/> <div id="xmTanDiv"></div> </div> <hr /> <script type="text/javascript"> //判断浏览器是否支持FileReader接口 if (typeof FileReader == 'undefined') { document.getElementById("xmTanDiv").InnerHTML = "<h1>当前浏览器不支持FileReader接口</h1>"; //使选择控件不可操作 document.getElementById("xdaTanFileImg").setAttribute("disabled", "disabled"); } //选择图片,马上预览 function xmTanUploadImg(obj) { var file = obj.files[0]; db8a console.log(obj);console.log(file); console.log("file.size = " + file.size); //file.size 单位为byte var reader = new FileReader(); //读取文件过程方法 reader.onloadstart = function (e) { console.log("开始读取...."); } reader.onprogress = function (e) { console.log("正在读取中...."); } reader.onabort = function (e) { console.log("中断读取...."); } reader.onerror = function (e) { console.log("读取异常...."); } reader.onload = function (e) { console.log("成功读取...."); var img = document.getElementById("xmTanImg"); img.src = e.target.result; //或者 img.src = this.result; //e.target == this } reader.readAsDataURL(file) } </script>
------------------------------- end ----------------------------- 2、另外 FileReader除了有函数readAsDataURL,另外还有另外两个函数readAsBinaryString 和 readAsText,分别可以将选择的文件读取成二进制和文本格式 测试一下,选择文本(txt、cs、html、js、css、xml),读取成二进制或者文本:选择文件: 实现代码:
<script type="text/javascript"> //判断浏览器是否支持FileReader接口 if (typeof FileReader == 'undefined') { document.getElementById("xmTanContentDiv").InnerHTML = "<p>当前浏览器不支持FileReader接口!</p>"; document.getElementById("xmTanFile").setAttribute("disabled", "disabled"); } //选择文件 function xmTanUploadFile(obj){ if (obj.files.length < 1) return; var file = obj.files[0]; if (file.size > 1024 * 1024) { alert("文件大于1M, 太大了,小点吧!"); obj.value = ""; return; } } //读取文件为二进制 function readAsBinaryString() { var obj = document.getElementById("xmTanFile"); if (obj.files.length < 1) return; var file = obj.files[0]; var reader = new FileReader(); //将文件以二进制形式读入页面 reader.readAsBinaryString(file); reader.onload = function (f) { document.getElementById("xmTanContentDiv").innerHTML = this.result; } } //读取文件为文本 function readAsText() { var obj = document.getElementById("xmTanFile"); if (obj.files.length < 1) return; var file = obj.files[0]; var reader = new FileReader(); //将文件以文本形式读入页面 reader.readAsText(file); reader.onload = function (f) { document.getElementById("xmTanContentDiv").innerHTML = this.result; } } </script> <div style="border: 2px dashed red; padding: 20px 0px;"> <label>选择文件:</label> <input type="file" id="xmTanFile" accept=".html,.js,.css,.txt,.cs,.xml" onchange="xmTanUploadFile(this)"/> <input type="button" value="读取成二进制数据" onclick="readAsBinaryString()" /> <input type="button" value="读取成文本数据" onclick="readAsText()" /> <input type="button" value="隐藏读取内容" onclick="document.getElementById('xmTanContentDiv').style.display = 'none';"/> <input type="button" value="显示读取内容" onclick="document.getElementById('xmTanContentDiv').style.display = 'block';"/> <div id="xmTanContentDiv"></div> </div>
---------------------------3、----------- a标签之download属性 ------------- 设置a标签href为图片链接,再设置download属性,点此链接可以直接下载图片
点此下载
实现代码:<div style="text-align:center; padding: 5px 20px;width: 70%;"> <img id="xmTanShowImg" src=""/> <h1><a href="javascript:void()" download="girl.jpg" id="xmTanDownload">点此下载</a></h1> </div> <script type="text/javascript"> //图片转成base64位字符串数据 var imgData = "data:image/png;base64,........."; //或直接设置图片链接: var imgData = "images/picture.png"; document.getElementById("xmTanShowImg").setAttribute("src", imgData); //给图片标签设置src document.getElementById("xmTanDownload").setAttribute("href", imgData); //给a标签设置href </script>
原文链接:http://www.cnblogs.com/tandaxia/p/5125275.html 多图片根据 url 打包下载 .zippublic void download(HttpServletRequest request, HttpServletResponse response){
try {
String downloadFilename = "中文.zip";//文件的名称
downloadFilename = URLEncoder.encode(downloadFilename, "UTF-8");//转换中文否则可能会产生乱码
response.setContentType("application/octet-stream");// 指明response的返回对象是文件流
response.setHeader("Content-Disposition", "attachment;filename=" + downloadFilename);// 设置在下载框默认显示的文件名
ZipOutputStream zos = new ZipOutputStream(response.getOutputStream());
String[] files = new String[]{"http://xxxx/xx.jpg","http://xxx/xx.jpg"};
for (int i=0;i<files.length;i++) {
URL url = new URL(files[i]);
zos.putNextEntry(new ZipEntry(i+".jpg"));
//FileInputStream fis = new FileInputStream(new File(files[i]));
InputStream fis = url.openConnection().getInputStream();
byte[] buffer = new byte[1024];
int r = 0;
while ((r = fis.read(buffer)) != -1) {
zos.write(buffer, 0, r);
}
fis.close();
}
zos.flush();
zos.close();
} catch (UnsupportedEncodingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
相关文章推荐
- 用HTML的File控件上传图片,用JS判断和限制图片格式、类型、尺寸
- html5+js压缩图片上传
- java指定若干个网络图片,打包为zip下载
- HTML+js+css实现点击图片弹出上传文件窗口的两种思路
- 后台下载微信js sdk上传的图片
- html 实时显示input type=file 上传的图片
- js file上传图片并显示出来
- 破晓之阳原创『上传图片』之HtmlInputFile控件
- js上传照片,预览,压缩后base64编码发送后台,及将后台返回的base64图片显示到HTML
- 关于PHP HTML <input type="file" name="img"/>上传图片,图片大小,宽高,后缀名。
- MVC文件图片ajax上传轻量级解决方案,使用客户端JSAjaxFileUploader插件02-多文件上传
- [js实例] input type=file 上传图片预览 createObjectURL
- js上传图片&预览(filereader)
- JS中利用FileReader实现上传图片前本地预览功能
- 使用微信JS-SDK上传图片,下载
- 原生js FileReader对象实现图片上传本地预览效果
- js获取file控件的完整路径(上传图片预览)
- AjaxFileUpload实现文件异步上传(AjaxFileUpload.js文件下载及参数介绍)
- 基于asp.net + easyui框架,js实现上传图片之前判断图片格式,同时实现预览,兼容各种浏览器+下载
- 微信 java 实现js-sdk 图片上传下载完整流程