webservice
1. 氚云后端代码,做个中间层webservice,通过webservice去调用第三方返回数据,在将数据转义为JSON字符串,以SOAP协议回传给氚云。
总体业务流程图如下:
2. webservice规范性:只能有4个同名接口,大小写都要一致,返回类型都为JSON字符串。对应关系如下表:
序号 |
函数 |
1 |
GetSchema(string schemaCode) |
2 |
GetSchemaList() |
3 |
GetList(string userCode, string schemaCode, string filter) |
4 |
Invoke(string userCode, string schemaCode, string methodName, string param)
|
3.webservice示例:
using System; using System.Collections.Generic; using System.IO; using System.Linq; using System.Net; using System.Text; using System.Web; using System.Web.Services; using Common; using H3.BizBus; using WebApplication2.model; using Newtonsoft.Json; using static WebApplication2.Class2; using Newtonsoft.Json.Linq; using System.Web.Script.Serialization; using static WebApplication2.Class1; using System.Runtime.Serialization.Json; using Microsoft.Ajax.Utilities; namespace WebApplication2 { /// <summary> /// WebDemo 的摘要说明 /// </summary> [WebService(Namespace = "http://tempuri.org/")] [WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)] [System.ComponentModel.ToolboxItem(false)] // 若要允许使用 ASP.NET AJAX 从脚本中调用此 Web 服务,请取消注释以下行。 // [System.Web.Script.Services.ScriptService] public class WebDemo : System.Web.Services.WebService { [WebMethod] //定义氚云表单结构 public string GetSchema(string schemaCode) { string strSchemaJson = string.Empty; BizStructureSchema schema = new BizStructureSchema();//创建一个业务结构 string errorMessage = string.Empty; schema.Code = schemaCode; schema.Add(new ItemSchema("Status", "返回结果", BizDataType.String)); schema.Add(new ItemSchema("Msg", "返回结果", BizDataType.String)); schema.Add(new ItemSchema("KHName", "KHName", BizDataType.String)); schema.Add(new ItemSchema("KHNage", "KHNage", BizDataType.Int)); schema.Add(new ItemSchema("KHNGender", "KHNGender", BizDataType.String)); schema.Add(new ItemSchema("KHNbithday", "KHNbithday", BizDataType.DateTime)); strSchemaJson = BizStructureUtility.SchemaToJson(schema); //string jsStr = Newtonsoft.Json.JsonConvert.SerializeObject(schemaCode); return strSchemaJson;//返回JSON字符串 } [WebMethod] /// <summary> /// 获取第三方数据至氚云(整个表单) /// </summary> /// <param name="userCode">氚云平台用户Id</param> /// <param name="schemaCode">氚云平台表单编码</param> /// <param name="filter">查询条件,josn格式数据</param> /// <returns></returns> //获取数据库数据将数据库数据转json格式传入氚云 public string GetList(string userCode, string schemaCode, string filter) { //数据库 DSFWSEntities1 db = new DSFWSEntities1(); //对filter数据进行value获取 string value = FJLdata(filter); if (value == "getcode") { int resultCodein = 0; //全局返回状态 0为成功 否则失败 string resultMsg = ""; //全局返回信息 int dataCount = 0; //返回数据条数 H3.BizBus.BizStructureSchema schema = null; string errorMessage = string.Empty; //获取BizStructureSchema字段结构 BizStructureUtility.JsonToSchema(this.GetSchema(schemaCode), out schema, out errorMessage); //定义返回的数据集合,这里以返回多条数据为例 List<BizStructure> list = new List<BizStructure>(); var json = db.AddInside.SingleOrDefault(d=>d.dbsave==1); if (json != null&&schemaCode!=json.schema) { string jsoninside = json.json; JObject obj = JObject.Parse(jsoninside); KHNcode khn = new KHNcode() { KHName = obj["KHName"].ToString(), KHNage = int.Parse(obj["KHNage"].ToString()), KHNGender = obj["KHNGender"].ToString(), KHNbirthday = DateTime.Parse(obj["KHNbirthday"].ToString()) }; Console.WriteLine(khn); BizStructure bizStructure = new H3.BizBus.BizStructure(schema); bizStructure["Status"] = "true"; bizStructure["Msg"] = "msg"; bizStructure["KHName"] = khn.KHName; bizStructure["KHNage"] = int.Parse(khn.KHNage.ToString()); bizStructure["KHNGender"] = khn.KHNGender; string khnco = khn.KHNGender; bizStructure["KHNbithday"] = DateTime.Parse(khn.KHNbirthday.ToString()); list.Add(bizStructure); resultMsg = "inset"; } else { //如果数据为空,创建一个空对象 BizStructure bizStructure = new H3.BizBus.BizStructure(schema); list.Add(bizStructure); } ListResult listResult = new ListResult(resultCodein, resultMsg, list.ToArray(), dataCount); //var listbiz= BizStructureUtility.ListResultToJson(listResult); //JObject objlistbiz = JObject.Parse(listbiz); //JArray objjsonbiz = (JArray)objlistbiz["Data"];//拿值 if (resultMsg=="inset") { var redbsave = db.AddInside.SingleOrDefault(d=>d.dbsave==1); db.AddInside.Remove(redbsave); if (db.SaveChanges()>0) { return BizStructureUtility.ListResultToJson(listResult); } } //返回序列化之后的数据 return BizStructureUtility.ListResultToJson(listResult); } if (value == "delcode" ) { int resultCodein = 0; //全局返回状态 0为成功 否则失败 string resultMsg = ""; //全局返回信息 int dataCount = 0; //返回数据条数 H3.BizBus.BizStructureSchema schema = null; string errorMessage = string.Empty; //获取BizStructureSchema字段结构 BizStructureUtility.JsonToSchema(this.GetSchema(schemaCode), out schema, out errorMessage); //定义返回的数据集合,这里以返回多条数据为例 List<BizStructure> list = new List<BizStructure>(); var dbremove = db.RemoveCode.SingleOrDefault(d=>d.dbre==1); if (dbremove != null && schemaCode != dbremove.reschema) { string jsoninside = dbremove.rejson; JObject obj = JObject.Parse(jsoninside); KHNcode khn = new KHNcode() { KHName = obj["KHName"].ToString(), KHNage = int.Parse(obj["KHNage"].ToString()), KHNGender = obj["KHNGender"].ToString(), KHNbirthday = DateTime.Parse(obj["KHNbirthday"].ToString()) }; BizStructure bizStructure = new H3.BizBus.BizStructure(schema); bizStructure["Status"] = "true"; bizStructure["Msg"] = "msg"; bizStructure["KHName"] = khn.KHName; bizStructure["KHNage"] = int.Parse(khn.KHNage.ToString()); bizStructure["KHNGender"] = khn.KHNGender; bizStructure["KHNbithday"] = DateTime.Parse(khn.KHNbirthday.ToString()); list.Add(bizStructure); resultMsg = "deletecode"; } else { //如果数据为空,创建一个空对象 BizStructure bizStructure = new H3.BizBus.BizStructure(schema); list.Add(bizStructure); } ListResult listResult = new ListResult(resultCodein, resultMsg, list.ToArray(), dataCount); if (resultMsg== "deletecode") { var redbremove = db.RemoveCode.SingleOrDefault(d => d.dbre == 1); db.RemoveCode.Remove(redbremove); if (db.SaveChanges() > 0) { return BizStructureUtility.ListResultToJson(listResult); } } //返回序列化之后的数据 return BizStructureUtility.ListResultToJson(listResult); } return ""; } ///filter进行转化获取value值,进行判断,返回到getlist /// public string FJLdata(string json) { JObject obj = JObject.Parse(json); JArray jsonstr = (JArray)obj["Matcher"]["Matchers"]; string value = jsonstr[0]["Value"].ToString(); return value; } [WebMethod] //氚云后端调用的方法名 public string Invoke(string userCode, string schemaCode, string methodName, string param) { DSFWSEntities1 db = new DSFWSEntities1(); int i = 0; string resultCode = "{\"resultCode\":0}"; //是否成功 0是成功 否则失败 string resultMessage = "全局信息添加到数据库失败"; //全局返回消息 //氚云调用webservice将数据存储到数据库,成功返回json格式 if (methodName == "submit") { KHNcode kh = new KHNcode(); JObject obj = JObject.Parse(param); kh.KHName = obj["KHName"].ToString(); kh.KHNage = int.Parse(obj["KHNage"].ToString()); kh.KHNGender = obj["KHNGender"].ToString(); kh.KHNbirthday = DateTime.Parse(obj["KHNbirthday"].ToString()); //返回数据 Console.WriteLine(resultCode); db.KHNcode.Add(kh); if (db.SaveChanges() > 0) { AddInside add = new AddInside(); add.dbsave = 1; add.json = param; add.schema = schemaCode; db.AddInside.Add(add); if (db.SaveChanges()>0) { return resultCode; } } else { return resultMessage; } } //这是全部数据 //第三方调用氚云数据,将数据存储到数据库,存储json转list else if (methodName == "alldata") { i++; if (i<2) { string apiAddress = @"https://www.h3yun.com/OpenApi/Invoke"; HttpWebRequest request = (System.Net.HttpWebRequest)WebRequest.Create(apiAddress); request.Method = "POST"; request.ContentType = "application/json"; request.Headers.Add("EngineCode", "i8f8rhfz68zbdfukhhz48kiw4"); request.Headers.Add("EngineSecret", "yhqF1mujLZtpa+iDHmAvzsfHJjQpWp8AuAhX/HxCy8W5FpRfDWa20Q=="); //身份认证参数 //request.Headers.Add("EngineCode", "fj854kdi05x0ur8ua4za9m766"); //request.Headers.Add("EngineSecret", "TiX3emcu3h0jN+SBtKDo6nfmb7jHD6ksM1ut961D56a/jdmKUGm62w=="); //参数 Dictionary<string, object> dicParams = new Dictionary<string, object>(); dicParams.Add("ActionName", "LoadBizObjects"); dicParams.Add("SchemaCode", "D000685KHNametwo"); dicParams.Add("Filter", "{\"FromRowNum\": 0,\"RequireCount\": false,\"ReturnItems\": [], \"SortByCollection\": [],\"ToRowNum\": 500, \"Matcher\": { \"Type\": \"And\", \"Matchers\": []}}"); string jsonData = JsonConvert.SerializeObject(dicParams); byte[] bytes; bytes = System.Text.Encoding.UTF8.GetBytes(jsonData); request.ContentLength = bytes.Length; using (Stream writer = request.GetRequestStream()) { writer.Write(bytes, 0, bytes.Length); writer.Close(); } string strValue = string.Empty; using (System.Net.HttpWebResponse response = (System.Net.HttpWebResponse)request.GetResponse()) { using (System.IO.Stream s = response.GetResponseStream()) { string StrDate = string.Empty; using (StreamReader Reader = new StreamReader(s, Encoding.UTF8)) { while ((StrDate = Reader.ReadLine()) != null) { strValue += StrDate + "\r\n"; } } } } return DSFWs(strValue); } #region //BizStructureSchema returnSchema = null; //string errorMessage = string.Empty; ////获取BizStructureSchema字段结构 //BizStructureUtility.JsonToSchema(this.GetSchema(schemaCode), out returnSchema, out errorMessage); //if (returnSchema == null) //{ // returnSchema = new BizStructureSchema(); //} //BizStructure returnBizStructure = new BizStructure(returnSchema);//返回对象 //bool flag = true; //string Msg = ""; //if (methodName=="Submit") { // kh.KHName =returnBizStructure["Param0"].ToString(); // kh.KHNage=int.Parse(returnBizStructure["Param1"].ToString()); // kh.KHNGender= returnBizStructure["Param2"].ToString(); // kh.KHNbirthday=DateTime.Parse(returnBizStructure["Param3"].ToString()); // if (db.SaveChanges()>0) { // return "true"; // } // else // { // return "false"; // } //} #endregion #region /* Dictionary<string, object> DataDic = new Dictionary<string, object>();//实例化数据 if (!string.IsNullOrEmpty(param)) { DataDic = JsonConvert.DeserializeObject<Dictionary<string, object>>(param);//反序列化JSON字符 } int resultCode = 0;//是否成功 0成功 1失败 string resultMessage = "";//返回消息 BizStructureSchema returnSchema = null; string errorMessage = string.Empty; //BizStructure returnBizStructure = null; //获取BizStructureSchema字段结构 BizStructureUtility.JsonToSchema(this.GetSchema(schemaCode), out returnSchema, out errorMessage); //BizStructureUtility.JsonToSchema(this.GetSchema(schemaCode), out returnSchema, out errorMessage); //returnBizStructure = new BizStructure(returnSchema); if (returnSchema == null) { returnSchema = new BizStructureSchema(); } BizStructure returnBizStructure = new BizStructure(returnSchema);//返回对象 if (methodName == "Test") { returnBizStructure["Param0"] = "A1"; } InvokeResult result = new H3.BizBus.InvokeResult(resultCode, resultMessage, returnBizStructure); //序列化返回数据 string returnResult = BizStructureUtility.InvokeResultToJson(result); return returnResult; */ #endregion } //进行删除,获取methodName,拿到param,查询数据库对数据进行判定,进行对数据库删除 else if (methodName=="delete") { List<KHNcode> khncode = new List<KHNcode>(); JObject obj = JObject.Parse(param); if (obj.Count==4) { string khname = obj["KHName"].ToString(); var value = db.KHNcode.SingleOrDefault(d => d.KHName == khname); if (value!=null) { db.KHNcode.Remove(value); if (db.SaveChanges()>0) { RemoveCode remove = new RemoveCode(); remove.dbre = 1; remove.rejson = param; remove.reschema = schemaCode; db.RemoveCode.Add(remove); if (db.SaveChanges() > 0) { return resultCode; } } else { return resultMessage; } } } } //对单条数据进行新增后第三方氚云调用 //else if (dbsave==1) { // //将新增的数据传入到中间存储方法,然后调用到getlist,第三方氚云调用getlist对新增数据进行filter // //对filter进行氚云后端代码的value值进行设置,之后进行判断 // return theaddcode(param); // } return "none"; } } }
H3chuanyun氚云辅助包
链接: https://pan.baidu.com/s/11Kjd3z1qRRvTnC5kWVR5cw 提取码: 2aqr