微信公众平台开发教程(四) 实例入门:机器人回复(附源码)


Posted in Javascript onDecember 02, 2016

上一篇文章,写了基本框架,可能很多人会觉得晕头转向,这里提供一个简单的例子来予以说明,希望能帮你解开谜团。

一、功能介绍

通过微信公众平台实现在线客服机器人功能。主要的功能包括:简单对话、查询天气等服务。

这里只是提供比较简单的功能,重在通过此实例来说明公众平台的具体研发过程。只是一个简单DEMO,如果需要的话可以在此基础上进行扩展。

当然后续我们还会推出比较复杂的应用实例。

二、具体实现

1、提供访问接口

这里不再赘述,参照上一章,微信公众账号开发教程(二) 基础框架搭建
https://3water.com/article/98754.htm

2、签名认证和分发请求

这里不再赘述,参照上一章,微信公众账号开发教程(二) 基础框架搭建
https://3water.com/article/98754.htm

3、处理请求,并响应

1)关注

当微信用户关注公众账号时,可以给其适当的提示。可以是欢迎词,可以是帮助提示。

直接上代码:

class EventHandler : IHandler
  {
    /// <summary>
    /// 请求的xml
    /// </summary>
    private string RequestXml { get; set; }
    /// <summary>
    /// 构造函数
    /// </summary>
    /// <param name="requestXml"></param>
    public EventHandler(string requestXml)
    {
      this.RequestXml = requestXml;
    }
    /// <summary>
    /// 处理请求
    /// </summary>
    /// <returns></returns>
    public string HandleRequest()
    {
      string response = string.Empty;
      EventMessage em = EventMessage.LoadFromXml(RequestXml);
      if (em.Event.Equals("subscribe",StringComparison.OrdinalIgnoreCase))
      {
        //回复欢迎消息
        TextMessage tm = new TextMessage();
        tm.ToUserName = em.FromUserName;
        tm.FromUserName = em.ToUserName;
        tm.CreateTime = Common.GetNowTime();
        tm.Content = "欢迎您关注***,我是大哥大,有事就问我,呵呵!\n\n";
        response = tm.GenerateContent();
      }

      return response;
    }
  }

 2)问候

简单的交流问候,比如你好、帮助等等,跟我们使用微信聊天一样,不过回应是由我们的程序响应。具体功能,可以根据自己的需要进行添加。

微信本来就是沟通的平台。这个案例,可以用于在线服务机器人,类似于淘宝的客服机器人,可是我们这个是微信版的。呵呵
其实,很简单,获取请求消息,根据关键字来匹配回应。当然这里可能要做的工作很多,如何支持智能匹配,如何支持模糊匹配等。

代码如下:

/// <summary>
  /// 文本信息处理类
  /// </summary>
  public class TextHandler : IHandler
  {
    /// <summary>
    /// 请求的XML
    /// </summary>
    private string RequestXml { get; set; }
    /// <summary>
    /// 构造函数
    /// </summary>
    /// <param name="requestXml">请求的xml</param>
    public TextHandler(string requestXml)
    {
      this.RequestXml = requestXml;
    }
    /// <summary>
    /// 处理请求
    /// </summary>
    /// <returns></returns>
    public string HandleRequest()
    {
      string response = string.Empty;
      TextMessage tm = TextMessage.LoadFromXml(RequestXml);
      string content = tm.Content.Trim();
      if (string.IsNullOrEmpty(content))
      {
        response = "您什么都没输入,没法帮您啊,%>_<%。";
      }
      else
      {
        if (content.StartsWith("tq", StringComparison.OrdinalIgnoreCase))
        {
          string cityName = content.Substring(2).Trim();
          response = WeatherHelper.GetWeather(cityName);
        }
        else
        {
          response = HandleOther(content);
        }
      }
      tm.Content = response;
      //进行发送者、接收者转换
      string temp = tm.ToUserName;
      tm.ToUserName = tm.FromUserName;
      tm.FromUserName = temp;
      response = tm.GenerateContent();
      return response;
    }
    /// <summary>
    /// 处理其他消息
    /// </summary>
    /// <param name="tm"></param>
    /// <returns></returns>
    private string HandleOther(string requestContent)
    {
      string response = string.Empty;
      if (requestContent.Contains("你好") || requestContent.Contains("您好"))
      {
        response = "您也好~";
      }
      else if (requestContent.Contains("傻"))
      {
        response = "我不傻!哼~ ";
      }
      else if (requestContent.Contains("逼") || requestContent.Contains("操"))
      {
        response = "哼,你说脏话! ";
      }
      else if (requestContent.Contains("是谁"))
      {
        response = "我是大哥大,有什么能帮您的吗?~";
      }
      else if (requestContent.Contains("再见"))
      {
        response = "再见!";
      }
      else if (requestContent.Contains("bye"))
      {
        response = "Bye!";
      }
      else if (requestContent.Contains("谢谢"))
      {
        response = "不客气!嘿嘿";
      }
      else if (requestContent == "h" || requestContent == "H" || requestContent.Contains("帮助"))
      {
        response = @"查询天气,输入tq 城市名称\拼音\首字母";
      }
      else
      {
        response = "您说的,可惜,我没明白啊,试试其他关键字吧。";
      }

      return response;
    }
  }

