Java与微信不得不说的故事——实现图文消息的发送

  上面已经实现了消息的接收和发送,下面开始整个图文消息。这个才是大头吧,毕竟公众号还是得靠点图才能留住观众。hey~左边的观众。hey~右边的观众。可惜菜鸟的博文没有观众。还是给大家贴下柳峰老师的博文吧,毕竟又是参照他的做的。博文连接贴到最下面了。哈哈,想打我吗?!

  其实,看完柳峰老师的博客,应该就感觉到很简单了吧,哈哈,又想打我是吗?!

  首先先看下微信开发文档中图文消息中必备的属性都有啥。

参数 是否必须 说明
ToUserName 接收方帐号(收到的OpenID)
FromUserName 开发者微信号
CreateTime 消息创建时间 (整型)
MsgType news
ArticleCount 图文消息个数,限制为10条以内
Articles 多条图文消息信息,默认第一个item为大图,注意,如果图文数超过10,则将会无响应
Title 图文消息标题
Description 图文消息描述
PicUrl 图片链接,支持JPG、PNG格式,较好的效果为大图360*200,小图200*200
Url 点击图文消息跳转链接

  

可以看到,比起本文消息,增加的属性有:Aritcles、AticleCount、Title、Description、PicUrl、Url。

<xml>

<ToUserName><![CDATA[toUser]]></ToUserName>
<FromUserName><![CDATA[fromUser]]></FromUserName>
<CreateTime>12345678</CreateTime>
<MsgType><![CDATA[news]]></MsgType>
<ArticleCount>2</ArticleCount>
<Articles>
<item>
<Title><![CDATA[title1]]></Title>
<Description><![CDATA[description1]]></Description>
<PicUrl><![CDATA[picurl]]></PicUrl>
<Url><![CDATA[url]]></Url>
</item>
<item>
<Title><![CDATA[title]]></Title>
<Description><![CDATA[description]]></Description>
<PicUrl><![CDATA[picurl]]></PicUrl>
<Url><![CDATA[url]]></Url>
</item>
</Articles>
</xml> 

  根据以上,我们可以建立与图文消息有关的实体类。NewsMessage.java 和 Article.java。

  

package org.liufeng.course.message.resp;

import java.util.List;

/**
 * 文本消息
 *
 * @author liufeng
 * @date 2013-09-11
 */
public class NewsMessage extends BaseMessage {
	// 图文消息个数,限制为10条以内
	private int ArticleCount;
	// 多条图文消息信息,默认第一个item为大图
	private List<Article> Articles;

	public int getArticleCount() {
		return ArticleCount;
	}

	public void setArticleCount(int articleCount) {
		ArticleCount = articleCount;
	}

	public List<Article> getArticles() {
		return Articles;
	}

	public void setArticles(List<Article> articles) {
		Articles = articles;
	}
}

  

package org.liufeng.course.message.resp;

/**
 * 图文model
 *
 * @author liufeng
 * @date 2013-09-11
 */
public class Article {
	// 图文消息名称
	private String Title;
	// 图文消息描述
	private String Description;
	// 图片链接,支持JPG、PNG格式,较好的效果为大图640*320,小图80*80
	private String PicUrl;
	// 点击图文消息跳转链接
	private String Url;

	public String getTitle() {
		return Title;
	}

	public void setTitle(String title) {
		Title = title;
	}

	public String getDescription() {
		return null == Description ? "" : Description;
	}

	public void setDescription(String description) {
		Description = description;
	}

	public String getPicUrl() {
		return null == PicUrl ? "" : PicUrl;
	}

	public void setPicUrl(String picUrl) {
		PicUrl = picUrl;
	}

	public String getUrl() {
		return null == Url ? "" : Url;
	}

	public void setUrl(String url) {
		Url = url;
	}
}

  有了上述实体类,可以在上一节的coreService中继续添加回复图文消息的代码,我写的如下:

