/// <summary>
        /// 发送短信 系统固化短信
        /// </summary>
        /// <param name="memberId"></param>
        /// <param name="mobile"></param>
        /// <param name="subType"></param>
        /// <param name="groupId"></param>
        /// <returns></returns>
        public static Result SendMsgBySysInit(string memberId, string mobile, string subType, int groupId)
        {
            using (CRMEntities db = new CRMEntities())
            {
                var qTemp = db.TM_Act_CommunicationTemplet.Where(o => o.IsSysInit == true && o.Type == "SMS" && o.SubType == subType && o.DataGroupID == groupId).FirstOrDefault();
                string sendMsg = "";
                int templateId = 0;
                if (qTemp != null)
                {
                    sendMsg = qTemp.BasicContent;
                    templateId = qTemp.TempletID;
                }
                Regex reg = new Regex(@"{[a-zA-Z \u4e00-\u9fa5]+}");
                MatchCollection mc = reg.Matches(sendMsg);
                List<Dictionary<string, string>> lstDict = new List<Dictionary<string, string>>();
                for (int i = 0; i < mc.Count; i++)
                {
                    string strRgx = mc[i].Value.ToString().TrimStart('{').TrimEnd('}');
                    Dictionary<string, string> dict = new Dictionary<string, string>();
                    var qAlias = db.TD_SYS_FieldAlias.Where(o => o.FieldDesc == strRgx).FirstOrDefault();
                    if (qAlias != null)
                    {
                        dict["name"] = qAlias.FieldAlias;
                        if (qAlias.ControlType == "date")
                        {
                            DateTime qSqlRet = db.Database.SqlQuery<DateTime>(string.Format("select {2} from {0} where memberId='{1}'", qAlias.TableName, memberId, qAlias.FieldName)).FirstOrDefault();
                            dict["value"] = qSqlRet.ToShortDateString();
                        }
                        else
                        {
                            string qSql = db.Database.SqlQuery<string>(string.Format("select Convert(varchar,{2}) from {0} where memberId='{1}'", qAlias.TableName, memberId, qAlias.FieldName)).FirstOrDefault();
                            dict["value"] = qSql;
                        }
                        lstDict.Add(dict);
                    }
                }
                if (lstDict != null && lstDict.Count > 0)
                {
                    Result ret = SendSms(memberId, mobile, templateId, lstDict, sendMsg);
                    return ret;
                }
                else
                    return new Result(false, "参数不正确,不能发送短信!");
            }
        }

internal static Result SendSms(string memberId, string mobile, int templateId, object para, string message)
        {
            string defaultUser = "sys";
            try
            {
                using (CRMEntities db = new CRMEntities())
                {
                    StringBuilder sb = new StringBuilder();
                    List<Dictionary<string, string>> lstPara = (List<Dictionary<string, string>>)para;
                    sb.Append("{");
                    for (int i = 0; i < lstPara.Count; i++)
                    {
                        Dictionary<string, string> dict = lstPara[i];
                        sb.AppendFormat("\"{0\"}:\"{1}\"", dict["name"], dict["value"]);
                        if (i < lstPara.Count - 1)
                            sb.AppendFormat(",");
                    }
                    sb.Append("}");
                    var ent = new TM_Sys_SMSSendingQueue
                    {
                        Mobile = mobile,
                        Message = message,
                        MemberID = memberId,
                        AddedDate = DateTime.Now,
                        AddedUser = defaultUser,
                        Remark = "sys",
                        MsgPara = sb.ToString(),//JsonHelper.Serialize(para),
                        TempletID = templateId,
                        IsSent = false,
                    };
                    db.TM_Sys_SMSSendingQueue.Add(ent);
                    db.SaveChanges();

return new Result(true, "发送成功!");
                }
            }
            catch (Exception ex)
            {
                return new Result(false, ex.Message);
            }
        }

