using System; using System.Text; using BP.DA; using BP.GPM.WeiXin; using BP.Tools; using System.Linq; using static BP.WF.WeiXin.GZH.WeiXinGZHModel; using System.Collections; namespace BP.WF.HttpHandler { /// /// 集成企业微信OA类 /// public class WF_MyOA : DirectoryPageBase { /// /// 集成企业微信OA类 /// public WF_MyOA() { } /// /// 初始化(处理登录用户) /// /// public string MyOA_Init() { string code = this.GetRequestVal("code"); //string state = this.GetRequestVal("state"); //执行标记. Hashtable myht = new Hashtable(); if (BP.Web.WebUser.No == null) { /* 如果当前登录人员帐号为 null .*/ string accessToken = WeiXinEntity.getAccessToken(); //获取 AccessToken myht.Add("Token", accessToken); string userId = getUserId(code, accessToken); User user = FormatToJson.ParseFromJson(userId); if (user.ErrCode != 0) { //throw new Exception("err@当前登录帐号为空,请检查AccessToken是否正确:" + accessToken); return "err@当前登录帐号为空,请检查AccessToken是否正确:" + accessToken; } else { BP.Port.Emps emps = new BP.Port.Emps(); int num = emps.Retrieve(BP.Port.EmpAttr.No, user.UserId); if (num <= 0) { //是否使用微信企业号中的组织结构进行登录 if (BP.Difference.SystemConfig.OZType == "1") { string url = "https://qyapi.weixin.qq.com/cgi-bin/user/get?access_token=" + accessToken + "&userid=" + user.UserId; string str = BP.DA.DataType.ReadURLContext(url, 4000, Encoding.UTF8); //人员详细信息 UserEntity userEn = FormatToJson.ParseFromJson(str); //所属部门 Array depts = userEn.department as Array; foreach (object item in depts) { BP.Port.Depts dts = new BP.Port.Depts(); url = "https://qyapi.weixin.qq.com/cgi-bin/department/list?access_token=" + accessToken + "&id=" + item; str = BP.DA.DataType.ReadURLContext(url, 4000, Encoding.UTF8); //部门详细信息 DeptList mydepts = FormatToJson.ParseFromJson(str); //如果部门不存在,插入部门信息 if (dts.Retrieve(BP.Port.DeptAttr.No, item) <= 0) { foreach (DeptEntity deptMent in mydepts.department) { dts = new BP.Port.Depts(); if (dts.Retrieve(BP.Port.DeptAttr.No, item) > 0) continue; else { BP.Port.Dept dp = new BP.Port.Dept(); dp.No = deptMent.id; dp.Name = deptMent.name; dp.ParentNo = deptMent.parentid; dp.Insert(); } } } else //如果存在,更新部门名称 { foreach (DeptEntity deptMent in mydepts.department) { BP.Port.Dept dp = new BP.Port.Dept(deptMent.id); dp.Name = deptMent.name; dp.ParentNo = deptMent.parentid; dp.Update(); } } //插入人员表 BP.Port.Emp emp = new BP.Port.Emp(); emp.No = user.UserId; emp.FK_Dept = item.ToString(); emp.Name = userEn.name; emp.Tel = userEn.mobile; emp.Insert(); //插入部门表 BP.Port.DeptEmp deptEmp = new BP.Port.DeptEmp(); deptEmp.MyPK = item + "_" + user.UserId; deptEmp.FK_Dept = item.ToString(); deptEmp.FK_Emp = user.UserId; deptEmp.Insert(); } //执行登录 BP.WF.Dev2Interface.Port_Login(user.UserId); } else { emps = new BP.Port.Emps(); num = emps.Retrieve(BP.Port.EmpAttr.Tel, user.UserId); if (num <= 0) { //throw new Exception("err@用户名错误,没有找到登录信息:" + accessToken); return "err@用户名错误,没有找到登录信息:" + accessToken; } foreach (BP.Port.Emp emp in emps) { BP.WF.Dev2Interface.Port_Login(emp.No); break; } } } else { BP.WF.Dev2Interface.Port_Login(user.UserId); } } } return BP.Tools.Json.ToJson(myht); //if (!state.Contains(',')) // Response.Redirect("../CCMobile/" + state + ".htm"); //else //{ // string[] vals = state.Split(','); // if (vals[0].Contains("URL_") == true) // { // string url = vals[0].Substring(4); // string dummyData = url.Trim().Replace("%", "").Replace(",", "").Replace(" ", "+"); // if (dummyData.Length % 4 > 0) // { // dummyData = dummyData.PadRight(dummyData.Length + 4 - dummyData.Length % 4, '='); // } // //Base64位解码 // byte[] bytes = Convert.FromBase64String(dummyData); // url = UTF8Encoding.UTF8.GetString(bytes); // Response.Redirect(url); // } // if (vals[0].Contains("MyView") == true) // { // Response.Redirect("../CCMobile/MyView.htm?WorkID=" + vals[1].Replace("WorkID_", "") + "&FK_Node=" + vals[2].Replace("FK_Node_", "") + ""); // } // if (vals[0].Contains("FlowNo")) // { // string[] pks = vals[0].Split('_'); // Response.Redirect("../CCMobile/MyFlow.htm?FK_Flow=" + pks[1] + "&state=" + vals[1] + ""); // } //} } /// /// 获得用户ID /// /// /// /// public string getUserId(string code, string accessToken) { string url = "https://qyapi.weixin.qq.com/cgi-bin/auth/getuserinfo?access_token=" + accessToken + "&code=" + code; return DataType.ReadURLContext(url, 39000, Encoding.UTF8); } } }