/******************************************************************************
* 文件名称: InvokeHelper.cs
* 文件说明: 调用助手,调用方法的封装
* 当前版本: V1.0
* 创建日期: 2022-04-12
*
* 2020-04-12: 增加 businessDLLInvoke 方法
* 2020-04-12: 增加 writeLog 方法
* 2020-04-14: 增加 businessDLLInvoke(重载) 方法
* 2020-04-14: 增加 irisServiceInvoke 方法
* 2022-05-16: 增加 invokeInsuService 方法
* 2022-05-16: 增加 invokeHISService 方法
******************************************************************************/
using Newtonsoft.Json;
using Newtonsoft.Json.Linq;
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Net;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
namespace DirectoryDownload.Helper
{
class InvokeHelper
{
///
/// 封装业务DLL的调用,返回整型,带两ref出参
///
///
///
///
///
///
public int businessDLLInvoke(string methodName, string inParam, ref string outParam,ref string ErrorMessage)
{
try
{
DllInvoke dllInvoke = new DllInvoke();
string path = GlobalVariables.currentDirectory + "\\" + GlobalVariables.businessDllName;
string[] str = new string[1];
str[0] = inParam;
object o2 = DllInvoke.ManagedInvoke(path, GlobalVariables.businessDllNameSpace, "InsuBusiness", methodName, str);
if (o2.ToString() == "")
{
ErrorMessage = "返回数据为空";
return -1;
}
JObject joRtn = JObject.Parse(o2.ToString());
if (joRtn["errorCode"].ToString() != "0")
{
ErrorMessage = joRtn["errorMessage"].ToString();
return -1;
}
else
{
outParam = o2.ToString();
return 0;
}
}
catch (Exception ex)
{
ErrorMessage = "调用异常:" + ex.ToString();
return -1;
}
finally
{
writeLog(methodName,inParam,outParam);
}
}
///
/// 封装业务DLL的调用,返回JSON对象
///
///
///
///
public JObject businessDLLInvoke(string methodName, string inParam)
{
string outParam = string.Empty; string path = "";
JObject joRtn = new JObject();
try
{
DllInvoke dllInvoke = new DllInvoke();
path = GlobalVariables.currentDirectory + "\\" + GlobalVariables.businessDllName;
string[] str = new string[1];
str[0] = inParam;
object o2 = DllInvoke.ManagedInvoke(path, GlobalVariables.businessDllNameSpace, "InsuBusiness", methodName, str);
outParam = o2.ToString();
joRtn = JObject.Parse(outParam);
return joRtn;
}
catch (Exception ex)
{
outParam = "businessDLLInvoke:原出参(" + outParam + ")\r\n ,异常:" + ex.Message;
return JsonHelper.getIrisExceptionJson(-1, "businessDLLInvoke:" ,outParam);
}
finally
{
writeLog(methodName + "(" + path + ")", inParam, outParam);
}
}
///
/// 调用壳DLL
///
///
///
///
public JObject invokeShellDll(string methodName, string inParam)
{
string outParam = string.Empty; string path = "";
JObject joRtn = new JObject();
try
{
DllInvoke dllInvoke = new DllInvoke();
path = GlobalVariables.currentDirectory + "\\" + "PTMedInsuInterface.dll";
string[] str = new string[1];
str[0] = inParam;
object o2 = DllInvoke.ManagedInvoke(path, "PTMedInsuInterface", "InsuBusiness", methodName, str);
outParam = o2.ToString();
joRtn = JObject.Parse(outParam);
return joRtn;
}
catch (Exception ex)
{
outParam = "invokeShellDll:原出参(" + outParam + ")\r\n ,异常:" + ex.Message;
return JsonHelper.getIrisExceptionJson(-1, "invokeShellDll:", outParam);
}
finally
{
writeLog(methodName + "(" + path + ")", inParam, outParam);
}
}
///
/// iris服务调用的封装
///
///
///
public JObject irisServiceInvoke(string data,string serviceName)
{
string rtn = "", url = "";
JObject joRtn = new JObject();
try
{
//先根据用户请求的uri构造请求地址
url = string.Format("{0}/{1}", GlobalVariables.irisServiceIP, GlobalVariables.irisServiceURL);
ServicePointManager.ServerCertificateValidationCallback = delegate { return true; };
ServicePointManager.SecurityProtocol = SecurityProtocolType.Ssl3 | SecurityProtocolType.Tls12 | SecurityProtocolType.Tls11 | SecurityProtocolType.Tls;
//创建Web访问对象
HttpWebRequest myRequest = (HttpWebRequest)WebRequest.Create(url);
//把用户传过来的数据转成“UTF-8”的字节流
byte[] buf = System.Text.Encoding.GetEncoding("UTF-8").GetBytes(data);
//添加头部信息
myRequest.Method = "POST";
myRequest.ContentLength = buf.Length;
myRequest.ContentType = "application/json";
myRequest.Headers.Add("Authorization", GlobalVariables.irisServiceAuthorization);
myRequest.MaximumAutomaticRedirections = 1;
myRequest.AllowAutoRedirect = true;
//发送请求
Stream stream = myRequest.GetRequestStream();
stream.Write(buf, 0, buf.Length);
stream.Close();
//获取接口返回值
//通过Web访问对象获取响应内容
HttpWebResponse myResponse = (HttpWebResponse)myRequest.GetResponse();
//通过响应内容流创建StreamReader对象,因为StreamReader更高级更快
StreamReader reader = new StreamReader(myResponse.GetResponseStream(), Encoding.UTF8);
//string rtn = HttpUtility.UrlDecode(reader.ReadToEnd());//如果有编码问题就用这个方法
rtn = reader.ReadToEnd();//利用StreamReader就可以从响应内容从头读到尾
reader.Close();
myResponse.Close();
joRtn = JObject.Parse(rtn);
return joRtn;
}
catch (Exception ex)
{
joRtn = JsonHelper.getIrisExceptionJson(-1, serviceName,rtn + "\r\n" + ex.Message);
rtn = joRtn.ToString();
return joRtn;
}
finally
{
writeLog(serviceName+ url , data, rtn);
}
}
///
/// iris服务调用的封装
///
///
///
public JObject invokeHISService(string data, string serviceDesc)
{
string rtn = "", url = "";
JObject joRtn = new JObject();
try
{
//先根据用户请求的uri构造请求地址
url = string.Format("{0}/{1}", GlobalVariables.hisIrisServiceIP, GlobalVariables.hisIrisServiceURL);
ServicePointManager.ServerCertificateValidationCallback = delegate { return true; };
ServicePointManager.SecurityProtocol = SecurityProtocolType.Ssl3 | SecurityProtocolType.Tls12 | SecurityProtocolType.Tls11 | SecurityProtocolType.Tls;
//创建Web访问对象
HttpWebRequest myRequest = (HttpWebRequest)WebRequest.Create(url);
//把用户传过来的数据转成“UTF-8”的字节流
byte[] buf = System.Text.Encoding.GetEncoding("UTF-8").GetBytes(data);
//添加头部信息
myRequest.Method = "POST";
myRequest.ContentLength = buf.Length;
myRequest.ContentType = "application/json";
myRequest.Headers.Add("Authorization", GlobalVariables.hisIrisServiceAuthorization);
myRequest.MaximumAutomaticRedirections = 1;
myRequest.AllowAutoRedirect = true;
//发送请求
Stream stream = myRequest.GetRequestStream();
stream.Write(buf, 0, buf.Length);
stream.Close();
//获取接口返回值
//通过Web访问对象获取响应内容
HttpWebResponse myResponse = (HttpWebResponse)myRequest.GetResponse();
//通过响应内容流创建StreamReader对象,因为StreamReader更高级更快
StreamReader reader = new StreamReader(myResponse.GetResponseStream(), Encoding.UTF8);
//string rtn = HttpUtility.UrlDecode(reader.ReadToEnd());//如果有编码问题就用这个方法
rtn = reader.ReadToEnd();//利用StreamReader就可以从响应内容从头读到尾
reader.Close();
myResponse.Close();
joRtn = JObject.Parse(rtn);
return joRtn;
}
catch (Exception ex)
{
joRtn = JsonHelper.getIrisExceptionJson(-1, serviceDesc, ex.Message);
rtn = JsonConvert.SerializeObject(joRtn);
return joRtn;
}
finally
{
GlobalVariables.writeLog(serviceDesc + "(" + url + ")", data, rtn);
}
}
///
/// iris服务调用的封装
///
///
///
public JObject invokeInsuService(string data, string serviceDesc)
{
string rtn = "", url = "";
JObject joRtn = new JObject();
try
{
//先根据用户请求的uri构造请求地址
url = string.Format("{0}/{1}", GlobalVariables.insuIrisServiceIP, GlobalVariables.insuIrisServiceURL);
ServicePointManager.ServerCertificateValidationCallback = delegate { return true; };
ServicePointManager.SecurityProtocol = SecurityProtocolType.Ssl3 | SecurityProtocolType.Tls12 | SecurityProtocolType.Tls11 | SecurityProtocolType.Tls;
//创建Web访问对象
HttpWebRequest myRequest = (HttpWebRequest)WebRequest.Create(url);
//把用户传过来的数据转成“UTF-8”的字节流
byte[] buf = System.Text.Encoding.GetEncoding("UTF-8").GetBytes(data);
//添加头部信息
myRequest.Method = "POST";
myRequest.ContentLength = buf.Length;
myRequest.ContentType = "application/json";
myRequest.Headers.Add("Authorization", GlobalVariables.insuIrisServiceAuthorization);
myRequest.MaximumAutomaticRedirections = 1;
myRequest.AllowAutoRedirect = true;
//发送请求
Stream stream = myRequest.GetRequestStream();
stream.Write(buf, 0, buf.Length);
stream.Close();
//获取接口返回值
//通过Web访问对象获取响应内容
HttpWebResponse myResponse = (HttpWebResponse)myRequest.GetResponse();
//通过响应内容流创建StreamReader对象,因为StreamReader更高级更快
StreamReader reader = new StreamReader(myResponse.GetResponseStream(), Encoding.UTF8);
//string rtn = HttpUtility.UrlDecode(reader.ReadToEnd());//如果有编码问题就用这个方法
rtn = reader.ReadToEnd();//利用StreamReader就可以从响应内容从头读到尾
reader.Close();
myResponse.Close();
joRtn = JObject.Parse(rtn);
return joRtn;
}
catch (Exception ex)
{
joRtn = JsonHelper.getIrisExceptionJson(-1, serviceDesc, ex.Message);
rtn = JsonConvert.SerializeObject(joRtn);
return joRtn;
}
finally
{
GlobalVariables.writeLog(serviceDesc + "(" + url + ")", data, rtn);
}
}
///
/// 一次交易的完整日志记录,用*****分割每次交易,简洁明了。
///
///
///
///
private void writeLog(string tradeName, string inParam, string outParam)
{
string logDir = GlobalVariables.currentDirectory + "\\Log", logName = DateTime.Now.ToString("yyyy-MM-dd") + "_Demo.Log";
string statrTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss ffff");
if (!Directory.Exists(logDir))
{
//创建文件夹
DirectoryInfo dirInfo = Directory.CreateDirectory(logDir);
}
if (!File.Exists(logDir + "\\" + logName))
{
FileStream fs1 = File.Create(logDir + "\\" + logName);
fs1.Close();
}
FileStream fs = new FileStream(logDir + "\\" + logName, FileMode.Append, FileAccess.Write);
StreamWriter sw = new StreamWriter(fs);
string content = "****************************交易开始(" + statrTime + ")****************************" + "\r\n";
content = content + "交易名称:" + tradeName + "\r\n";
content = content + "交易入参:" + inParam + "\r\n";
content = content + "交易出参:" + outParam + "\r\n";
content = content + "****************************交易结束(" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss ffff") + ")****************************" + "\r\n";
sw.WriteLine(content);
sw.Close();
fs.Close();
}
}
}