C#后台利用正则表达式查找匹配字符的更多相关文章

  1. 在eclipse中利用正则表达式查找替换

    众所周知,eclipse是可以用正则表达式来进行查找的,那么怎么利用正则表达式进行替换呢? 方法也很简单,就是在Replace with: 里面输入$来代表捕获型括号的匹配结果,$1为第一个匹配结果, ...

  2. swift 3.0 正则表达式查找/替换字符

    1.什么是正则表达式 正则表达式,又称正规表示法.常规表示法(英语:Regular Expression,在代码中常简写为regex.regexp或RE),计算机科学的一个概念.正则表达式使用单个字符 ...

  3. linux 查找匹配文件中包含指定字符的 前五行,这里是指所有匹配的前五行

    最近被问到 一个关于查找匹配字符的信息显示问题: 系统/etc/sysctl.conf文件会定义系统内核的一些配置,请查找和net有关的信息,并只打印前面5行信息. 解决方式大概试两种写法均可: 1. ...

  4. (转)ObjC利用正则表达式抓取网页内容(网络爬虫)

    转自:http://www.cocoachina.com/bbs/read.php?tid=103813 *****boy]原创 2012年5月20日 在开发项目的过程,很多情况下我们需要利用互联网上 ...

  5. OC利用正则表达式获取网络资源(网络爬虫)

    在开发项目的过程,很多情况下我们需要利用互联网上的一些数据,在这种情况下,我们可能要写一个爬虫来爬我们所需要的数据.一般情况下都是利用正则表达式来匹配Html,获取我们所需要的数据.一般情况下分以下三 ...

  6. ObjC利用正则表达式抓取网页内容(网络爬虫)

    本文转载至 http://www.cocoachina.com/bbs/read.php?tid=103813&fpage=63 在开发项目的过程,很多情况下我们需要利用互联网上的一些数据,在 ...

  7. Sublime 、NotePad++中查找匹配中文字符

    在Sublime .NotePad++中可以使用正则表达式 [\x{4e00}-\x{9fa5}] 查找匹配中文字符.

  8. Js 利用正则表达式和replace函数获取string中所有被匹配到的文本

    js的replace函数除了替换文本以外还有获取所有被正则表达式匹配到的文本的功能.这里以一个简单的案例来作为演示. 利用正则查找出所有被两个花括号包裹的字符串: var str = '<div ...

  9. Notepad++正则表达式查找替换文本中文字符

    测试需求 测试工具中xml配置文件中注释字段包含中文字符,在Win10系统下使用工具中偶尔会出现中文乱码导致配置文件失效.解决方法将配置文件中的中文注释换成英文注释或者直接替换删除.如何将配置文件中的 ...

随机推荐

  1. AIX 7.1 install python

    周围环境AIX7.1   设备python-2.6.2  因为互联网是非常多的安装文档.而且也没有细挑的版本号.因为我觉得python2.6 可能相对保守一些,至少之前用到的版本号是这个.所以此处依旧 ...

  2. Cocos2dx 3.0开发环境的搭建--Eclipse建立在Android工程

    一.前言: 这部分描述了Cocos2d-x 3.0的一些基础内容,以及在Eclipse上上编译我们的Cocos2d-x项目,成功把Helloworld执行起来了.看完本篇博客之后.你就会知道Cocos ...

  3. (hdu step 7.1.2)You can Solve a Geometry Problem too(乞讨n条线段,相交两者之间的段数)

    称号: You can Solve a Geometry Problem too Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/ ...

  4. Byte[]和BASE64之间的转换

    一. BASE64编码 把byte[]中的元素当做无符号八位整数转换成只含有64个基本字符的字符串,这些基本字符是: l 大写的A-Z l 小写的a-z l 数字0-9 l '+' 和 '/' l 空 ...

  5. 北邮iptv用WindowsMediaplayer打不开的解决的方法

    前言:之前我的iptv能够用,可是有次我安装了realplayer,它就偷偷把iptv文件的默认打开方式给篡改了,卸载了                  realplayer之后,iptv不能直接用 ...

  6. Maven使用-利用Maven引入相关包(Struts2)

    根据上一篇的项目搭建,接下来引入需要使用Struts2相关包 1,如何利用maven往项目中引入包? maven就像一个导包助手一样,让它知道去哪里拿什么,他就会自动完成需要的包的搬运工作. (1), ...

  7. c# socket udp广播

    一.广播消息 由于Tcp是有连接的,所以不能用来发送广播消息.发送广播消息,必须用到Udp,Udp可以不用建立连接而发送消息.广播消息的目的IP地址是一种特殊IP地址,称为广播地址.广播地址由IP地址 ...

  8. 读书时间《JavaScript高级程序设计》一:基础篇

    第一次看了<JavaScript高级程序设计>第二版,那时见到手上的书,第一感觉真是好厚的一本书啊.现在再次回顾一下,看的是<JavaScript高级程序设计>第三版,并记录一 ...

  9. SharePoint使用BCS开发你第一个应用程序(三)

    SharePoint使用BCS开发你第一个应用程序(三) 创建外部内容类型.         创建外部内容类型有三种不同方式: 1. 在记事本上手写XML代码(不推荐). 2. 使用SharePoin ...

  10. 《Javascript权威指南》13号学习笔记:使用日期和时间

    一.创Date示例 1.Date类的方法和属性是非常不静,故,申请书Date属性和方法之前.必须创建Date类的实例. var date = new Date();  //以当前日期和时间创建实例. ...