3)查询天气

这个功能需要请求实时查询的,请求官方的天气发布网站,然后解析其返回值,按照我们需要的格式,组织天气信息,最后发送给微信客户。

采用文本消息方式处理。

用户请求,只需输入:tq 城市名称/拼音/首字母,即可获取消息。

回复的消息:(以北京为例)

北京
2013年11月6日 星期三
今天:(17℃~4℃)晴北风4-5级转3-4级4-5级转3-4级
24小时穿衣指数:天气冷,建议着棉服、羽绒服、皮夹克加羊毛衫等冬季服装。年老体弱者宜着厚棉衣、冬大衣或厚羽绒服。
明天:(14℃~3℃)晴转多云微风小于3级
48小时穿衣指数:天气冷,建议着棉服、羽绒服、皮夹克加羊毛衫等冬季服装。年老体弱者宜着厚棉衣、冬大衣或厚羽绒服。

来看源码吧:

class WeatherHelper
  {
    /// <summary>
    /// 城市集合字段
    /// </summary>
    private static Dictionary<string, City> mCities;
    /// <summary>
    /// 城市集合
    /// </summary>
    public static Dictionary<string, City> Cities
    {
      get
      {
        if (mCities == null)
        {
          LoadCities();
        }

        return mCities;
      }
    }
    /// <summary>
    /// 加载城市
    /// </summary>
    private static void LoadCities()
    {
      mCities = new Dictionary<string, City>();
      mCities.Clear();
      mCities.Add("101010100", new City() { Code = "101010100", Name = "北京", PinYin = "beijing", FristLetter = "bj" });
      mCities.Add("101020100", new City() { Code = "101020100", Name = "上海", PinYin = "shanghai", FristLetter = "sh" });
      mCities.Add("101200101", new City() { Code = "101200101", Name = "武汉", PinYin = "wuhai", FristLetter = "wh" });
      
    }
    /// <summary>
    /// 获取城市的天气
    /// </summary>
    /// <param name="name">城市名称、拼音或首字母</param>
    /// <returns></returns>
    public static string GetWeather(string name)
    {
      string result = string.Empty;
      string cityCode = string.Empty;
      //获取城市编码
      IEnumerable<string> codes = from item in Cities
                    where item.Value != null
                       && (item.Value.Name.Equals(name, StringComparison.OrdinalIgnoreCase) 
                          || item.Value.PinYin.Equals(name, StringComparison.OrdinalIgnoreCase) 
                          || item.Value.FristLetter.Equals(name, StringComparison.OrdinalIgnoreCase))
                    select item.Value.Code;
      if (codes != null && codes.Count() > 0)
      {
        cityCode = codes.First<string>();
      }

      //http请求,获取天气
      if (!string.IsNullOrEmpty(cityCode))
      {
        string url = "http://m.weather.com.cn/data/{0}.html";
        url = string.Format(url, cityCode);
        WebRequest request = HttpWebRequest.Create(url);
        //超时时间为:2秒
        request.Timeout = 2000;
        request.Credentials = CredentialCache.DefaultCredentials;
        WebResponse response = request.GetResponse();
        StreamReader reader = new StreamReader(response.GetResponseStream(), Encoding.UTF8);
        string weahterInfo = reader.ReadToEnd();
        if (string.IsNullOrEmpty(weahterInfo))
        {
          result = "暂时没有取到天气数据,请稍后再试";
        }
        else
        {
          XmlDocument doc = JsonConvert.DeserializeXmlNode(weahterInfo);
          if (doc != null)
          {
            XmlNode node = doc.DocumentElement;
            if (node != null)
            {
              StringBuilder builder = new StringBuilder();
              builder.Append(node["city"].InnerText).Append("\n");
              builder.Append(node["date_y"].InnerText).Append(" ").Append(node["week"].InnerText).Append("\n");
              builder.Append("今天:").Append("(").Append(node["temp1"].InnerText).Append(")").Append(node["weather1"].InnerText).Append(node["wind1"].InnerText).Append(node["fl1"].InnerText).Append("\n");
              builder.Append("24小时穿衣指数:").Append(node["index_d"].InnerText).Append("\n");
              builder.Append("明天:").Append("(").Append(node["temp2"].InnerText).Append(")").Append(node["weather2"].InnerText).Append(node["wind2"].InnerText).Append(node["fl2"].InnerText).Append("\n");
              builder.Append("48小时穿衣指数:").Append(node["index48_d"].InnerText).Append("\n");
              result = builder.ToString();
            }
          }
          #region 天气json数据格式
          /*
         
        {
  "weatherinfo": {
    "city": "北京", 
    "city_en": "beijing", 
    "date_y": "2013年11月4日", 
    "date": "", 
    "week": "星期一", 
    "fchh": "11", 
    "cityid": "101010100", 
    "temp1": "17℃~5℃", 
    "temp2": "16℃~5℃", 
    "temp3": "18℃~4℃", 
    "temp4": "17℃~5℃", 
    "temp5": "14℃~6℃", 
    "temp6": "14℃~2℃", 
    "tempF1": "62.6?~41?", 
    "tempF2": "60.8?~41?", 
    "tempF3": "64.4?~39.2?", 
    "tempF4": "62.6?~41?", 
    "tempF5": "57.2?~42.8?", 
    "tempF6": "57.2?~35.6?", 
    "weather1": "晴转多云", 
    "weather2": "多云", 
    "weather3": "多云转晴", 
    "weather4": "晴转多云", 
    "weather5": "多云转阴", 
    "weather6": "阴转晴", 
    "img1": "0", 
    "img2": "1", 
    "img3": "1", 
    "img4": "99", 
    "img5": "1", 
    "img6": "0", 
    "img7": "0", 
    "img8": "1", 
    "img9": "1", 
    "img10": "2", 
    "img11": "2", 
    "img12": "0", 
    "img_single": "0", 
    "img_title1": "晴", 
    "img_title2": "多云", 
    "img_title3": "多云", 
    "img_title4": "多云", 
    "img_title5": "多云", 
    "img_title6": "晴", 
    "img_title7": "晴", 
    "img_title8": "多云", 
    "img_title9": "多云", 
    "img_title10": "阴", 
    "img_title11": "阴", 
    "img_title12": "晴", 
    "img_title_single": "晴", 
    "wind1": "微风", 
    "wind2": "微风", 
    "wind3": "微风", 
    "wind4": "微风", 
    "wind5": "微风", 
    "wind6": "北风4-5级", 
    "fx1": "微风", 
    "fx2": "微风", 
    "fl1": "小于3级", 
    "fl2": "小于3级", 
    "fl3": "小于3级", 
    "fl4": "小于3级", 
    "fl5": "小于3级", 
    "fl6": "4-5级", 
    "index": "较冷", 
    "index_d": "建议着大衣、呢外套加毛衣、卫衣等服装。体弱者宜着厚外套、厚毛衣。因昼夜温差较大,注意增减衣服。", 
    "index48": "冷", 
    "index48_d": "天气冷,建议着棉服、羽绒服、皮夹克加羊毛衫等冬季服装。年老体弱者宜着厚棉衣、冬大衣或厚羽绒服。", 
    "index_uv": "中等", 
    "index48_uv": "弱", 
    "index_xc": "适宜", 
    "index_tr": "适宜", 
    "index_co": "舒适", 
    "st1": "17", 
    "st2": "5", 
    "st3": "17", 
    "st4": "5", 
    "st5": "18", 
    "st6": "6", 
    "index_cl": "适宜", 
    "index_ls": "适宜", 
    "index_ag": "极不易发"
  }
}
        */
          #endregion

        }
      }
      else
      {
        result = "没有获取到该城市的天气,请确定输入了正确的城市名称,如\'北京\'或者\'beijing\'或者\'bj\'";
      }

      //返回
      return result;
    }
    /// <summary>
    /// 内部类:城市
    /// </summary>
    internal class City
    {
      /// <summary>
      /// 编码
      /// </summary>
      public string Code { get; set; }
      /// <summary>
      /// 名称
      /// </summary>
      public string Name { get; set; }
      /// <summary>
      /// 拼音
      /// </summary>
      public string PinYin { get; set; }
      /// <summary>
      /// 拼音首字母
      /// </summary>
      public string FristLetter { get; set; }
    }
  }

 三、源码

