O2OA使用手册
第1章 功能简介及概述
第6章 平台部署与配置
  • 6.1 O2OA(翱途)开发平台如何基于nginx上下文分发的方式快速集群部署
  • 6.2 系统架构-平台集群化部署之基于Nginx端口分发机制实现集群部署
  • 6.3 系统架构-基于nginx快速集群部署-上下文分发
  • 6.4 安装部署-在Windows系统中部署O2OA开发平台
  • 6.5 安装部署-在Linux系统中部署O2OA开发平台
  • 6.6 安装部署-在宝塔/PHPStudy中部署O2OA开发平台
  • 6.7 安装部署-O2OA开发平台之HTTP端口规划
  • 6.8 安装部署-平台服务器版本升级操作说明
  • 6.9 安装部署-私有化部署服务器架构推荐
  • 6.10 安装部署-O2OA开发平台集群部署配置及操作说明
  • 6.11 安装部署-在线部署自定义应用的WAR包和JAR包
  • 6.12 服务器配置与管理-​O2OA主要配置文件说明
  • 6.13 服务器配置与管理-服务器端口冲突和端口修改
  • 6.14 服务器配置与管理-如何修改服务器内存占用率?
  • 6.15 服务器配置与管理-如何访问和操作H2内置数据库
  • 6.16 服务器配置与管理-​如何在O2OA中使用MySQL数据库?
  • 6.17 服务器配置与管理-如何修改平台支持的数据库驱动包
  • 6.18 服务器配置与管理-O2OA使用openGauss(华为高斯数据库)配置
  • 6.19 服务器配置与管理-O2OA开发平台平台数据库配置信息样例
  • 6.20 服务器配置与管理-配置O2OA服务器连接O2云
  • 6.21 服务器配置与管理-O2OA实现服务器随操作系统自动启动
  • 6.22 服务器配置与管理-文件存储服务器配置
  • 6.23 服务器配置与管理-工作日节假日配置
  • 6.24 服务器配置与管理-为平台增加全文检索功能
  • 6.25 服务器配置与管理-消息提醒配置说明
  • 6.26 服务器配置与管理-自定义消息提醒
  • 6.27 服务器配置与管理-定制消息通知的内容
  • 6.28 服务器配置与管理-消息通知过滤
  • 6.29 服务器配置与管理-为待办创建配置邮件通知
  • 6.30 服务器配置与管理-待办待阅数据的查询操作和管理
  • 6.31 服务器配置与管理-​自动执行平台数据的备份与恢复
  • 6.32 服务器配置与管理-数据导出导入与系统数据备份
  • 6.33 ​服务器配置与管理-定期自动执行数据备份与恢复
  • 6.34 系统安全-O2OA作为认证中心实现基于OAUTH2单点认证
  • 6.35 系统安全-O2OA基于Nginx的SSL跳转、转发配置
  • 6.36 系统安全-访问日志相关配置
  • 6.37 系统安全-审计日志相关配置
  • 6.38 系统安全-平台日志文件说明
  • 6.39 系统安全-O2OA日志输出设置log4j2.xml
  • 6.40 系统安全-用户密码初始化规则的设定
  • 6.41 系统安全-启用HTTPS(百度云版)
  • 6.42 系统安全-启用HTTPS(腾讯云版)
  • 6.43 系统安全-自签名SSL证书验证HTTPS功能
  • 6.44 系统安全-登录密码RSA加密
  • 6.45 系统安全-用户登录IP限制
  • 6.46 系统安全-在用户登录过程中启用图形验证码
  • 6.47 系统安全-平台部署之使用非root用户运行服务
  • 6.48 系统安全-O2Server启用国密加密设置
  • 6.49 系统安全-日志应用使用说明
  • 6.50 系统安全-用户重置密码操作
  • 6.51 系统安全-超级管理员(xadmin)密码修改
  • 6.52 系统安全-使用Web端运行服务器管理命令
  • 6.53 系统安全-o2server无法正常显示验证码解决办法
  • 6.54 O2OA(翱途)开发平台前端安全配置建议(一)
  • 第16章 开发知识及常见问题
  • 16.1 如何替换登录页面二维码中默认的logo图标
  • 16.2 O2OA(翱途)流程引擎中如何修改,定制流程的流转记录
  • 16.3 mysql数据库备份
  • 16.4 domain不正确的时候如何强制设置成正确的
  • 16.5 配置文件中使用密文存储密码
  • 16.6 常见问题-连接MySQL出现 Public Key Retrieval is not allowed 的错误
  • 16.7 常见问题-查看表结构
  • 16.8 常见问题-7.2及以上版本开启web代理后请求中没有正确使用web端口问题解决方式
  • 16.9 linux环境libreoffice安装及使用
  • 16.10 在O2OA中使用网络会议(二):Openmeetings与O2OA认证配置
  • 16.11 在O2OA中使用网络会议(一):Openmeetings-5.1.0亲手安装整理 Step-By-Step
  • 16.12 藕粉社区问答系列1
  • 16.13 藕粉社区问答系列2
  • 16.14 藕粉社区问答系列3
  • 16.15 快速入门-平台相关资料汇总
  • 16.16 快速入门-服务器总体介绍汇总
  • 16.17 快速入门-流程表单载入基础数据
  • 16.18 快速入门-常用表单脚本样例汇总
  • 16.19 快速入门-自定义表数据分页样例
  • 16.20 OEM白标-如何修改平台中的Logo图标和文字
  • 16.21 云服务器-阿里云ECS服务器的端口启用
  • 16.22 开发知识-React篇:在O2OA平台框架中使用React
  • 16.23 开发知识-React篇:在O2OA门户页面中使用React
  • 16.24 开发知识-Vue篇:在Vue应用中集成O2OA
  • 16.25 开发知识-Vue篇:使用Vue-CLI开发O2应用
  • 16.26 开发知识-Vue篇:在O2门户页面中使用Vue
  • 16.27 平台中使用Druid数据库连接及监控
  • 16.28 开发知识-在PAAS平台上部署O2OA开发平台
  • 16.29 开发知识-如何使用Tomcat架设webdav服务器
  • 16.30 开发知识-单个端口模式的Nginx和系统配置
  • 16.31 开发知识-Linux非root用户如何使用80端口启动O2OA
  • 16.32 开发知识-O2OA平台启用Eruda进行移动端调试
  • 16.33 开发知识-神通数据库安装
  • 16.34 开发知识-人大金仓数据安装
  • 16.35 开发知识-中标麒麟安装达梦数据库(DM8)
  • 16.36 开发知识-中标麒麟安装人大金仓详细步骤
  • 16.37 开发知识-使用VNC连接中标麒麟V7操作系统
  • 16.38 开发知识-鲲鹏(ARM)麒麟操作系统如何替换yum源?
  • 16.39 开发知识-数据优化知识点
  • 16.40 水印安全-附件水印|加密|文档格式转换图片|PDF
  • 16.41 消息队列-配置activeMQ、kafka消息队列
  • 16.42 常见问题-数据导出或者导入时发生OOM异常
  • 16.43 常见问题-如何让用户在首次登录时,必须对初始密码进行修改
  • 16.44 常见问题-如何在模块部署中控制模块的访问权限
  • 16.45 常见问题-如何在平台中开发Ftp文件上传文件的服务?
  • 16.46 常见问题-如何使用服务管理调用WebService
  • 16.47 常见问题-如何使用脚本调用外部服务
  • 16.48 常见问题-如何使用脚本控制流程自动流转
  • 16.49 常见问题-如何通过脚本调用系统内服务
  • 16.50 常见问题-接口代码疑惑解答汇总
  • 16.51 常见问题:Maven编译o2server错误: Java Heap Space
  • 16.52 常见问题-集群配置后启动报错:NullPointerException
  • 16.53 常见问题-服务器错误:can not decrypt token
  • 16.54 常见问题-IOS移动办公无法收到验证码
  • 16.55 常见问题-服务器和日志时间相差12小时的问题
  • 16.56 常见问题-为什么127.0.0.1可以访问但其他IP无法访问
  • 16.57 藕粉社区问答系列4
  • 16.58 开发知识-React篇:在React应用中集成O2OA

  • 服务集成-通过接口从第三方应用系统启动流程

    时间:2022-08-03   

    O2OA允许用户自行修改源码或者增加源码来扩展系统服务,也可以包装功能更强的业务服务。本文主要介绍如何在Java代码中通过接口从第三方应用系统启动O2OA中的业务流程(通过第三方调用启动流程)

    总体思络: 先用户单点获取token(因为创建流程、上传附件接口需要身份认证),接着创建流程,然后上传附件到流程实例。

    一、完整样例代码

    代码如下:

    import java.io.BufferedReader;
    import java.io.ByteArrayOutputStream;
    import java.io.File;
    import java.io.FileOutputStream;
    import java.io.IOException;
    import java.io.InputStream;
    import java.io.InputStreamReader;
    import java.io.PrintWriter;
    import java.net.URL;
    import java.net.URLConnection;
    import java.util.ArrayList;
    import java.util.Date;
    import java.util.HashMap;
    import java.util.LinkedHashMap;
    import java.util.List;
    import java.util.Map;
    import java.util.Set;
    import java.util.concurrent.ExecutorService;
    import java.util.concurrent.Executors;
    import org.apache.commons.io.IOUtils;
    import org.apache.http.HttpEntity;
    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.ContentType;
    import org.apache.http.entity.StringEntity;
    import org.apache.http.entity.mime.MultipartEntityBuilder;
    import org.apache.http.entity.mime.content.FileBody;
    import org.apache.http.entity.mime.content.StringBody;
    import org.apache.http.impl.client.CloseableHttpClient;
    import org.apache.http.impl.client.HttpClients;
    import org.apache.http.message.BasicNameValuePair;
    import org.apache.http.util.EntityUtils;
    import com.google.gson.JsonArray;
    import com.google.gson.JsonObject;
    import com.google.gson.JsonParser;
    
    public class HttpClientUtil {
    public static final int THREAD_POOL_SIZE = 5;
    public interface HttpClientDownLoadProgress {
    	public void onProgress(int progress);
    }
    private static HttpClientUtil httpClientDownload;
    private ExecutorService downloadExcutorService;
    private HttpClientUtil() {
    	downloadExcutorService = Executors.newFixedThreadPool(THREAD_POOL_SIZE);
    }
    public static HttpClientUtil getInstance() {
    	if (httpClientDownload == null) {
    		httpClientDownload = new HttpClientUtil();
    	}
    	return httpClientDownload;
    }
    
    /**
     * @param url
     * @param filePath
     */
    public void download(final String url, final String filePath) {
    	downloadExcutorService.execute(new Runnable() {
    		@Override
    		public void run() {
    			httpDownloadFile(url, filePath, null, null);
    		}
    	});
    }
    
    /**
     *
     * @param url
     * @param filePath
     * @param progress
     */
    public void download(final String url, final String filePath, final HttpClientDownLoadProgress progress) {
    	downloadExcutorService.execute(new Runnable() {
    
    		@Override
    		public void run() {
    			httpDownloadFile(url, filePath, progress, null);
    		}
    	});
    }
    
    /**
     * @param url
     * @param filePath
     */
    private void httpDownloadFile(String url, String filePath, HttpClientDownLoadProgress progress,
    		Map<String, String> headMap) {
    	CloseableHttpClient httpclient = HttpClients.createDefault();
    	try {
    		HttpGet httpGet = new HttpGet(url);
    		setGetHead(httpGet, headMap);
    		CloseableHttpResponse response1 = httpclient.execute(httpGet);
    		try {
    			System.out.println(response1.getStatusLine());
    			HttpEntity httpEntity = response1.getEntity();
    			long contentLength = httpEntity.getContentLength();
    			InputStream is = httpEntity.getContent();
    
    			ByteArrayOutputStream output = new ByteArrayOutputStream();
    			byte[] buffer = new byte[4096];
    			int r = 0;
    			long totalRead = 0;
    			while ((r = is.read(buffer)) > 0) {
    				output.write(buffer, 0, r);
    				totalRead += r;
    				if (progress != null) {
    					progress.onProgress((int) (totalRead * 100 / contentLength));
    				}
    			}
    			FileOutputStream fos = new FileOutputStream(filePath);
    			output.writeTo(fos);
    			output.flush();
    			output.close();
    			fos.close();
    			EntityUtils.consume(httpEntity);
    		} finally {
    			response1.close();
    		}
    	} catch (Exception e) {
    		e.printStackTrace();
    	} finally {
    		try {
    			httpclient.close();
    		} catch (IOException e) {
    			e.printStackTrace();
    		}
    	}
    }
    
    /**
     * @param url
     * @return
     */
    public String httpGet(String url) {
    	return httpGet(url, null);
    }
    
    /**
     * http get
     *
     * @param url
     * @return
     */
    public String httpGet(String url, Map<String, String> headMap) {
    	String responseContent = null;
    	CloseableHttpClient httpclient = HttpClients.createDefault();
    	try {
    		HttpGet httpGet = new HttpGet(url);
    		CloseableHttpResponse response1 = httpclient.execute(httpGet);
    		setGetHead(httpGet, headMap);
    		try {
    			HttpEntity entity = response1.getEntity();
    			responseContent = getRespString(entity);
    			EntityUtils.consume(entity);
    		} finally {
    			response1.close();
    		}
    	} catch (Exception e) {
    		e.printStackTrace();
    	} finally {
    		try {
    			httpclient.close();
    		} catch (IOException e) {
    			e.printStackTrace();
    		}
    	}
    	return responseContent;
    }
    
    public String httpPost(String url, Map<String, String> paramsMap) {
    	return httpPost(url, paramsMap, null);
    }
    
    /**
     * @param url
     * @param paramsMap
     * @return
     */
    public String httpPost(String url, Map<String, String> paramsMap, Map<String, String> headMap) {
    	String responseContent = null;
    	CloseableHttpClient httpclient = HttpClients.createDefault();
    	try {
    		HttpPost httpPost = new HttpPost(url);
    		setPostHead(httpPost, headMap);
    		setPostParams(httpPost, paramsMap);
    		CloseableHttpResponse response = httpclient.execute(httpPost);
    		try {
    			HttpEntity entity = response.getEntity();
    			responseContent = getRespString(entity);
    			EntityUtils.consume(entity);
    		} finally {
    			response.close();
    		}
    	} catch (Exception e) {
    		e.printStackTrace();
    	} finally {
    		try {
    			httpclient.close();
    		} catch (IOException e) {
    			e.printStackTrace();
    		}
    	}
    	return responseContent;
    }
    
    /**
     * @param httpPost
     * @param headMap
     */
    private void setPostHead(HttpPost httpPost, Map<String, String> headMap) {
    	if (headMap != null && headMap.size() > 0) {
    		Set<String> keySet = headMap.keySet();
    		for (String key : keySet) {
    			httpPost.addHeader(key, headMap.get(key));
    		}
    	}
    }
    
    /**
     * 
     *
     * @param httpGet
     * @param headMap
     */
    private void setGetHead(HttpGet httpGet, Map<String, String> headMap) {
    	if (headMap != null && headMap.size() > 0) {
    		Set<String> keySet = headMap.keySet();
    		for (String key : keySet) {
    			httpGet.addHeader(key, headMap.get(key));
    		}
    	}
    }
    
    /**
     *
     *
     * @param serverUrl       ַ
     * @param localFilePath
     * 
     * @param serverFieldName
     * @param params
     * @return
     * @throws Exception
     */
    public String uploadFileImpl(String serverUrl, String localFilePath, String serverFieldName,
    		Map<String, String> params, Map<String, String> paramshead) throws Exception {
    	String respStr = null;
    	CloseableHttpClient httpclient = HttpClients.createDefault();
    	try {
    		HttpPost httppost = new HttpPost(serverUrl);
    
    		setPostHead(httppost, paramshead);
    
    		FileBody binFileBody = new FileBody(new File(localFilePath));
    
    		MultipartEntityBuilder multipartEntityBuilder = MultipartEntityBuilder.create();
    
    		multipartEntityBuilder.addPart(serverFieldName, binFileBody);
    
    		setUploadParams(multipartEntityBuilder, params);
    
    		HttpEntity reqEntity = multipartEntityBuilder.build();
    		httppost.setEntity(reqEntity);
    
    		CloseableHttpResponse response = httpclient.execute(httppost);
    		try {
    			HttpEntity resEntity = response.getEntity();
    			respStr = getRespString(resEntity);
    			EntityUtils.consume(resEntity);
    		} finally {
    			response.close();
    		}
    	} finally {
    		httpclient.close();
    	}
    	return respStr;
    }
    
    /**
     * @param multipartEntityBuilder
     * @param params
     */
    private void setUploadParams(MultipartEntityBuilder multipartEntityBuilder, Map<String, String> params) {
    	if (params != null && params.size() > 0) {
    		Set<String> keys = params.keySet();
    		for (String key : keys) {
    			multipartEntityBuilder.addPart(key, new StringBody(params.get(key), ContentType.APPLICATION_JSON));
    
    		}
    	}
    }
    
    /**
     * String
     *
     * @param entity
     * @return
     * @throws Exception
     */
    private String getRespString(HttpEntity entity) throws Exception {
    	if (entity == null) {
    		return null;
    	}
    	InputStream is = entity.getContent();
    	StringBuffer strBuf = new StringBuffer();
    	byte[] buffer = new byte[4096];
    	int r = 0;
    	while ((r = is.read(buffer)) > 0) {
    		strBuf.append(new String(buffer, 0, r, "UTF-8"));
    	}
    	return strBuf.toString();
    }
    
    /**
     * @param httpPost
     * @param paramsMap
     * @throws Exception
     */
    private void setPostParams(HttpPost httpPost, Map<String, String> paramsMap) throws Exception {
    	if (paramsMap != null && paramsMap.size() > 0) {
    		List<NameValuePair> nvps = new ArrayList<NameValuePair>();
    		Set<String> keySet = paramsMap.keySet();
    		for (String key : keySet) {
    			nvps.add(new BasicNameValuePair(key, paramsMap.get(key)));
    		}
    		httpPost.setEntity(new UrlEncodedFormEntity(nvps));
    	}
    }
    
    public static String sendPost(String url, String token, String paramsStr) throws IOException, Exception {
    
    	// POST请求
    	CloseableHttpClient httpclient = HttpClients.createDefault();
    
    	// 请求参数
    	StringEntity postingString = new StringEntity(paramsStr, "utf-8");
    	HttpPost httpPost = new HttpPost(url);
    	httpPost.setEntity(postingString);
    
    	// 请求头设置
    	httpPost.addHeader("Cookie", "x-token=" + token);
    	httpPost.addHeader("accept", "*/*");
    	httpPost.addHeader("connection", "Keep-Alive");
    	httpPost.addHeader("Content-Type", "application/json; charset=utf-8");
    	httpPost.addHeader("user-agent", "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1;SV1)");
    
    	// 执行请求
    	CloseableHttpResponse execute = httpclient.execute(httpPost);
    
    	// 处理返回结果
    	String restStr = IOUtils.toString(execute.getEntity().getContent(), "utf-8");
    	return restStr;
    }
    
    public static String sendPost(String url, String param) {
    	PrintWriter out = null;
    	BufferedReader in = null;
    	String result = "";
    	try {
    		URL realUrl = new URL(url);
    		URLConnection conn = realUrl.openConnection();
    		conn.setRequestProperty("accept", "*/*");
    		conn.setRequestProperty("connection", "Keep-Alive");
    		conn.setRequestProperty("Content-Type", "application/json; charset=utf-8");
    		conn.setRequestProperty("user-agent", "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1;SV1)");
    		conn.setDoOutput(true);
    		conn.setDoInput(true);
    
    		out = new PrintWriter(conn.getOutputStream());
    		out.print(param);
    		out.flush();
    		in = new BufferedReader(new InputStreamReader(conn.getInputStream()));
    		String line;
    		while ((line = in.readLine()) != null) {
    			result += line;
    		}
    	} catch (Exception e) {
    		System.out.println(" POST" + e);
    		e.printStackTrace();
    	} finally {
    		try {
    			if (out != null) {
    				out.close();
    			}
    			if (in != null) {
    				in.close();
    			}
    		} catch (IOException ex) {
    			ex.printStackTrace();
    		}
    	}
    	return result;
    }
    
    public static void main(String[] args) throws IOException, Exception {
    	String token = "";
    	// 第一步:单点登入
    	String path = "http://127.0.0.1:20020/x_organization_assemble_authentication/jaxrs/sso"; // 单点路径
    	long time = new Date().getTime(); // 当前时间
    	String login_uid = "kfry"; // 用户id
    	String sso_key = "12345678"; // 加密密码
    	String xtoken = null;
    	String client = "sso"; // sso配置名称
    	try {
    		xtoken = Crypto.encrypt(login_uid + "#" + time, sso_key);
    		System.out.println(xtoken);
    	} catch (Exception e1) {
    		e1.printStackTrace();
    	}
    
    	String string = "{"token": " + xtoken + ", "client": " + client + "}";
    	String str = HttpClientUtil.getInstance().sendPost(path, string);
    	JsonParser parser = new JsonParser();
    	JsonObject object = null;
    	object = (JsonObject) parser.parse(str);
    	JsonObject value = object.get("data").getAsJsonObject();
    	token = value.get("token").getAsString();
    
    	// 第二步:创建流程
    	String processId = "e4c77038-2964-498f-9d37-1635e26639eb";// 流程id
    	path = "http://127.0.0.1:20020/x_processplatform_assemble_surface/jaxrs/work/process/"+processId;// 流程创建路径
    	String datagrid = "{"data": [{" + "      "
    			+ "   "col1": { "textfield1": "1" },"
    			+ "         "col2": { "textfield2": "2" }," 
    			+ "         "col3": { "textfield3": "3" },"
    			+ "         "col4": { "textfield4": "4" },"
    			+ "         "col5": { "textfield5": "5" }"
    			+ "     }," + "     {"
    			+ "         "col1": { "textfield1": "11" },"
    			+ "         "col2": { "textfield2": "12" }," 
    			+ "         "col3": { "textfield3": "13" },"
    			+ "         "col4": { "textfield4": "14" }," 
    			+ "         "col5": { "textfield5": "15" }"
    			+ "     }]}"; // 数据网格数据
    
    	JsonParser parser1 = new JsonParser();
    	JsonObject jsonObj = parser1.parse(datagrid).getAsJsonObject();
    
    	JsonObject jsonObject = new JsonObject();
    	jsonObject.addProperty("latest", false);
    	jsonObject.addProperty("title", "演示系统grid测试(2021-02-22)");// 标题
    	jsonObject.addProperty("identity", "开发人员@932ca9a4-4c80-4a29-9e44-aed85afe21d3@I"); // 创建者身份
    
    	JsonObject jsonObjectdata = new JsonObject();
    	jsonObjectdata.addProperty("subject", "演示系统grid测试2021-02-22"); // 标题
    	jsonObjectdata.addProperty("calendar", "2020-04-13 12:00:00");// 表单 上的字段名“calendar”
    	jsonObjectdata.addProperty("explain", "演示系统grid测试"); // 表单 上的字段名“explain”
    	jsonObjectdata.add("datagrid", jsonObj); // 表单上的数据网格
    
    	jsonObject.add("data", jsonObjectdata);
    	// 创建流程
    	String strflow = HttpClientUtil.getInstance().sendPost(path, token, jsonObject.toString());
    	String work = "";
    
    	// 获取返回的workid
    	JsonParser parser2 = new JsonParser();
    	JsonObject object2 = null;
    	object2 = (JsonObject) parser2.parse(strflow);
    	JsonArray value2 = object2.getAsJsonArray("data");
    	object2 = value2.get(0).getAsJsonObject();
    	work = object2.get("work").getAsString();
    
    	System.out.println("work=" + work);
    
    	// 上传附件
    	try {
    		Map<String, String> uploadParams = new LinkedHashMap<String, String>();
    		uploadParams.put("fileName", "明天.docx"); // 附件名
    		uploadParams.put("site", "attachment"); // 表单上的附件控件标识
    		uploadParams.put("extraParam", "");
    
    		Map<String, String> headMap = new HashMap<String, String>();
    		headMap.put("Cookie", "x-token=" + token); // 单点token
    		headMap.put("accept", "*/*");
    		headMap.put("connection", "Keep-Alive");
    		headMap.put("user-agent", "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1;SV1)");
    
    		String attUrl = "http://127.0.0.1:20020/x_processplatform_assemble_surface/jaxrs/attachment/upload/work/"
    				+ work;
    		String filePath = "F:Download明天.docx";
    		HttpClientUtil.getInstance().uploadFileImpl(attUrl, filePath, "file", uploadParams, headMap);
    	} catch (Exception e) {
    		e.printStackTrace();
    	}
    }
    }

    二、功能代码介绍

    第一步:单点登入

    一、创建SSO配置,请参考组织管理里中的SSO管理

    二、通过下面代码获取token.

    注意:下面代码中要调整的内容如下:
    “path”:单点路径要根据实际服务器ip调整;

    “login_uid”:单点用户id;

    “sso_key”:加密解密密码;

    “client”:sso配置名称;

           String token = "";
            //第一步:单点登入
            String path = "http://127.0.0.1:20020/x_organization_assemble_authentication/jaxrs/sso"; //单点路径
            long time = new Date().getTime(); //当前时间
            String login_uid = "kfry"; //用户id
            String sso_key = "12345678"; //加密密码
            String xtoken = null;
            String client = "sso"; //sso配置名称
    		try {
    			xtoken = Crypto.encrypt( login_uid + "#" + time, sso_key );
    			System.out.println(xtoken);
    		} catch (Exception e1) {
    			e1.printStackTrace();
    		}
    		
            String string = "{"token": "+xtoken+", "client": " + client + "}";
            String  str =  HttpClientUtil.getInstance().sendPost(path,string);
            JsonParser parser = new JsonParser(); 
            JsonObject object = null; 
            object =(JsonObject) parser.parse(str);
            JsonObject value =object.get("data").getAsJsonObject();
            token= value.get("token").getAsString();


    第二步:创建流程

    一、设置x-token

    注意:下面代码中要调整的内容如下:

    “processId”: 流程id;

    “path”:创建流程路径要根据实际服务器ip调整;

    “title”:标题;

    “identity”:创建者身份;

    subject”:标题;

    ......
    // 第二步:创建流程
    		String processId = "e4c77038-2964-498f-9d37-1635e26639eb";// 流程id
    		path = "http://127.0.0.1:20020/x_processplatform_assemble_surface/jaxrs/work/process/";// 流程创建路径
    		String datagrid = "{"data": [{" + "      "
    				+ "   "col1": { "textfield1": "1" },"
    				+ "         "col2": { "textfield2": "2" }," 
    				+ "         "col3": { "textfield3": "3" },"
    				+ "         "col4": { "textfield4": "4" },"
    				+ "         "col5": { "textfield5": "5" }"
    				+ "     }," + "     {"
    				+ "         "col1": { "textfield1": "11" },"
    				+ "         "col2": { "textfield2": "12" }," 
    				+ "         "col3": { "textfield3": "13" },"
    				+ "         "col4": { "textfield4": "14" }," 
    				+ "         "col5": { "textfield5": "15" }"
    				+ "     }]}"; // 数据网格数据
    
    		JsonParser parser1 = new JsonParser();
    		JsonObject jsonObj = parser1.parse(datagrid).getAsJsonObject();
    
    		JsonObject jsonObject = new JsonObject();
    		jsonObject.addProperty("latest", false);
    		jsonObject.addProperty("title", "演示系统grid测试(2021-02-22)");// 标题
    		jsonObject.addProperty("identity", "开发人员@932ca9a4-4c80-4a29-9e44-aed85afe21d3@I"); // 创建者身份
    
    		JsonObject jsonObjectdata = new JsonObject();
    		jsonObjectdata.addProperty("subject", "演示系统grid测试2021-02-22"); // 标题
    		jsonObjectdata.addProperty("calendar", "2020-04-13 12:00:00");// 表单 上的字段名“calendar”
    		jsonObjectdata.addProperty("explain", "演示系统grid测试"); // 表单 上的字段名“explain”
    		jsonObjectdata.add("datagrid", jsonObj); // 表单上的数据网格
    
    		jsonObject.add("data", jsonObjectdata);
    		// 创建流程
    		String strflow = HttpClientUtil.getInstance().sendPost(path, token, jsonObject.toString());
    		String work = "";
    
    		// 获取返回的workid
    		JsonParser parser2 = new JsonParser();
    		JsonObject object2 = null;
    		object2 = (JsonObject) parser2.parse(strflow);
    		JsonArray value2 = object2.getAsJsonArray("data");
    		object2 = value2.get(0).getAsJsonObject();
    		work = object2.get("work").getAsString();
    ......


    第三步:上传附件

    一、设置x-token

    二、设置workid

    注意:下面代码中要调整的内容如下:

    “fileName”:附件名

    “site”:表单上的附件控件标识

    filePath”:附件路径

    “attUrl”:附件接口要根据实际服务器ip调整

    	// 上传附件
    		try {
    			Map<String, String> uploadParams = new LinkedHashMap<String, String>();
    			uploadParams.put("fileName", "明天.docx"); // 附件名
    			uploadParams.put("site", "attachment"); // 表单上的附件控件标识
    			uploadParams.put("extraParam", "");
    
    			Map<String, String> headMap = new HashMap<String, String>();
    			headMap.put("Cookie", "x-token=" + token); // 单点token
    			headMap.put("accept", "*/*");
    			headMap.put("connection", "Keep-Alive");
    			headMap.put("user-agent", "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1;SV1)");
    
    			String attUrl = "http://127.0.0.1:20020/x_processplatform_assemble_surface/jaxrs/attachment/upload/work/"
    					+ work;
    			String filePath = "F:Download明天.docx";
    			HttpClientUtil.getInstance().uploadFileImpl(attUrl, filePath, "file", uploadParams, headMap);
    		} catch (Exception e) {
    			e.printStackTrace();
    		}