// 单图文消息
				if ("1".equals(content)) {

					// 创建图文消息(回复用)
					NewsMessage newsMessage = new NewsMessage();
					newsMessage.setToUserName(fromUserName);
					newsMessage.setFromUserName(toUserName);
					newsMessage.setCreateTime(new Date().getTime());
					newsMessage.setMsgType(MessageUtil.RESP_MESSAGE_TYPE_NEWS);

					List<Article> articleList = new ArrayList<Article>();

					Article article = new Article();
					article.setTitle("haojiahong的博客");
					article.setDescription("我不是高手,我不会武功。"+emoji(0x1F61D));
					article.setPicUrl("http://pic.cnblogs.com/avatar/466668/20150530175722.png");
					article.setUrl("http://www.cnblogs.com/haojiahong");
					articleList.add(article);
					// 设置图文消息个数
					newsMessage.setArticleCount(articleList.size());
					// 设置图文消息包含的图文集合
					newsMessage.setArticles(articleList);
					// 将图文消息对象转换成xml字符串
					respMessage = MessageUtil.messageToXml(newsMessage);
				}
			}

  当微信用户端输入“1”的时候,会回复一条图文消息。如下图所示:

  此图是是使用微信在线调试器得到的结果,其中图片和符号表情没有显示出来,不过在手机上测试时可以正常显示,所以可以大可放心哟~

  

  加一点题外话:

  这是菜单列,一开始最后提示回复“?”的时候给重新显示此菜单。可以?有中文和英文两种形式,手机默认的是中文,而写程序的时候习惯上用英文,所以,这种情况最好还是能避免就避免了。

  代码如下:

/**
	 * 主菜单
	 * @return
	 */
	public static String getMainMenu() {
	    StringBuffer buffer = new StringBuffer();
	    buffer.append("您好,我是(●—●),请回复数字选择服务:").append("\n\n");
	    buffer.append("1  我的博客").append("\n");
	    buffer.append("2  公交查询").append("\n");
	    buffer.append("3  周边搜索").append("\n");
	    buffer.append("4  歌曲点播").append("\n");
	    buffer.append("5  经典游戏").append("\n");
	    buffer.append("6  美女电台").append("\n");
	    buffer.append("7  人脸识别").append("\n");
	    buffer.append("8  聊天唠嗑").append("\n\n");
	    buffer.append("回复“0”显示此帮助菜单");
	    return buffer.toString();
	}

  

  嘿嘿,这里有柳峰老师的博客,很经典哟,别忘记点了呀,哈哈哈!

  柳峰老师图文消息攻略博客地址:http://blog.csdn.net/lyq8479/article/details/9393195

时间: 2024-10-02 23:26:21

Java与微信不得不说的故事——实现图文消息的发送的相关文章

Java与微信不得不说的故事——消息的接收与发送

Java与微信的知识也是自学阶段,代码都是参照柳峰老师的.具体可以查看此博:http://blog.csdn.net/lyq8479/article/details/8949088. 下面说一下消息的接收和发送吧. 消息的推送:当普通用户向公众账号发送消息是,微信服务器将POST消息到填写的URL上.消息是一个xml包. 消息的回复:对于每一个POST请求,开发者在响应包中返回特定的xml包,对消息进行响应. 所以,需要有解析xml包和包装xml包的方法.于是,引进了dom4j.jar和xstr

Java与微信不得不说的故事——实现微信公众平台与sae服务器的对接

又颓废了些日子,说好认真来半年的,那就接着来啊,公司的easyUI平台慢慢开始明白了,可是最近bug太多了,只能找时间在研究了,平时无聊看见了了java微信平台开发,感觉有点意思呀,自己也来试试,不过又得求教博客园里面的大神们了,现在开始研究. 一开始无聊的时候,自己在新浪云服务器注册了一个账号,可以建立一些应用在上面,微信平台也是可以的.于是自己照着微信官方的例子,建立了微信公众平台与新浪云服务器的接口,成功了.不过官方是用PHP语言写的(也许PHP是世界上最好的语言).可是作为一个Javae

【玩转微信公众平台之十】 图文消息回复讲解

讲解目录 <保卫战:异形入侵>游戏开发    1 第一讲   游戏演示和资源的介绍    1 第二讲  "异形"怪物的实现    1 第三讲  "异形"怪物生命值的体现    9 第四讲  "异形"怪物死后处理    12 第五讲  玩家的制作    15 第六讲  玩家的行走控制(键盘)    16 第七讲  武器的切换(鼠标)     16 第八讲  摄像头的变化(鼠标)    19 第九讲  子弹预制体和特效的制作    20

