★我要吧★

 找回密码
 注册[Register]
搜索
qq空间相册密码查看为什么登陆后需要激活无法注册?

[交流] QQ表情的发送与接收

[复制链接]
发表于 2016-5-9 15:57:15 | 显示全部楼层 |阅读模式
我想大家对QQ表情一定不会陌生,一个个小头像极大丰富了聊天的乐趣,使得聊天不再是简单的文字叙述,还能够配上喜、怒、哀、乐等表达人物心情的小图片。本文重点要介绍的内容就是如何在微信公众平台使用QQ表情,即在微信公众帐号开发模式下,如何发送QQ表情给用户,以及如何识别用户发来的是QQ表情。
3 B1 A8 w% x0 X5 B* y+ C2 @1 ^& O
) k( a  {/ h& G7 J  h3 Q0 @% m, \QQ表情代码表
7 ?; }3 B' X1 \首先需要明确的是:QQ表情虽然呈现为一张张动态的表情图片,但在微信公众平台的消息接口中却是属于文本消息;也就是说当用户向公众帐号发送QQ表情时,公众帐号后台程序接收到的消息类型MsgType的值为text。只要上面这点能理解了,下面的工作就好开展了。
$ m  [' g' s* D  o3 w对于QQ表情,发送的是文本消息,而呈现出来却是表情图片,那么每一个QQ表情图片一定会有与之相对应的表情代码。下面是我已经整理好的微信公众帐号中使用的QQ表情代码对照表:
( t, x/ Y9 ?, c1 M0 S+ o- O. V  X$ P$ `7 T
& c3 j! H' \' B* J3 K
# z" B5 V2 O5 {4 c
' m3 K( d6 j% _* `. s
; a, |- }. G& x9 V. t; X2 r
0 L( I( t+ E! `
上面一共列出了105个QQ表情,每个表情都给出了与之相对应的文字代码与符号代码(也许这两种叫法并不恰当),至于这两种代码怎么来的以及如何使用,下面马上会讲到。9 O) v& f0 g2 c, {8 }

( a  \0 O# c$ n" ]! c用户向公众帐号发送QQ表情
* P) _: C/ q& m) t) d) F6 @: b在微信上使用公众帐号时,如何发送QQ表情,我想这个很少有人不会的。在输入框旁边有一个笑脸的图片按钮,点击它将会弹出表情选择界面,可选择的表情依次为“QQ表情”、“符号表情”和“动画表情”。当我们点击选择了某个QQ表情后,发现在输入框中会显示该表情的文字代码,这里是用一对中括号引起的,如下图所示:0 F, j" Z- q' C4 X2 u* e
& y4 V+ ^# B. C$ c7 ]9 D
其实,当我们很熟悉要使用QQ表情的文字代码时,也可以直接在输入框中输入表情的代码,而不需要弹出表情选择框。如下图所示:5 z8 @& C" t! i: R! d; b

# ]7 h5 c% [9 `8 {" c, [5 e+ x6 `
从上图可以看出,在输入框中输入“[呲牙]”、“/呲牙”和“/::D”这三种代码的作用一样,都是发送呲牙的QQ表情。这个时候,大家再回过头去看文章最开始的QQ表情代码对照表,就明白是怎么回事了。
  V" M) t* Q4 o; }- R
( g9 l! d) a5 E0 L: _5 D2 c公众帐号向用户发送QQ表情
' S% }0 b0 ]  V4 A/ Z/ o& x9 c与用户向公众帐号发送QQ表情一样,在开发模式下,公众帐号也可以用同样的表情代码(文字代码或符号代码)向用户回复QQ表情。代码片段如下:
4 X1 Q; s9 h% ?! a6 Z8 D4 n# o9 y+ Q8 L; f- [, P# z) c

      D  o7 f! B8 R// 文本消息   
  • if (msgType.equals(MessageUtil.REQ_MESSAGE_TYPE_TEXT)) {   
    $ {8 [5 K/ P0 F- p+ _    // 回复文本消息   
  •     TextMessage textMessage = new TextMessage();   
    1 c% t0 c. p6 Y) C9 b    textMessage.setToUserName(fromUserName);   
  •     textMessage.setFromUserName(toUserName);   ! `: T+ G- c/ m& C  N
        textMessage.setCreateTime(new Date().getTime());   
  •     textMessage.setMsgType(MessageUtil.RESP_MESSAGE_TYPE_TEXT);   & G0 P3 i7 D* x. R
        textMessage.setFuncFlag(0);   
  •     textMessage.setContent("[难过] /难过 /::(");   
    . t8 T6 ^; k/ o      
  •     // 文本消息对象转换成xml字符串   : J* N% B3 |$ s4 z
        respMessage = MessageUtil.textMessageToXml(textMessage);   
  • }   $ C- G+ F" E2 A& t% `/ h% g
$ J) D) a" r" Q& D2 U7 l, h2 {
上面代码片段的作用是:判断发送的消息类型,如果是文本消息(MsgType=text),则回复三个难过的QQ表情给用户。可以看出,不管是用户发给公众帐号,还是公众帐号发给用户,都可以使用QQ表情的文字代码(如:[难过]  /难过)和符号代码(如 /::()。* w! e) Z  r- P8 n3 n# [

' e$ M3 J# L5 M8 \公众帐号识别用户发送的QQ表情- y5 ~4 s% C) _
在掌握了如何发送QQ表情后,我们再来看看公众帐号如何识别用户发送的是QQ表情。这是什么意思呢?当用户向公众帐号发送一个QQ表情,在后台程序中接收到的会是什么值,我们又怎么知道这个值就是一个QQ表情。
, g. i1 }0 ]! S5 _) ]) |5 y) P+ b其实,只要做个简单的测试,比如:将接收到的文本消息输出到日志中(可以用log4j或者System.out.print),不难发现:向公众帐号发送一个QQ表情,在后台程序中接收到的是QQ表情的符号代码。6 o+ k$ ]0 m, p9 o) z
下面是我简单封装的一个方法,通过正则表达式实现的,用于判断用户发送的是否是单个QQ表情。
9 \$ h/ L) w# ?$ t2 s6 x+ y! P8 p* z) D

    2 {; Q4 f* C' S& b2 i9 x9 k2 C/**  
  • * 判断是否是QQ表情  , j: d( e( R( p$ T
    *   
  • * @param content  / O  o0 v/ |; Q+ R0 K  d
    * @return  
  • */   
    & }. v- a, l: m% Ppublic static boolean isQqFace(String content) {   
  •     boolean result = false;   + u/ O$ a% O/ |4 x+ U% L, m% n8 G
       
  •     // 判断QQ表情的正则表达式   
    + o' x" H! Z1 h0 Y0 B    String qqfaceRegex = "/::\\)|/::~|/::B|/::\\||/:8-\\)|/::<|/::$|/::X|/::Z|/::'\\(|/::-\\||/::@|/::P|/::D|/::O|/::\\(|/::\\+|/:--b|/::Q|/::T|/:,@P|/:,@-D|/::d|/:,@o|/::g|/:\\|-\\)|/::!|/::L|/::>|/::,@|/:,@f|/::-S|/:\\?|/:,@x|/:,@@|/::8|/:,@!|/:!!!|/:xx|/:bye|/:wipe|/:dig|/:handclap|/:&-\\(|/:B-\\)|/:<@|/:@>|/::-O|/:>-\\||/:P-\\(|/::'\\||/:X-\\)|/::\\*|/:@x|/:8\\*|/:pd|/:<W>|/:beer|/:basketb|/:oo|/:coffee|/:eat|/:pig|/:rose|/:fade|/:showlove|/:heart|/:break|/:cake|/:li|/:bome|/:kn|/:footb|/:ladybug|/:shit|/:moon|/:sun|/:gift|/:hug|/:strong|/:weak|/:share|/:v|/:@\\)|/:jj|/:@@|/:bad|/:lvu|/:no|/:ok|/:love|/:<L>|/:jump|/:shake|/:<O>|/:circle|/:kotow|/:turn|/:skip|/:oY|/:#-0|/:hiphot|/:kiss|/:<&|/:&>";   
  •     Pattern p = Pattern.compile(qqfaceRegex);   
    0 P5 u. ?5 C# g1 g* R! g    Matcher m = p.matcher(content);   
  •     if (m.matches()) {   
    ' }* S. D. ?0 s' R9 b        result = true;   
  •     }   2 s0 \5 s9 F6 k
        return result;   
  • }   
    , J: j$ |# v7 f) M

/ L8 H$ ?! K5 z  b下面是方法的使用,实现了这样一个简单的功能:用户发什么QQ表情给公众帐号,公众帐号就回复什么QQ表情给用户(xiaoqrobot就是这么做的)。实现代码如下:
& j# X8 h; n  F# K4 n
+ S# _% ]  c) D3 n8 h6 Z

    4 o0 i) O" y0 Z2 S) P& H$ X4 F// 文本消息   
  • if (msgType.equals(MessageUtil.REQ_MESSAGE_TYPE_TEXT)) {   
    " x* N+ a5 w( p( g, R: [' ]    // 文本消息内容   
  •     String content = requestMap.get("Content");   4 V, V* N1 I. @
          
  •     // 判断用户发送的是否是单个QQ表情   
    * P. M. ^' \2 G& H& j    if(XiaoqUtil.isQqFace(content)) {   
  •         // 回复文本消息   
    " @2 H9 O. W) e6 l, G( L- A        TextMessage textMessage = new TextMessage();   
  •         textMessage.setToUserName(fromUserName);   
    - X, ~, _7 D+ u        textMessage.setFromUserName(toUserName);   
  •         textMessage.setCreateTime(new Date().getTime());   + U/ z1 b% g9 Z9 F8 {* C
            textMessage.setMsgType(MessageUtil.RESP_MESSAGE_TYPE_TEXT);   
  •         textMessage.setFuncFlag(0);   
    * S" a2 m& @% G; p& ^        // 用户发什么QQ表情,就返回什么QQ表情   
  •         textMessage.setContent(content);   ! _8 K% |1 s( @6 n% I
               
  •         // 将文本消息对象转换成xml字符串   
    0 ?# b& c1 ?) C# \4 J' }0 x) H        respMessage = MessageUtil.textMessageToXml(textMessage);   
  •     }   
  • }   
    , J; A' a1 ^; w. Q$ @" {" Q

5 y3 `2 N# W2 n7 D* ]  d好了,关于微信公众帐号中QQ表情的使用就介绍这么多。其实,我并不希望初学者上来只是简单拷贝我贴出的代码,实现了自己想要的功能就完事了,更希望初学的朋友能够通过此文章学会一种思考问题和解决问题的方法。
5 P# ]2 T6 x' A  l0 Z
5 M, _! s$ J- |6 L7 B
发表于 2016-7-22 19:11:52 来自手机 | 显示全部楼层
感谢分享。      
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

QQ|手机版|小黑屋|☆我要吧☆ ( 豫ICP备13016831号-1 )

GMT+8, 2024-12-29 19:47 , Processed in 0.064670 second(s), 22 queries .

Powered by abc369 X3.4

© 2001-2023 abc369.

快速回复 返回顶部 返回列表