微信公众号开发之回复图文消息(被动)

目录

(一)微信公众号开发之VS远程调试
(二)微信公众号开发之基础梳理
(三)微信公众号开发之自动消息回复和自定义菜单
(四)微信公众号开发之网页授权获取用户基本信息
(五)微信公众号开发之网页中及时获取当前用户Openid及注意事项
(六)微信公众号开发之扫码支付
(七)微信公众号开发之公众号支付
(八)微信公众号开发之现金红包
(九)微信公众号开发之回复图文消息(被动)

 

题记:

  .NET Core 经过几年的发展,已经可以说是遍地开花了,现在如果还不展开.NET Core探索之路,那未免也太有点落后于.NET的时代潮流了.

 

前几篇已经提及到了关注和回复消息事件,但此前都局限于回复文本消息。那么,如果有个需求是,用户发送特定字符,如何回复特定的图文消息给用户呢?

首先我们来看看实现后的效果如下:

实现过程

 

回复图片消息

我们先看一下 回复图文消息的XML字符格式

<xml>
  <
ToUserName><![CDATA[toUser] ]></ToUserName>
  <
FromUserName>< ![CDATA[fromUser] ]></FromUserName>
  <
CreateTime>12345678</CreateTime>
  <
MsgType><![CDATA[image] ]></MsgType>
  <
Image><MediaId><![CDATA[media_id] ]></MediaId></Image>
</
xml>

根据这个XML格式,我们很清楚已经知道这个地方需要用到几个必要的参数,包括:OpenID,微信号、创建时间、封面图片以及Mediald这些。

我们这个是在.NET Core2.1上实现的,这里稍微说明下,此前我们在.NET 4.5中使用的一般处理程序是这样写的:

public void ProcessRequest(HttpContext context)
{
      //TODO      
}

ASP.NET Core中提供了一个IHttpContextAccessor接口,HttpContextAccessor 默认实现了它简化了访问HttpContext。

它必须在程序启动时在ConfigureServices中注册,这样在程序中就能获取到HttpContextAccessor,并用来访问HttpContext。

services.AddSingleton<IHttpContextAccessor, HttpContextAccessor>();

然后我们在控制器中注入进来

        private readonly IHttpContextAccessor _accessor;
        public HandlerController(IHttpContextAccessor accessor)
        {
            _accessor = accessor;
        }
        [Route("ProcessRequest")]
        public void ProcessRequest()
        {
            var context = _accessor.HttpContext;
            context.Response.ContentType = "text/plain";
            string responseMsg = Response(context.Request);
            context.Response.Clear();
            context.Response.ContentType = "UTF-8";
            context.Response.WriteAsync(responseMsg);
        }

好了,前面是一些铺垫,代码部分和之前.NET 相差无几,玩.NET Core 记住一句话:无处不在的依赖注入。

这里,我们提前将一些用到的关键词以及上面提到的必要参数放到appsetting.json配置中,方面后面修改。

 "new_images_messages": {
    "keyword": "触发的关键字",
    "validTime": "2018-12-28",
    "title": "文章标题",
    "description": "描述",
    "picUrl": "图片url",
    "url": "图文消息的url"
  }

另外,我这里采用读取配置的方式封装了一层,在Startup中DI进IConfiguration 接口

注:需要引入

using Microsoft.Extensions.Configuration;
      public Startup(IConfiguration configuration)
        {
            Configuration = configuration;
        }

        public IConfiguration Configuration { get; }

 

 然后新建一个ConfigurationKeys 类,专门存放配置文件中不同类型的数据值:

        public static string NEW_IMAGES_MESSAGES_TITLE = "new_images_messages:title";

        public static string NEW_IMAGES_MESSAGES_DES = "new_images_messages:description";

        public static string NEW_IMAGES_MESSAGES_PIC = "new_images_messages:picUrl";

        public static string NEW_IMAGES_MESSAGES_URL = "new_images_messages:url";

        public static string NEW_IMAGES_MESSAGES_KEYWORD = "new_images_messages:keyword";

        public static string NEW_IMAGES_MESSAGES_VALIDTIME = "new_images_messages:validTime";

使用时首先在控制器中注入配置接口

private readonly IConfiguration _config;
public EventHandler(IConfiguration config)
{
  _config = config;
}

与发过来消息做对比

//判断接收到的文本消息是否是配置文件中的触发关键词  
if (content == _config[ConfigurationKeys.NEW_IMAGES_MESSAGES_KEYWORD])
{
      _logger.LogInformation("答复图文消息");
      response =ReArticle(tm.FromUserName, tm.ToUserName);
}
  public string ReArticle(string fromUserName, string toUserName)
  {
      var title = _config[ConfigurationKeys.NEW_IMAGES_MESSAGES_TITLE];
      var description = _config[ConfigurationKeys.NEW_IMAGES_MESSAGES_DES];
      var picUrl = _config[ConfigurationKeys.NEW_IMAGES_MESSAGES_PIC];
      var url = _config[ConfigurationKeys.NEW_IMAGES_MESSAGES_URL];
      return new NewsMessage().Template(fromUserName, toUserName, title, description, picUrl, url);
  }

这里需要将模板提前配置好,所以这里新建了一个Template方法

