用edoc2实现上传和下载
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;
import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.NameValuePair;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.CloseableHttpResponse;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.entity.mime.MultipartEntityBuilder;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClientBuilder;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.message.BasicNameValuePair;
import org.apache.http.util.EntityUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;
import org.springframework.util.StringUtils;
import org.springframework.web.multipart.MultipartFile; import java.io.*;
import java.net.InetAddress;
import java.net.URI;
import java.net.UnknownHostException;
import java.util.*; @Component
public class FileUploadAndDownloadUtil {
private static Logger logger = LoggerFactory.getLogger(FileUploadAndDownloadUtil.class);
/**
* edoc2的url
*/
private static String baseUrl;
/**
* 集成登录密钥
*/
private static String integrationKey;
/**
* 登录用户名
*/
private static String loginName;
/**
* folderId 上传文件及下载文件关联的文件夹的id
*/
private static String folderId;
/*用户凭证*/
private static String token; /*登录*/
private static synchronized String CheckAndLogin() {
logger.info("CheckAndLogin......");
if (StringUtils.isEmpty(token))
return login();
boolean isEffective = checkToken();
if (isEffective)
return token;
else
return login();
} /*登录*/
private static String login() {
String regionUrl = baseUrl + "/api/services/org/UserLoginIntegrationByUserLoginName";
HttpClientRequest req = HttpClientRequest.newInstance();
JSONObject obj = new JSONObject();
obj.put("loginName", loginName);
obj.put("ipAddress", getLocalHost());
obj.put("integrationKey", integrationKey);
String result = req.postJson(regionUrl, obj.toJSONString());
logger.info("login:" + result);
JSONObject obj_result = JSON.parseObject(result);
token = obj_result.get("data").toString();
return token;
} /**
* 检查token是否有效
*
* @return boolean
*/
private static boolean checkToken() {
String url = baseUrl + "/api/services/Org/CheckUserTokenValidity?token=" + token;
HttpClientRequest req = HttpClientRequest.newInstance();
String result = req.get(url);
logger.info("checkToken:" + result);
JSONObject obj_result = JSON.parseObject(result);
boolean isContain = obj_result.containsKey("data");
if (!isContain)
return false;
return obj_result.getBoolean("data");
} /**
* 下载
*
* @param fileId 文件id
* @return 响应
* @throws IOException 异常
*/
public static HttpResponse download(String fileId) throws IOException, InterruptedException {
String token = CheckAndLogin(); String url = baseUrl + "/DownLoad/DownLoadCheck?token=" + token + "&fileIds=" + fileId;
HttpClientRequest req = HttpClientRequest.newInstance();
String result = req.get(url);
logger.info("downLoadCheck: {}", result); JSONObject obj_result = JSON.parseObject(result);
String blockurl;
/*除了0都是有问题*/
if (obj_result.getInteger("nResult") == 0) {
blockurl = baseUrl + "/downLoad/index?regionHash=" + obj_result.get("RegionHash") + "&async=false&token=" + token;
} else {
throw new DefException(obj_result.getString("msg"));
} // 获得Http客户端(可以理解为:你得先有一个浏览器;注意:实际上HttpClient与浏览器是不一样的)
CloseableHttpClient httpClient = HttpClientBuilder.create().build();
// 创建Get请求
HttpGet httpGet = new HttpGet(blockurl); // 响应模型
// 由客户端执行(发送)Get请求
CloseableHttpResponse response1 = httpClient.execute(httpGet);
logger.info("downLoad: {}", blockurl);
return response1;
} /**
* 上传文件,这个和upload2是用的两种不同的方式来上传文件
*
* @param file 文件
* @return 返回上传的文件的相关的信息
* @throws IOException 异常
*/
public static String upload(MultipartFile file, String newfilenameString) throws IOException, InterruptedException {
String token = CheckAndLogin();
byte[] b = file.getBytes();
int filesize = b.length; String UploadId = UUID.randomUUID().toString();
JSONObject obj = new JSONObject();
obj.put("UploadId", UploadId);
/*15是个人文件夹的ParentId ,1044是crm文件管理*/
obj.put("ParentId", folderId);
obj.put("fileSize", filesize);
obj.put("name", newfilenameString);
obj.put("Token", token);
/*第一次请求*/
HttpClientRequest req = HttpClientRequest.newInstance();
String url = baseUrl + "/api/services/Transfer/StartUploadFile";
String json = req.postJson(url, obj.toString());
logger.info("StartUploadFile:" + json); JSONObject obj_result = JSON.parseObject(json);
String blockurl;
/*除了0都是有问题*/
if (obj_result.getInteger("Result") == 0) {
if (obj_result.getInteger("RegionId") == 1) {
blockurl = baseUrl + "/api/services/Transfer/UploadFileBlock";
} else {
blockurl = obj_result.getString("RegionUrl");
}
} else {
throw new DefException(obj_result.getString("Message"));
} int buffer = 819216;
int smallData = filesize % buffer;
int blockNum = filesize / buffer == 0 ? 1 : filesize / buffer;
try (InputStream bais = file.getInputStream()) {
for (int i = 0; i <= blockNum; i++) {
byte[] buffers = new byte[buffer]; //noinspection ResultOfMethodCallIgnored
bais.read(buffers);
String base64 = Base64.getEncoder().encodeToString(buffers);
JSONObject obj_block = new JSONObject();
obj_block.put("Token", token);
obj_block.put("dataSize", (i == blockNum ? smallData : buffer));
obj_block.put("FilePos", i * buffer);
obj_block.put("RegionHash", obj_result.getString("RegionHash"));
obj_block.put("BlockData", base64);
obj_block.put("uploadId", UploadId);
/*传输数据*/
String result_block = req.postJson(blockurl, obj_block.toJSONString());
logger.info("UploadFileBlock:" + result_block);
}
} catch (Exception e) {
throw new DefException("传输文件错误。");
}
String endurl = baseUrl + "/api/services/Transfer/EndUploadFile";
JSONObject obj_end = new JSONObject();
obj_end.put("Token", token);
obj_end.put("uploadId", UploadId);
obj_end.put("RegionHash", obj_result.getString("RegionHash"));
/*结束传输请求*/
String end_block = req.postJson(endurl, obj_end.toJSONString());
logger.info(end_block);
return obj_result.getString("FileId");
} /**
* 上传文件
*
* @param file 文件
* @param newfilenameString 新名字
* @return 返回上传的文件id
* @throws IOException 异常
*/
public static String upload2(MultipartFile file, String newfilenameString) throws IOException, InterruptedException {
String token = CheckAndLogin();
byte[] b = file.getBytes();
int filesize = b.length; String uploadId = UUID.randomUUID().toString();
String url = baseUrl + "/WebCore"; CloseableHttpClient httpclient = HttpClients.createDefault();
CloseableHttpResponse response;
HttpPost post = new HttpPost(url);
HttpEntity formEntity; List<NameValuePair> formParams = new ArrayList<>();
formParams.add(new BasicNameValuePair("fileSize", "" + filesize));
formParams.add(new BasicNameValuePair("folderId", folderId));
formParams.add(new BasicNameValuePair("fileName", newfilenameString));
formParams.add(new BasicNameValuePair("module", "RegionDocOperationApi"));
formParams.add(new BasicNameValuePair("fun", "CheckAndCreateDocInfo"));
formParams.add(new BasicNameValuePair("type", file.getContentType()));
formParams.add(new BasicNameValuePair("size", "" + file.getSize()));
formParams.add(new BasicNameValuePair("attachType", "0"));
formParams.add(new BasicNameValuePair("fileModel", "UPLOAD"));
formParams.add(new BasicNameValuePair("token", token)); formEntity = new UrlEncodedFormEntity(formParams, "UTF-8");
post.setEntity(formEntity);
response = httpclient.execute(post);
HttpEntity entity = response.getEntity();
JSONObject str = JSON.parseObject(EntityUtils.toString(entity, "UTF-8")); logger.info(str.toJSONString());
if (str.getIntValue("result") != 0)
throw new DefException(str.getString("reason")); String blockurl = baseUrl + "/document/upload?token=" + token; /*注意:chunkSize不可以过大,否则会导致文件损坏*/
int chunkSize = 1024 * 1024 * 3;
int chunks = filesize / chunkSize == 0 ? 1 : filesize / chunkSize + 1;
int smallData = filesize % chunkSize;
try (InputStream ins = file.getInputStream()) {
for (int i = 0; i < chunks; i++) {
MultipartEntityBuilder builder = MultipartEntityBuilder.create();
builder.addTextBody("id", uploadId);
builder.addTextBody("name", newfilenameString);
builder.addTextBody("type", file.getContentType());
builder.addTextBody("lastModifiedDate", new Date().toString());
builder.addTextBody("size", "" + file.getSize());
builder.addTextBody("chunks", "" + chunks);
builder.addTextBody("chunk", "" + i);
builder.addTextBody("fileName", newfilenameString);
builder.addTextBody("blockSize", "" + (i + 1 == chunks ? smallData : chunkSize));
builder.addTextBody("chunkSize", "" + chunkSize);
builder.addTextBody("uploadId", uploadId);
builder.addTextBody("regionId", str.getJSONObject("data").getString("RegionId"));
builder.addTextBody("regionHash", str.getJSONObject("data").getString("RegionHash")); byte[] bytes = new byte[chunkSize];//每次读取文件的大小为5MB
//noinspection ResultOfMethodCallIgnored
ins.read(bytes); File tempfile = new File(String.valueOf(0));
FileOutputStream temfileStream = new FileOutputStream(tempfile);
temfileStream.write(bytes);
builder.addBinaryBody("file", tempfile);
// 把文件加到HTTP的post请求中
// builder.addBinaryBody("file", bytes, ContentType.APPLICATION_OCTET_STREAM, file.getOriginalFilename());
post.setURI(URI.create(blockurl));
HttpEntity multipart = builder.build();
post.setEntity(multipart);
temfileStream.close();
response = httpclient.execute(post);
HttpEntity responseEntity = response.getEntity();
String sResponse = EntityUtils.toString(responseEntity, "UTF-8");
logger.info(sResponse);
}
}
return str.getJSONObject("data").getString("FileId");
} /**
* @return 预览的url
*/
public static String getPreViewUrl() throws InterruptedException {
String token = FileUploadAndDownloadUtil.CheckAndLogin();
return baseUrl + "/jump.html?token=" + token + "&returnUrl=http://192.168.20.194/preview.html?fileid=1082";
} @Value("${EDOC2_BASE_URL}")
public void setBaseUrl(String baseUrl) {
FileUploadAndDownloadUtil.baseUrl = baseUrl;
} @Value("${INTEGRATIONKEY}")
public void setIntegrationKey(String integrationKey) {
FileUploadAndDownloadUtil.integrationKey = integrationKey;
} @Value("${EDOC2_LOGIN_NAME}")
public void setLoginName(String loginName) {
FileUploadAndDownloadUtil.loginName = loginName;
} @Value("${EDOC2_FOLDER_ID}")
public void setFolderId(String folderId) {
FileUploadAndDownloadUtil.folderId = folderId;
} /**
* 获取本地的ip
*
* @return ip
*/
private static String getLocalHost() {
try {
return InetAddress.getLocalHost().getHostAddress();
} catch (UnknownHostException e) {
e.printStackTrace();
throw new DefException("找不到HostAddress。");
}
}
}
用edoc2实现上传和下载的更多相关文章
- win7下利用ftp实现华为路由器的上传和下载
win7下利用ftp实现华为路由器的上传和下载 1. Win7下ftp的安装和配置 (1)开始->控制面板->程序->程序和功能->打开或关闭Windows功能 (2)在Wi ...
- Java实现FTP文件与文件夹的上传和下载
Java实现FTP文件与文件夹的上传和下载 FTP 是File Transfer Protocol(文件传输协议)的英文简称,而中文简称为"文传协议".用于Internet上的控制 ...
- java web学习总结(二十四) -------------------Servlet文件上传和下载的实现
在Web应用系统开发中,文件上传和下载功能是非常常用的功能,今天来讲一下JavaWeb中的文件上传和下载功能的实现. 对于文件上传,浏览器在上传的过程中是将文件以流的形式提交到服务器端的,如果直接使用 ...
- Struts2入门(七)——Struts2的文件上传和下载
一.前言 在之前的随笔之中,我们已经了解Java通过上传组件来实现上传和下载,这次我们来了解Struts2的上传和下载. 注意:文件上传时,我们需要将表单提交方式设置为"POST" ...
- php实现文件上传与下载(上)
php实现文件的上传与下载是一个挺基本的功能,一般网站多多少少都会有这样的需求在内,当然不是说所有的文件都可以被上传,那这网络就太没有安全性可言了.因为接触php时间不长,今天写练练手,随笔也就是公开 ...
- SecureCRT上传和下载文件
SecureCRT上传和下载文件(下载默认目录) SecureCR 下的文件传输协议有ASCII .Xmodem .Ymodem .Zmodem ASCII:这是最快的传输协议,但只能传送文本文件. ...
- SpringMVC文件上传和下载
上传与下载 1文件上传 1.1加入jar包 文件上传需要依赖的jar包 1.2配置部件解析器 解析二进制流数据. <?xml version="1.0" encoding=& ...
- 通读AFN②--AFN的上传和下载功能分析、SessionTask及相应的session代理方法的使用细节
这一部分主要研究AFN的上传和下载功能,中间涉及到各种NSURLSessionTask的一些创建的解析和HTTPSessionManager对RESTful风格的web应用的支持,同时会穿插一点NSU ...
- 每天一个linux命令(26):用SecureCRT来上传和下载
用SSH管理linux服务器时经常需要远程与本地之间交互文件.而直接用SecureCRT自带的上传下载功能无疑是最方便的,SecureCRT下的文件传输协议有ASCII.Xmodem.Zmodem.文 ...
随机推荐
- Http请求Response Code含义
http状态返回代码 1xx(临时响应) 表示临时响应并需要请求者继续执行操作的状态代码.100 (继续) 请求者应当继续提出请求. 服务器返回此代码表示已收到请求的第一部分,正在等待其余部分.101 ...
- 模拟客户端向服务器发起请求(从Fiddler抓包到Jmeter接口测试)
一.安装Fiddler 二.配置 在菜单栏Tools->Fiddler Options->Connections,勾选Allow remote computers to connect,默 ...
- UVA - 11996 Jewel Magic (Treap+二分哈希)
维护一个01序列,一共四种操作: 1.插入一个数 2.删除一个数 3.反转一个区间 4.查询两个后缀的LCP 用Splay或者Treap都可以做,维护哈希值,二分求LCP即可. 注意反转序列的时候序列 ...
- hiho #1038 : 01背包 (dp)
#1038 : 01背包 时间限制:20000ms 单点时限:1000ms 内存限制:256MB 描述 且说上一周的故事里,小Hi和小Ho费劲心思终于拿到了茫茫多的奖券!而现在,终于到了小Ho领取奖励 ...
- struts2没有打印日志原因和No result defined for action XXXAction and result input
在项目中调用一个action的方法的时候发生了一个错误,但是在catalina.out和配置的log4j都没有打印异常,后来在执行的action中加了logger.error("XXXXX& ...
- centos7排查swap占用过高
使用free -h 查看发现服务器在可用内存还有91G的情况下,使用Swap分区空间 查看具体是哪进程在占用Swap分区 ###for i in $( cd /proc;ls |grep " ...
- layer 相关网址
layer 1.8.5 官方网址: http://layer.layui.com/1.8.5/ API网址: http://layer.layui.com/1.8.5/api.html
- C# 两个进程之间通讯(管道通信 )
#region 客户端 NamedPipeClientStream pipeClient = new NamedPipeClientStream("localh ...
- 字符串之format整理
format 用法 本文根据官方文档及自己理解整理,只整理出自己可以理解的部分,h因个人水平有限,难免有所错误和纰漏,欢迎批评指正. 格式{ [field_name] ["!" c ...
- HTML DOM的学习
请看下面的 HTML 片段: <html> <head> <title>DOM 教程</title> </head> <body> ...