自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

微信公號開發(fā)之圖文消息全攻略

移動開發(fā)
本篇主要介紹微信公眾帳號開發(fā)中圖文消息的使用,以及圖文消息的幾種表現(xiàn)形式。標(biāo)題取名為“圖文消息全攻略”,這絕對不是標(biāo)題黨,是想借此機(jī)會把大家對圖文消息相關(guān)的問題、疑慮、障礙全部清除掉。

本篇主要介紹微信公眾帳號開發(fā)中圖文消息的使用,以及圖文消息的幾種表現(xiàn)形式。標(biāo)題取名為“圖文消息全攻略”,這絕對不是標(biāo)題黨,是想借此機(jī)會把大家對圖文消息相關(guān)的問題、疑慮、障礙全部清除掉。

圖文消息的主要參數(shù)說明

通過微信官方的消息接口指南,可以看到對圖文消息的參數(shù)介紹,如下圖所示:

從圖中可以了解到:

1)圖文消息的個數(shù)限制為10,也就是圖中ArticleCount的值(圖文消息的個數(shù),限制在10條以內(nèi));

2)對于多圖文消息,***條圖文的圖片顯示為大圖,其他圖文的圖片顯示為小圖;

3)***條圖文的圖片大小建議為640*320,其他圖文的圖片大小建議為80*80;

好了,了解這些,再結(jié)合前面所講的消息及消息處理工具的封裝,想要回復(fù)圖文消息給用戶也就不是什么難事了。

圖文消息的多種表現(xiàn)形式