public string Template(string fromUserName, string toUserName, string title, string description, string picUrl, string url)
{
            string xml = "<xml><ToUserName><![CDATA[" + fromUserName + "]]></ToUserName><FromUserName><![CDATA[" + toUserName + "]]></FromUserName>";
            xml += "<CreateTime>" + FileUtility.DateTimeToUnixTimestamp(DateTime.Now) + "</CreateTime>";
            xml +="<MsgType><![CDATA[news]]></MsgType><Content><![CDATA[]]></Content><ArticleCount>1</ArticleCount><Articles>";
            xml += "<item><Title><![CDATA[" + title + "]]></Title><Description><![CDATA[" + description +"]]></Description><PicUrl><![CDATA[" + picUrl + "]]></PicUrl><Url><![CDATA[" + url +"]]></Url></item>";
            xml += "</Articles><FuncFlag>0</FuncFlag></xml>";
            return xml;
}

 

 上述的时间转换方法

public static long DateTimeToUnixTimestamp(DateTime dateTime)
{
    var start = new DateTime(1970, 1, 1, 0, 0, 0, dateTime.Kind);
    return Convert.ToInt64((dateTime - start).TotalSeconds);
}

 

 至此,已经全部实现,那如果项目已经上线,需要增加这个功能项,但是又不能破坏现有服务器,如何进行调试呢,可以借助微信的测试号,用于在线调试公众号。

 地址:微信测试号

进入测试号里面,有appID,appsecret我们需要将这两个信息替换本地的TokenContext中的值。然后URL可以借助花生壳等内网穿透的工具 映射到本地 进行开发调试。

整体做完就可以实现开始的展示图的效果了。

       End

转载于:https://www.cnblogs.com/zhangxiaoyong/p/10161188.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Java微信公众号定时发送消息模板通常分为两部分: 第一部分是实现Wechat API与Java后端的通信。Wechat API是微信提供的接口,可以让我们通过Java代码与微信公众号进行交互。具体来说,我们需要在Java中通过HTTP或HTTPS协议发送请求,获取微信公众号的access_token,再通过access_token来进行后续的操作,例如:获取用户的消息、发送消息、创建菜单等等。Java中可以使用Apache HttpClient或OkHttp等库来发送HTTP请求,拿到接口返回的JSON数据。 第二部分是实现定时发送消息。Java中可以使用Quartz框架用于实现定时任务。Quartz是一个开源的作业调度框架,可以用于在指定时间执行任务。我们可以利用Quartz提供的API,创建一个定时任务,定期调用我们的后端Java代码发送微信公众号消息。在定时任务的实现中,我们需要考虑任务的频率、执行时间、失败策略等问题。 当以上两部分都实现以后,我们就可以在Java后端实现微信公众号定时发送消息的功能了。具体来说,我们需要将发送消息的代码放到定时任务中,指定要发送的消息内容,以及要发送给的用户。然后启动定时任务即可,Java后端会自动按照设定的规则发送微信公众号消息。 值得注意的是,微信官方文档要求所有公众号对接的应用都必须是官方认证的,所以在实现这个功能之前,我们需要先将我们的应用向微信官方申请认证,获得相应的API调用权限。 ### 回答2: Java微信公众号定时发送消息模板是一种利用Java语言实现的微信公众平台的定时发送消息模板。该模板可以帮助微信公众号上的管理员在指定时间点自动发送指定的消息,从而提高工作效率和用户体验。 实现Java微信公众号定时发送消息模板的关键是使用了微信公众平台提供的接口。这些接口可以通过Java语言进行调用,从而实现向微信公众号发送消息、设置菜单、自动回复、素材管理、用户管理等功能。在定时发送消息模板中,我们需要利用这些接口设置定时任务,并在指定时间点调用接口发送消息。 具体实现过程如下: 1. 首先需要在微信公众平台上申请开发者账号,并获取相应的开发者ID、开发者密码和Token。 2. 在Java中使用微信公众平台提供的SDK调用相关接口,实现发送消息、设置菜单、自动回复等功能。 3. 利用Java中的定时任务框架,如Quartz、Spring定时任务等,在指定的时间点调用相应的微信接口实现定时发送消息。 4. 利用Java中的模板功能,以标准化的格式组织需要发送的消息内容,使消息具有可读性和易管理性。 需要注意的是,为了避免被微信公众平台封禁账号,我们需要遵循微信公众平台的相关规定,比如定时发送的消息不能含有敏感词汇、不能频繁发送等。另外,定时发送的频次也需要控制在一定范围内,避免对用户造成困扰。 总之,Java微信公众号定时发送消息模板是一种非常实用的工具,可以帮助管理员提高工作效率和用户体验。但实现过程需要注意一些细节和规范,确保操作的合法性和安全性。 ### 回答3: Java微信公众号定时发送消息模板是指利用Java编程语言实现微信公众号定时发送消息功能,并且提供了消息模板方便开发者进行二次开发。这个模板主要包含以下几个方面: 一、微信公众号接入 首先,需要在微信公众号后台注册并获取开发者ID和开发者密钥,然后使用Java框架接入微信公众号的开放平台。接入之后,就可以使用微信公众号提供的API实现发送消息功能。 二、定时任务 接下来,需要编写Java代码实现定时任务功能。Java提供了Timer和TimerTask类可以很方便地实现定时任务功能。开发者可以选择设定每日,周,月等不同的定时任务。 三、发送消息 定时任务设置好后,需要编写Java代码实现发送消息的功能。这个功能可以通过调用微信公众号提供的API来实现。消息的发送可以以文本消息图文消息,视频消息等不同的形式呈现。 四、编写消息模板 最后,为了让开发者方便使用,我们需要编写一个消息模板来进行二次开发消息模板可以包含以下几个方面:微信公众号接入的配置信息、定时任务的配置信息、发送消息的配置信息,以及发送消息的实现方法等。这个模板可以让开发者快速地实现微信公众号定时发送消息的功能。 通过这个模板,开发者可以很方便地搭建起微信公众号定时发送消息的系统,从而可以提高服务的质量和用户体验。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值