这里可是可执行的代码哦。应大家的需求,这里提供全部的源代码。

demo下载

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Valerio 发布了 Mootools
Sep 23 Javascript
jquery.pagination.js 无刷新分页实现步骤分享
May 23 Javascript
基于jquery的点击链接插入链接内容的代码
Jul 31 Javascript
jquery插件tooltipv顶部淡入淡出效果使用示例
Dec 05 Javascript
jquery单行文字向上滚动效果的实现代码
Sep 05 Javascript
js简单实现Select互换数据的方法
Aug 17 Javascript
js实现模拟银行卡账号输入显示效果
Nov 18 Javascript
解析javascript图片懒加载与预加载的分析总结
Oct 27 Javascript
vue 设置路由的登录权限的方法
Jul 03 Javascript
微信网页登录逻辑与实现方法
Apr 29 Javascript
Element-ui el-tree新增和删除节点后如何刷新tree的实例
Aug 31 Javascript
基于vuex实现购物车功能
Jan 10 Vue.js
基于javascript实现按圆形排列DIV元素(三)
Dec 02 #Javascript
js中动态创建json,动态为json添加属性、属性值的实例
Dec 02 #Javascript
bootstrap模态框跳转到当前模板页面 框消失了而背景存在问题的解决方法
Nov 30 #Javascript
js 动态生成json对象、时时更新json对象的方法
Dec 02 #Javascript
详解JavaScript中数组的reduce方法
Dec 02 #Javascript
基于javascript实现按圆形排列DIV元素(二)
Dec 02 #Javascript
微信公众平台开发教程(六)获取个性二维码的实例
Dec 02 #Javascript
You might like
Zend Framework教程之Bootstrap类用法概述
2016/03/14 PHP
PHP预定义变量9大超全局数组用法详解
2016/04/23 PHP
php文件上传原理与实现方法详解
2019/12/20 PHP
键盘 keycode的值 javascript时触发事件时很有用的要素
2009/11/02 Javascript
放弃用你的InnerHTML来输出HTML吧 jQuery Tmpl不详细讲解
2013/04/20 Javascript
JS中怎样判断undefined(比较不错的方法)
2014/03/27 Javascript
js判断手机号运营商的方法
2015/10/23 Javascript
Javascript中神奇的this
2016/01/20 Javascript
JavaScript实现的MD5算法完整实例
2016/02/02 Javascript
JQuery PHP图片在线裁剪实例
2020/07/27 Javascript
JS实现自动阅读单词(有道单词本添加功能)
2016/11/14 Javascript
原生js二级联动效果
2017/06/20 Javascript
微信小程序联网请求的轮播图
2017/07/07 Javascript
JS动态修改网页body的背景色实例代码
2017/10/07 Javascript
JavaScript图片处理与合成总结
2018/03/04 Javascript
Angularjs中的$apply及优化使用详解
2018/07/02 Javascript
JS获取子节点、父节点和兄弟节点的方法实例总结
2018/07/06 Javascript
PHP读取远程txt文档到数组并实现遍历
2020/08/25 Javascript
Vant 在vue-cli 4.x中按需加载操作
2020/11/05 Javascript
详解Django中间件的5种自定义方法
2018/07/26 Python
使用TensorFlow实现SVM
2018/09/06 Python
python3 selenium自动化 下拉框定位的例子
2019/08/23 Python
详解Python高阶函数
2020/08/15 Python
使用Python中tkinter库简单gui界面制作及打包成exe的操作方法(二)
2020/10/12 Python
css3 flex实现div内容水平垂直居中的几种方法
2020/03/27 HTML / CSS
美国内衣第一品牌:Hanes(恒适)
2016/07/29 全球购物
捷克家居装饰及图书音像购物网站:Velký košík
2018/04/16 全球购物
中专生自我鉴定
2013/12/17 职场文书
小学生成长感言
2014/01/30 职场文书
财务管理专业求职信
2014/06/11 职场文书
幼儿园秋季开学寄语
2014/08/02 职场文书
中学生学习保证书
2015/02/26 职场文书
学校重阳节活动总结
2015/03/24 职场文书
2015年人民调解工作总结
2015/05/18 职场文书
python3使用diagrams绘制架构图的步骤
2021/04/08 Python
Python图像处理之图像拼接
2021/04/28 Python