下面直接通過代碼演示圖文消息最主要的五種表現(xiàn)形式的用法,源代碼如下:

  1. package org.liufeng.course.service; 
  2.  
  3. import java.util.ArrayList; 
  4. import java.util.Date; 
  5. import java.util.List; 
  6. import java.util.Map; 
  7.  
  8. import javax.servlet.http.HttpServletRequest; 
  9.  
  10. import org.liufeng.course.message.resp.Article; 
  11. import org.liufeng.course.message.resp.NewsMessage; 
  12. import org.liufeng.course.message.resp.TextMessage; 
  13. import org.liufeng.course.util.MessageUtil; 
  14.  
  15. /** 
  16.  * 核心服務(wù)類 
  17.  *  
  18.  * @author liufeng 
  19.  * @date 2013-07-25 
  20.  */ 
  21. public class CoreService { 
  22.     /** 
  23.      * 處理微信發(fā)來的請求 
  24.      *  
  25.      * @param request 
  26.      * @return 
  27.      */ 
  28.     public static String processRequest(HttpServletRequest request) { 
  29.         String respMessage = null
  30.         try { 
  31.             // xml請求解析 
  32.             Map<String, String> requestMap = MessageUtil.parseXml(request); 
  33.  
  34.             // 發(fā)送方帳號(open_id) 
  35.             String fromUserName = requestMap.get("FromUserName"); 
  36.             // 公眾帳號 
  37.             String toUserName = requestMap.get("ToUserName"); 
  38.             // 消息類型 
  39.             String msgType = requestMap.get("MsgType"); 
  40.  
  41.             // 默認(rèn)回復(fù)此文本消息 
  42.             TextMessage textMessage = new TextMessage(); 
  43.             textMessage.setToUserName(fromUserName); 
  44.             textMessage.setFromUserName(toUserName); 
  45.             textMessage.setCreateTime(new Date().getTime()); 
  46.             textMessage.setMsgType(MessageUtil.RESP_MESSAGE_TYPE_TEXT); 
  47.             textMessage.setFuncFlag(0); 
  48.             // 由于href屬性值必須用雙引號引起,這與字符串本身的雙引號沖突,所以要轉(zhuǎn)義 
  49.             textMessage.setContent("歡迎訪問<a href=\"http://blog.csdn.net/lyq8479\">柳峰的博客</a>!"); 
  50.             // 將文本消息對象轉(zhuǎn)換成xml字符串 
  51.             respMessage = MessageUtil.textMessageToXml(textMessage); 
  52.  
  53.             // 文本消息 
  54.             if (msgType.equals(MessageUtil.REQ_MESSAGE_TYPE_TEXT)) { 
  55.                 // 接收用戶發(fā)送的文本消息內(nèi)容 
  56.                 String content = requestMap.get("Content"); 
  57.  
  58.                 // 創(chuàng)建圖文消息 
  59.                 NewsMessage newsMessage = new NewsMessage(); 
  60.                 newsMessage.setToUserName(fromUserName); 
  61.                 newsMessage.setFromUserName(toUserName); 
  62.                 newsMessage.setCreateTime(new Date().getTime()); 
  63.                 newsMessage.setMsgType(MessageUtil.RESP_MESSAGE_TYPE_NEWS); 
  64.                 newsMessage.setFuncFlag(0); 
  65.  
  66.                 List<Article> articleList = new ArrayList<Article>(); 
  67.                 // 單圖文消息 
  68.                 if ("1".equals(content)) { 
  69.                     Article article = new Article(); 
  70.                     article.setTitle("微信公眾帳號開發(fā)教程Java版"); 
  71.                     article.setDescription("柳峰,80后,微信公眾帳號開發(fā)經(jīng)驗4個月。為幫助初學(xué)者入門,特推出此系列教程,也希望借此機(jī)會認(rèn)識更多同行!"); 
  72.                     article.setPicUrl("http://0.xiaoqrobot.duapp.com/images/avatar_liufeng.jpg"); 
  73.                     article.setUrl("http://blog.csdn.net/lyq8479"); 
  74.                     articleList.add(article); 
  75.                     // 設(shè)置圖文消息個數(shù) 
  76.                     newsMessage.setArticleCount(articleList.size()); 
  77.                     // 設(shè)置圖文消息包含的圖文集合 
  78.                     newsMessage.setArticles(articleList); 
  79.                     // 將圖文消息對象轉(zhuǎn)換成xml字符串 
  80.                     respMessage = MessageUtil.newsMessageToXml(newsMessage); 
  81.                 } 
  82.                 // 單圖文消息---不含圖片 
  83.                 else if ("2".equals(content)) { 
  84.                     Article article = new Article(); 
  85.                     article.setTitle("微信公眾帳號開發(fā)教程Java版"); 
  86.                     // 圖文消息中可以使用QQ表情、符號表情 
  87.                     article.setDescription("柳峰,80后," + emoji(0x1F6B9
  88.                             + ",微信公眾帳號開發(fā)經(jīng)驗4個月。為幫助初學(xué)者入門,特推出此系列連載教程,也希望借此機(jī)會認(rèn)識更多同行!\n\n目前已推出教程共12篇,包括接口配置、消息封裝、框架搭建、QQ表情發(fā)送、符號表情發(fā)送等。\n\n后期還計劃推出一些實用功能的開發(fā)講解,例如:天氣預(yù)報、周邊搜索、聊天功能等。"); 
  89.                     // 將圖片置為空 
  90.                     article.setPicUrl(""); 
  91.                     article.setUrl("http://blog.csdn.net/lyq8479"); 
  92.                     articleList.add(article); 
  93.                     newsMessage.setArticleCount(articleList.size()); 
  94.                     newsMessage.setArticles(articleList); 
  95.                     respMessage = MessageUtil.newsMessageToXml(newsMessage); 
  96.                 } 
  97.                 // 多圖文消息 
  98.                 else if ("3".equals(content)) { 
  99.                     Article article1 = new Article(); 
  100.                     article1.setTitle("微信公眾帳號開發(fā)教程\n引言"); 
  101.                     article1.setDescription(""); 
  102.                     article1.setPicUrl("http://0.xiaoqrobot.duapp.com/images/avatar_liufeng.jpg"); 
  103.                     article1.setUrl("http://blog.csdn.net/lyq8479/article/details/8937622"); 
  104.  
  105.                     Article article2 = new Article(); 
  106.                     article2.setTitle("第2篇\n微信公眾帳號的類型"); 
  107.                     article2.setDescription(""); 
  108.                     article2.setPicUrl("http://avatar.csdn.net/1/4/A/1_lyq8479.jpg"); 
  109.                     article2.setUrl("http://blog.csdn.net/lyq8479/article/details/8941577"); 
  110.  
  111.                     Article article3 = new Article(); 
  112.                     article3.setTitle("第3篇\n開發(fā)模式啟用及接口配置"); 
  113.                     article3.setDescription(""); 
  114.                     article3.setPicUrl("http://avatar.csdn.net/1/4/A/1_lyq8479.jpg"); 
  115.                     article3.setUrl("http://blog.csdn.net/lyq8479/article/details/8944988"); 
  116.  
  117.                     articleList.add(article1); 
  118.                     articleList.add(article2); 
  119.                     articleList.add(article3); 
  120.                     newsMessage.setArticleCount(articleList.size()); 
  121.                     newsMessage.setArticles(articleList); 
  122.                     respMessage = MessageUtil.newsMessageToXml(newsMessage); 
  123.                 } 
  124.                 // 多圖文消息---首條消息不含圖片 
  125.                 else if ("4".equals(content)) { 
  126.                     Article article1 = new Article(); 
  127.                     article1.setTitle("微信公眾帳號開發(fā)教程Java版"); 
  128.                     article1.setDescription(""); 
  129.                     // 將圖片置為空 
  130.                     article1.setPicUrl(""); 
  131.                     article1.setUrl("http://blog.csdn.net/lyq8479"); 
  132.  
  133.                     Article article2 = new Article(); 
  134.                     article2.setTitle("第4篇\n消息及消息處理工具的封裝"); 
  135.                     article2.setDescription(""); 
  136.                     article2.setPicUrl("http://avatar.csdn.net/1/4/A/1_lyq8479.jpg"); 
  137.                     article2.setUrl("http://blog.csdn.net/lyq8479/article/details/8949088"); 
  138.  
  139.                     Article article3 = new Article(); 
  140.                     article3.setTitle("第5篇\n各種消息的接收與響應(yīng)"); 
  141.                     article3.setDescription(""); 
  142.                     article3.setPicUrl("http://avatar.csdn.net/1/4/A/1_lyq8479.jpg"); 
  143.                     article3.setUrl("http://blog.csdn.net/lyq8479/article/details/8952173"); 
  144.  
  145.                     Article article4 = new Article(); 
  146.                     article4.setTitle("第6篇\n文本消息的內(nèi)容長度限制揭秘"); 
  147.                     article4.setDescription(""); 
  148.                     article4.setPicUrl("http://avatar.csdn.net/1/4/A/1_lyq8479.jpg"); 
  149.                     article4.setUrl("http://blog.csdn.net/lyq8479/article/details/8967824"); 
  150.  
  151.                     articleList.add(article1); 
  152.                     articleList.add(article2); 
  153.                     articleList.add(article3); 
  154.                     articleList.add(article4); 
  155.                     newsMessage.setArticleCount(articleList.size()); 
  156.                     newsMessage.setArticles(articleList); 
  157.                     respMessage = MessageUtil.newsMessageToXml(newsMessage); 
  158.                 } 
  159.                 // 多圖文消息---***一條消息不含圖片 
  160.                 else if ("5".equals(content)) { 
  161.                     Article article1 = new Article(); 
  162.                     article1.setTitle("第7篇\n文本消息中換行符的使用"); 
  163.                     article1.setDescription(""); 
  164.                     article1.setPicUrl("http://0.xiaoqrobot.duapp.com/images/avatar_liufeng.jpg"); 
  165.                     article1.setUrl("http://blog.csdn.net/lyq8479/article/details/9141467"); 
  166.  
  167.                     Article article2 = new Article(); 
  168.                     article2.setTitle("第8篇\n文本消息中使用網(wǎng)頁超鏈接"); 
  169.                     article2.setDescription(""); 
  170.                     article2.setPicUrl("http://avatar.csdn.net/1/4/A/1_lyq8479.jpg"); 
  171.                     article2.setUrl("http://blog.csdn.net/lyq8479/article/details/9157455"); 
  172.  
  173.                     Article article3 = new Article(); 
  174.                     article3.setTitle("如果覺得文章對你有所幫助,請通過博客留言或關(guān)注微信公眾帳號xiaoqrobot來支持柳峰!"); 
  175.                     article3.setDescription(""); 
  176.                     // 將圖片置為空 
  177.                     article3.setPicUrl(""); 
  178.                     article3.setUrl("http://blog.csdn.net/lyq8479"); 
  179.  
  180.                     articleList.add(article1); 
  181.                     articleList.add(article2); 
  182.                     articleList.add(article3); 
  183.                     newsMessage.setArticleCount(articleList.size()); 
  184.                     newsMessage.setArticles(articleList); 
  185.                     respMessage = MessageUtil.newsMessageToXml(newsMessage); 
  186.                 } 
  187.             } 
  188.         } catch (Exception e) { 
  189.             e.printStackTrace(); 
  190.         } 
  191.         return respMessage; 
  192.     } 
  193.  
  194.     /** 
  195.      * emoji表情轉(zhuǎn)換(hex -> utf-16) 
  196.      *  
  197.      * @param hexEmoji 
  198.      * @return 
  199.      */ 
  200.     public static String emoji(int hexEmoji) { 
  201.         return String.valueOf(Character.toChars(hexEmoji)); 
  202.     } 

上面代碼實現(xiàn)的功能是當(dāng)用戶發(fā)送數(shù)字1-5時,分別回復(fù)五種不同表現(xiàn)形式的圖文消息給用戶,如下:

a)用戶發(fā)送1,回復(fù)單圖文消息。參考代碼68~81行,運行效果如下:

b)用戶發(fā)送2,回復(fù)單圖文消息---不含圖片。參考代碼82~96行,運行效果如下:

說明:圖文消息的標(biāo)題、描述是可以包含QQ表情、符號表情的。

c)用戶發(fā)送3,回復(fù)多圖文消息。參考代碼97~123行,運行效果如下:

 

說明:對于多圖文消息,描述不會被顯示,可以在標(biāo)題使用換行符,使得顯示更加美觀。

d)用戶發(fā)送4,回復(fù)多圖文消息---首條消息不含圖片。參考代碼124~158行,運行效果如下:

 

e)用戶發(fā)送5,回復(fù)多圖文消息---***一條消息不含圖片。參考代碼159~186行,運行效果如下:

 

可以看出,圖文消息有著豐富的內(nèi)容及多樣化的表現(xiàn)形式,希望大家能夠根據(jù)各自的特點及實際使用需要,合理地運用。

***,根據(jù)實踐經(jīng)驗,我對圖文消息做一個使用總結(jié):

1)一定要給圖文消息的Url屬性賦值。不管是單圖文,還是多圖文,或者是不含圖片的圖文,都有可能會被用戶點擊。如果Url為空,用戶點擊后將會打開一個空白頁面,這給用戶的體驗是非常差的;

2)只有單圖文的描述才會顯示,多圖文的描述不會被顯示;

3)圖文消息的標(biāo)題、描述中可以使用QQ表情和符號表情。合理地運用表情符號,會使得消息更加生動;

4)圖文消息的標(biāo)題、描述中可以使用換行符。合理地使用換行符,會使得內(nèi)容結(jié)構(gòu)更加清晰;

5)圖文消息的標(biāo)題、描述中不支持超文本鏈接(html的<a>標(biāo)簽)。不只是技術(shù)上實現(xiàn)不了,就連邏輯上也說不通,因為一條圖文消息的任何位置被點擊,都將調(diào)用微信內(nèi)置的瀏覽器打開Url,如果標(biāo)題、描述里再放幾個超鏈接,不知道點擊該打開哪個頁面。真搞不懂為什么有好幾個同學(xué)都在問這個問題,難道設(shè)計成多圖文不好嗎?

6)圖文消息的鏈接、圖片鏈接可以使用外部域名下的資源,如本例中:柳峰的頭像、博文的鏈接,都是指向CSDN網(wǎng)站的資源。在網(wǎng)上,甚至是微信官方交流群里,認(rèn)為圖文消息的Url、PicUrl不可以使用外鏈的大有人在,不知道這謠言從哪開始的,實踐是檢驗真理的唯一標(biāo)準(zhǔn)!

7)使用指定大小的圖片。***條圖文的圖片大小建議為640*320,其他圖文的圖片大小建議為80*80。如果使用的圖片太大,加載慢,而且耗流量;如果使用的圖片太小,顯示后會被拉伸,失真了很難看。

8)每條圖文消息的圖文建議控制在1-4條。這樣在絕大多數(shù)終端上一屏能夠顯示完,用戶掃一眼就能大概了解消息的主要內(nèi)容,這樣最有可能促使用戶去點擊并閱讀。

責(zé)任編輯:徐川 來源: blog
相關(guān)推薦

2013-11-13 00:51:22

微信微信公號微信公眾賬號

2013-11-13 00:14:16

微信微信公號微信公眾賬號

2013-11-12 23:32:53

微信公號微信公眾賬號

2013-11-13 01:25:33

微信微信公號微信公眾賬號

2013-11-13 00:20:01

微信微信公號微信公眾賬號

2014-09-24 11:32:21

微信企業(yè)號開發(fā)

2017-07-06 17:39:53

JavaScript開發(fā)程序員

2014-09-24 11:11:08

微信企業(yè)號開發(fā)

2009-07-04 11:26:12

unix應(yīng)急安全攻略

2009-07-17 17:43:49

Jruby開發(fā)Web

2024-10-25 15:25:42

2013-11-13 01:19:18

2024-05-07 09:01:21

Queue 模塊Python線程安全隊列

2013-06-08 11:13:00

Android開發(fā)XML解析

2013-04-15 10:48:16

Xcode ARC詳解iOS ARC使用

2011-08-03 15:31:40

號販子網(wǎng)上預(yù)約掛號

2010-04-23 14:04:23

Oracle日期操作

2011-04-22 15:42:48

Windows 7

2014-03-19 17:22:33

2009-12-14 14:32:38

動態(tài)路由配置
點贊
收藏

51CTO技術(shù)棧公眾號