微信公众平台改版 终于支持图文消息链接了

微信公众平台发布更新了,终于允许在图文消息中加入跳转链接,但仅针对开通了微信支付的公众号,开通微信支付应该不算难,大伙赶紧去开通吧.本次微信公众平台改版升级还新增开发者中心.界面扁平化.改善用户体验等,以下是微信团队的公告: 微信公众平台改版说明 1. 允许在图文消息中加入跳转链接 对开通了微信支付的公众号,允许在图文消息中加入跳转链接 2. 将服务中心升级为功能插件 每个公众号都可以在添加功能插件页面,看到该帐号能申请的所有功能. 3. 商户功能改名为微信支付 为便于企业或商家认知及申请微信支

如何用微信编辑器排版出美观的图文消息

更多:http://www.webyang.net/Html/web/article_148.html 很多时候看到图文并茂.错落有致.优雅无比的图文消息,大多数不会HTML代码的小编总会羡慕不已.那有没有傻瓜式的编辑器呢? 也许另外一些人想必都知道微信编辑器了,很多运营微信公众平台的朋友都曾经对图文编辑排版都琢磨过,有人还有很多不知道微信编辑器怎么用,因此,本博主将教大家如何使用微信编辑器,了解微信编辑器更改网站的各个板块作用,让您的图文变得更有特色. 浏览器打开www.webyang.net

[037] 微信公众帐号开发教程第13篇-图文消息全攻略

引言及内容概要 已经有几位读者抱怨“柳峰只用到文本消息作为示例,从来不提图文消息,都不知道图文消息该如何使用”,好吧,我错了,原本以为把基础API封装完.框架搭建好,再给出一个文本消息的使用示例,大家就能够照猫画虎的,或许是因为我的绘画功底太差,画出的那只猫本来就不像猫吧…… 本篇主要介绍微信公众帐号开发中图文消息的使用,以及图文消息的几种表现形式.标题取名为“图文消息全攻略”,这绝对不是标题党,是想借此机会把大家对图文消息相关的问题.疑虑.障碍全部清除掉. 图文消息的主要参数说明 通过微信官方

微信公众平台开发(97) 图文消息

关键字:微信公众平台 开发模式 图文消息作者:方倍工作室原文:http://www.cnblogs.com/txw1958/p/weixin-97-news.html 在这篇微信公众平台开发教程中,我们将介绍如何灵活的使用图文消息功能.我们将只介绍被动回复消息中的图文消息,发送客服消息及高级群发消息接口的发送的图文消息与本文介绍的图文消息的各情况基本一致. 本文分为以下四个部分: 图文消息的定义 图文消息的实现 图文消息的类型 图文消息的回复 一.图文消息的定义 在微信公众平台消息中,发送被动响

后悔药来了?发出去的微信图文消息删除后不再显示

之前微信公众平台上群发的图文消息一旦发出去后就不能再改了,假使发送成功后发现有错别字你马上到后台修改了,订阅用户看到的还是那个错别字,即使改了也没用,ytkah就吃过这个亏.现在公众平台貌似有更新了,发出去的微信图文消息你删除后不再显示,提示“该内容已被发布者删除”. 后悔药来了?微信公众平台图文消息群发成功后删除订阅用户看不到内容.修改文字和段落是否成功还没测试,如果哪位公众号运营者已完成过的,欢迎发送截图给我们哈,不胜感激!

微信公众号 发送图文消息

介绍被动回复消息中的图文消息,发送客服消息及高级群发消息接口的发送的图文消息与本文介绍的图文消息的各情况基本一致. 本文分为以下四个部分: 图文消息的定义 图文消息的实现 图文消息的类型 图文消息的回复 一.图文消息的定义 在微信公众平台消息中,发送被动响应消息中的图文消息的XML结构如下所示. <xml> <ToUserName><![CDATA[toUser]]></ToUserName> <FromUserName><![CDATA[