对于想了解js同时下载多个文件的读者,本文将提供新的信息,我们将详细介绍js怎样一键下载多个文件,并且为您提供关于android:利用异步请求同时下载多张图片(07)、asp.net多个文件同时下载、
对于想了解js 同时下载多个文件的读者,本文将提供新的信息,我们将详细介绍js怎样一键下载多个文件,并且为您提供关于android:利用异步请求同时下载多张图片(07)、asp.net 多个文件同时下载、asp.net实现多个文件同时下载功能、C++ 如何同时下载多个文件的有价值信息。
本文目录一览:- js 同时下载多个文件(js怎样一键下载多个文件)
- android:利用异步请求同时下载多张图片(07)
- asp.net 多个文件同时下载
- asp.net实现多个文件同时下载功能
- C++ 如何同时下载多个文件
js 同时下载多个文件(js怎样一键下载多个文件)
export const downloadFile = (fileName, url)=> {
if (isIE()) {
ieDown(url)
} else {
var aLink = document.createElement(''a'');
var evt = document.createEvent(''MouseEvents'');
// var evt = document.createEvent("HTMLEvents")
evt.initMouseEvent(''click'', true, false, window, 0, 0, 0, 0, 0, false, false, false, false, 0, null);
// evt.initEvent("click", false, false)//initEvent 不加后两个参数在FF下会报错, 感谢 Barret Lee 的反馈
aLink.download = fileName;
aLink.href = url;
aLink.dispatchEvent(evt)
}
};
export const isIE = ()=> {
var explorer = window.navigator.userAgent;
return explorer.indexOf(''MSIE'') >= 0 || explorer.indexOf(''Trident/7.0'') >= 0;
};
const ieDown = url=> {
window.open(url)
};
android:利用异步请求同时下载多张图片(07)
android:利用异步同时下载多张图片(07)
android:利用异步同时下载多张图片,doInBackground()方法下载后返回的时候返回一个list
//布局文件就是四个ImageView
//第一种返回的是一个数组的集合,再转换成位图
//第二种返回的直接是位图集合
public class MainActivity extends Activity {
private ImageView image_1;
private ImageView image_2;
private ImageView image_3;
private ImageView image_4;
private String urlString1 = "http://www.touxiang.cn/uploads/20130608/08-023618_517.jpg";
private String urlString2 = "http://www.touxiang.cn/uploads/20140216/16-075941_383-lp.jpg";
private String urlString3 = "http://www.touxiang.cn/uploads/20140216/16-082440_368-lp.jpg";
private String urlString4 = "http://www.touxiang.cn/uploads/20140216/16-063601_933-lp.jpg";
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
this.image_1 = (ImageView) this.findViewById(R.id.image_1);
this.image_2 = (ImageView) this.findViewById(R.id.image_2);
this.image_3 = (ImageView) this.findViewById(R.id.image_3);
this.image_4 = (ImageView) this.findViewById(R.id.image_4);
/* 也可以定义为数组 String[] url = { "http://litchiapi.jstv.com/Attachs/Top/11949/e650e0201de541d2ba91dca202b0fcfe.jpg",
"http://192.168.10.85:8080/xml/login.jpeg",
"http://192.168.10.85:8080/xml/ss.jpg",
"http://g.hiphotos.baidu.com/image/h%3D200/sign=bff104116009c93d18f209f7af3cf8bb/024f78f0f736afc30fd7717ab419ebc4b64512d1.jpg" };
//"http://192.168.10.85:8080/xml/ss.jpg"本地服务器的图片
*/
new myTask().execute(urlString1,urlString2,urlString3,urlString4);
}
class myTask extends AsyncTask<String, Integer, List<byte[]>> {
@Override
protected List<byte[]> doInBackground(String... params) {
List<byte[]> list = new ArrayList<byte[]>();
HttpClient client = new DefaultHttpClient();
for (int i = 0; i < params.length; i++) {
HttpGet get = new HttpGet(params[i]);
try {
HttpResponse response = client.execute(get);
if (response.getStatusLine().getStatusCode() == 200) {
list.add(EntityUtils.toByteArray(response.getEntity()));
}
} catch (ClientProtocolException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
return list;
}
@Override
protected void onPostExecute(List<byte[]> result) {
if (result != null) {
Bitmap bitmap_1 = BitmapFactory.decodeByteArray(result.get(0),
0, result.get(0).length);
image_1.setImageBitmap(bitmap_1);
Bitmap bitmap_2 = BitmapFactory.decodeByteArray(result.get(1),
0, result.get(1).length);
image_2.setImageBitmap(bitmap_2);
Bitmap bitmap_3 = BitmapFactory.decodeByteArray(result.get(2),
0, result.get(2).length);
image_3.setImageBitmap(bitmap_3);
Bitmap bitmap_4 = BitmapFactory.decodeByteArray(result.get(3),
0, result.get(3).length);
image_4.setImageBitmap(bitmap_4);
} else {
Toast.makeText(MainActivity.this, "网络错误!!", Toast.LENGTH_SHORT)
.show();
}
}
}
}
//第二种方法返回的直接是位图集合:如下:
protected List<Bitmap> doInBackground(String... params) {
List<Bitmap> list = new ArrayList<Bitmap>();
for (int i = 0; i < params.length; i++) {
try {
HttpClient httpClient = new DefaultHttpClient();
HttpGet httpGet = new HttpGet(params[i]);
HttpResponse response = httpClient.execute(httpGet);
if (response.getStatusLine().getStatusCode() == 200) {
HttpEntity entity = response.getEntity();
byte[] data = EntityUtils.toByteArray(entity);
Bitmap bm = BitmapFactory.decodeByteArray(data, 0,
data.length);
list.add(bm);
}
} catch (Exception e) {
e.printStackTrace();
}
}
return list;
}
@Override
protected void onPostExecute(List<Bitmap> result) {
super.onPostExecute(result);
if (result != null) {
imageView_1.setImageBitmap(result.get(0));
imageView_2.setImageBitmap(result.get(1));
imageView_3.setImageBitmap(result.get(2));
imageView_4.setImageBitmap(result.get(3));
} else {
Toast.makeText(context, "网络异常,加载数据失败!", Toast.LENGTH_LONG)
.show();
}
pDialog.dismiss();
}
}
asp.net 多个文件同时下载
需求:
支持文件批量下载。现在有很多小图片需要批量下载,不希望在服务器打包下载。
支持大文件断点下载。比如下载10G的文件。
PC端全平台支持。Windows,macOS,Linux
全浏览器支持。ie6,ie7,ie8,ie9,ie10,ie11,edge,firefox,chrome,safari
支持文件夹结构下载。不希望在服务器打包,而是直接下载文件夹,下载后在本地文件夹结构和服务器保持一致。
支持从URL中下载文件。
支持JSON数据结构。
方案:
1、首先读取文件夹下的文件,可能同时存在多个文件
2、选中文件,然后点击下载,同时可以选择多个文件。
思路:通过生产压缩包的形式进行下载,然后再清楚压缩包,这样用户可以一次性全部下载下来。
一、获取目录下的所有文件,然后绑定到checkboxlist中 ,代码如下:
批量下载多个文件
$("#btn-down-files").click(function (){
if(downer.Config["Folder"]==""){ downer.open_folder();return;}
var urls =[
{ fileUrl:"http://res2.ncmem.com/res/images/ie11.png"}
,{ fileUrl:"http://res2.ncmem.com/res/images/up6.1/down.png"}
,{ fileUrl:"http://res2.ncmem.com/res/images/firefox.png"}
,{ fileUrl:"http://res2.ncmem.com/res/images/edge.png"}
,{ fileUrl:"http://res2.ncmem.com/res/images/up6.1/cloud.png"}
,{ fileUrl:"http://res2.ncmem.com/res/images/home/w.png"}
,{ fileUrl:"http://res2.ncmem.com/res/images/img.png"}
];
downer.app.addUrls(urls);
});
自定义JSON数据下载
$("#btn-down-json").click(function () {
if (downer.Config["Folder"] == "") { downer.open_folder(); return; }
var fd = {
nameLoc: "图片列表"
, files: [
{ fileUrl: "http://res2.ncmem.com/res/images/ie11.png" }
, { fileUrl: "http://res2.ncmem.com/res/images/up6.1/down.png" }
, { fileUrl: "http://res2.ncmem.com/res/images/firefox.png" }
, { fileUrl: "http://res2.ncmem.com/res/images/edge.png" }
, { fileUrl: "http://res2.ncmem.com/res/images/up6.1/cloud.png" }
, { fileUrl: "http://res2.ncmem.com/res/images/home/w.png" }
, { fileUrl: "http://res2.ncmem.com/res/images/img.png" }
]
};
downer.app.addJson(fd);
});
服务端代码:
protected void Btn_down_Click(object sender, EventArgs e)
{
if (ckl_ck.Items.Count > 0)
{
List<string> listFJ = new List<string>();//保存附件路径
List<string> listFJName = new List<string>();//保存附件名字
for (int i = 0; i < ckl_ck.Items.Count; i++)
{
if (ckl_ck.Items[i].Selected)
{
listFJ.Add(Server.MapPath("Resource/Help/") + ckl_ck.Items[i].Text);
listFJName.Add(ckl_ck.Items[i].Text);
}
}
string time = DateTime.Now.Ticks.ToString();
ZipFileMain(listFJ.ToArray(), listFJName.ToArray(), Server.MapPath("Resource/Help/" + time + ".zip"), 9);//压缩文件
DownloadFile(Server.UrlEncode("附件.zip"), Server.MapPath("Resource/Help/" + time + ".zip"));//下载文件 }
}
private void DownloadFile(string fileName, string filePath)
{
FileInfo fileInfo = new FileInfo(filePath);
Response.Clear();
Response.ClearContent();
Response.ClearHeaders();
Response.AddHeader("Content-Disposition", "attachment;filename=" + fileName);
Response.AddHeader("Content-Length", fileInfo.Length.ToString());
Response.AddHeader("Content-Transfer-Encoding", "binary");
Response.ContentType = "application/octet-stream";
Response.ContentEncoding = System.Text.Encoding.GetEncoding("gb2312");
Response.WriteFile(fileInfo.FullName);
Response.Flush();
File.Delete(filePath);//删除已下载文件 Response.End();
}
/// <summary>
///压缩文件
///</summary>
/// <param name="fileName">要压缩的所有文件(完全路径)</param>
/// <param name="fileName">文件名称</param>
/// <param name="name">压缩后文件路径</param>
/// <param name="Level">压缩级别</param>
public void ZipFileMain(string[] filenames, string[] fileName, string name, int Level)
{
ZipOutputStream s = new ZipOutputStream(File.Create(name));
Crc32 crc = new Crc32();
//压缩级别
s.SetLevel(Level); // 0 - store only to 9 - means best compression
try
{
int m = 0;
foreach (string file in filenames)
{
//打开压缩文件
FileStream fs = File.OpenRead(file);//文件地址
byte[] buffer = new byte[fs.Length];
fs.Read(buffer, 0, buffer.Length);
//建立压缩实体
ZipEntry entry = new ZipEntry(fileName[m].ToString());//原文件名
//时间
entry.DateTime = DateTime.Now;
//空间大小
entry.Size = fs.Length;
fs.Close();
crc.Reset();
crc.Update(buffer);
entry.Crc = crc.Value;
s.PutNextEntry(entry);
s.Write(buffer, 0, buffer.Length);
m++;
}
}
catch
{
throw;
}
finally
{
s.Finish();
s.Close();
}
}
三、系统中需要引用的dll http://blog.ncmem.com/wordpress/2019/08/28/java批量下载/ 需要下载。
四、运行效果如图:
asp.net实现多个文件同时下载功能
本文实例为大家分享了asp.net多个文件同时下载的具体代码,供大家参考,具体内容如下
1、首先读取文件夹下的文件,可能同时存在多个文件
2、选中文件,然后点击下载,同时可以选择多个文件。
思路:通过生产压缩包的形式进行下载,然后再清楚压缩包,这样用户可以一次性全部下载下来。
一、获取目录下的所有文件,然后绑定到checkboxlist中 ,代码如下:
ckl_ck.Items.Clear(); DirectoryInfo TheFolder = new DirectoryInfo(Server.MapPath("Resource/Help")); //遍历文件夹下的文件 foreach (FileInfo NextFile in TheFolder.GetFiles()) this.ckl_ck.Items.Add(NextFile.Name);
二、选中文件后,点击下载按钮。代码:
protected void Btn_down_Click(object sender, EventArgs e) { if (ckl_ck.Items.Count > 0) { List<string> listFJ = new List<string>();//保存附件路径 List<string> listFJName = new List<string>();//保存附件名字 for (int i = 0; i < ckl_ck.Items.Count; i++) { if (ckl_ck.Items[i].Selected) { listFJ.Add(Server.MapPath("Resource/Help/") + ckl_ck.Items[i].Text); listFJName.Add(ckl_ck.Items[i].Text); } } string time = DateTime.Now.Ticks.ToString(); ZipFileMain(listFJ.ToArray(), listFJName.ToArray(), Server.MapPath("Resource/Help/" + time + ".zip"), 9);//压缩文件 DownloadFile(Server.UrlEncode("附件.zip"), Server.MapPath("Resource/Help/" + time + ".zip"));//下载文件 } } private void DownloadFile(string fileName, string filePath) { FileInfo fileInfo = new FileInfo(filePath); Response.Clear(); Response.ClearContent(); Response.ClearHeaders(); Response.AddHeader("Content-Disposition", "attachment;filename=" + fileName); Response.AddHeader("Content-Length", fileInfo.Length.ToString()); Response.AddHeader("Content-Transfer-Encoding", "binary"); Response.ContentType = "application/octet-stream"; Response.ContentEncoding = System.Text.Encoding.GetEncoding("gb2312"); Response.WriteFile(fileInfo.FullName); Response.Flush(); File.Delete(filePath);//删除已下载文件 Response.End(); } /// <summary> /// 压缩文件 /// </summary> /// <param name="fileName">要压缩的所有文件(完全路径)</param> /// <param name="fileName">文件名称</param> /// <param name="name">压缩后文件路径</param> /// <param name="Level">压缩级别</param> public void ZipFileMain(string[] filenames, string[] fileName, string name, int Level) { ZipOutputStream s = new ZipOutputStream(File.Create(name)); Crc32 crc = new Crc32(); //压缩级别 s.SetLevel(Level); // 0 - store only to 9 - means best compression try { int m = 0; foreach (string file in filenames) { //打开压缩文件 FileStream fs = File.OpenRead(file);//文件地址 byte[] buffer = new byte[fs.Length]; fs.Read(buffer, 0, buffer.Length); //建立压缩实体 ZipEntry entry = new ZipEntry(fileName[m].ToString());//原文件名 //时间 entry.DateTime = DateTime.Now; //空间大小 entry.Size = fs.Length; fs.Close(); crc.Reset(); crc.Update(buffer); entry.Crc = crc.Value; s.PutNextEntry(entry); s.Write(buffer, 0, buffer.Length); m++; } } catch { throw; } finally { s.Finish(); s.Close(); } }
三、系统中需要引用的dll 需要下载。
四、运行效果如图:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
- Asp.net实现MVC处理文件的上传下载功能实例教程
- ASP.NET Core实现文件上传和下载
- ASP.NET Core实现动态获取文件并下载
- ASP.NET实现从服务器下载文件问题处理
- asp.net实现服务器文件下载到本地的方法
- ASP.Net下载大文件的实现方法
- ASP.NET 在下载文件时对其重命名的思路及实现方法
- asp.net中文件下载功能的实例代码
- 在ASP.NET中下载文件的实现代码
- asp.net 文件下载实现代码
- ASP.NET MVC实现文件下载
C++ 如何同时下载多个文件
我想设计一个程序,能同时下载多个文件,但不能影响程序性能, 同时下载多文件读写会不会造成IO频繁的问题,如何处理?关于js 同时下载多个文件和js怎样一键下载多个文件的介绍现已完结,谢谢您的耐心阅读,如果想了解更多关于android:利用异步请求同时下载多张图片(07)、asp.net 多个文件同时下载、asp.net实现多个文件同时下载功能、C++ 如何同时下载多个文件的相关知识,请在本站寻找。
本文标签: