• 微信开发详细教程


    一、 准备工作

    a) 账号

    1. SAE上面注册一个账号
    2. 在微信公众号开发平台地址 https://mp.weixin.qq.com  注册一个微信公众号。

    注意:1、个人只能申请到个人类型的订阅号。

    2、微信公众号认证需要300大洋。

    1. 申请公众号测试号地址

    http://mp.weixin.qq.com/debug/cgi-bin/sandboxinfo?action=showinfo&t=sandbox/index

    二、 微信公众账号介绍

     

     

    服务号、订阅号、企业号的介绍(区别) 

    1、订阅号:主要偏于为用户传达资讯(类似报纸杂志),认证前后都是每天只可以群发一条消息;

    2、服务号:主要偏于服务交互(类似银行,114,提供服务查询),认证前后都是每个月可群发4条消息;

    3、企业号:主要用于公司内部通讯使用,需要先有成员的通讯信息验证才可以关注成功企业号;

    温馨提示:

    1、如果想简单的发送消息,达到宣传效果,建议可选择订阅号;

    2、如果想进行商品销售,进行商品售卖,建议可申请服务号;

    3、如果想用来管理内部企业员工、团队,对内使用,可申请企业号。

     

    三、 微信数据收发原理以及消息数据格式

     

    31 开发者模式成为开发者时的消息校验原理

    开发者提交信息后,微信服务器将发送GET请求到填写的服务器地址URL上,并且带上四个参数(signaturetimestampnonceechostr),开发者通过对签名(signature)的检验,来判断此条信息的真实性。

    验证成功之后,开发者接受用户消息的时候,微信也都会带上前面三个参数(signaturetimestampnonce)访问开发者设置的URL,开发者依然通过签名的校验判断消息的真实性。

    加密/校验流程如下:

    1. tokentimestampnonce三个参数进行字典序排序

    2. 将三个参数字符串拼接成一个字符串进行sha1加密

    3. 开发者获得加密后的字符串可与signature对比,标识该请求来源于微信

    32 成为开发者后消息收发的原理

    微信消息收发原理图:

     

    其实,我们需要做的事情,就是对HTTP请求,做出响应。也就是拿到微信服务器给我们的数据,然后处理后再返回去。

    上图的消息收发过程是这样的:用户用手机发送一个?给微信公众号,微信服务器接受到? 然后组装一个消息发送给我们自己的服务器,我们的服务器回复一个时间,并且将时间也按照一定的规则组装,回复给公众号,公众号所在的服务器再回复给用户。

    四、 接入指南

    接入微信公众号平台开发,需要按照如下步骤:

    1、 填写服务器配置

    2、 验证服务器地址的有效性

    3、 依据接口文档实现业务逻辑

    第一步:填写服务器配置

    进入微信公众平台https://mp.weixin.qq.com

    在左侧列表中最下方,找到基本配置,点击进入

     

    点击启用,如果编辑模式开启了。那就先把编辑模式关闭。

     

    点击“修改配置”按钮,按照要求填写。

    参数说明:

    其中URL是开发者用来接收微信消息和事件的接口URL

    Token是开发者任意填写的,但是填写的要与代码中的一致。Token是用作签名(填写的Token会和接口URL中包含的Token进行对比,从而验证安全性),Token是为了用来验证发送我们的信息是否来自微信服务器。

    第二步:验证服务器地址的有效性

    开发者提供信息后,微信服务器将发送GET请求到填写的服务器地址URL上,GET请求携带四个参数:

    开发者通过检验signature对请求进行校验。若确认此次GET请求来自微信服务器,需要原样返回echostr参数的内容。这样就接入成功了,否则接入失败。

    接入的代码如下:

    //获得参数 signature nonce token timestamp echostr

    $nonce     = $_GET['nonce'];

    $token     = 'imooc';

    $timestamp = $_GET['timestamp'];

    $echostr   = $_GET['echostr'];

    $signature = $_GET['signature'];

    //第一步:形成数组,然后按字典序排序

    $array = array();

    $tmpArr= array($nonce, $timestamp, $token);

    sort($tmpArr,SORT_STRING);

    //第二步:拼接成字符串,sha1加密 ,然后与signature进行校验

    $str = sha1( implode( $tmpArr ) );

    //第三步:获得加密后的字符串与signature对比

    if( $str  == $signature && $echostr ){

    //第一次接入weixin api接口的时候

    echo  $echostr;

    exit;

    }

    第三部:依据接口文档实现业务逻辑

    验证URL有效性后即接入生效,成为开发者。

    经历过第一次验证后,此后用户每次向公众号发送消息、或者产生自定义菜单点击事件时,开发者填写的服务器配置URL将得到微信服务器推送过来的消息和事件,然后开发者可以依据自身业务逻辑进行相应,例如回复消息等。

    其他需要知道的:

    1、 用户向公众号发送消息时,公众号收到的消息发送者是一个OpenID每个用户对每个公众号有一个唯一的OpenID

    2、 微信公众号接口只支持80端口

    五、 接受普通消息

    当普通微信用户向微信公众账号发消息时,微信服务器将POST消息的XML数据发送到我们自己的服务器上,也就是我们在微信公众平台填写的URL

     

    普通消息有:文本消息、图片消息、语言消息、视频消息、地理位置消息。

    接受文本消息的XML格式

    <xml>

     <ToUserName><![CDATA[toUser]]></ToUserName>

     <FromUserName><![CDATA[fromUser]]></FromUserName>

     <CreateTime>1348831860</CreateTime>

     <MsgType><![CDATA[text]]></MsgType>

     <Content><![CDATA[this is a test]]></Content>

     <MsgId>1234567890123456</MsgId>

     </xml>

    当微信服务器接受到用户发送的消息,微信服务器再把这条消息通过XML格式组装后,发送给我们的服务器。那么,如果我们想要回复文本消息。我们也需要把消息通过XML格式组装好发送给微信服务器,微信服务器再发送给用户

    回复文本消息的XML格式:

    <xml>

    <ToUserName><![CDATA[toUser]]></ToUserName>

    <FromUserName><![CDATA[fromUser]]></FromUserName>

    <CreateTime>12345678</CreateTime>

    <MsgType><![CDATA[text]]></MsgType>

    <Content><![CDATA[你好]]></Content>

    </xml>

    实例代码:

     

    注意,$toUser 是指将这个消息返回给谁。因为我们是将消息回复给用户的,所以

    $toUser = $this->postObj->FromUserName;//获取到发送消息给微信公众号的用户openId

    素材管理

    新增临时素材

    公众号经常需要用到一些临时性的多媒体素材的场景,例如在使用接口特别是发送消息时,对多媒体文件、多媒体消息的获取和调用等操作,是通过media_id来进行的。素材管理接口对所有认证的订阅号和服务号开发。通过本接口,公众号可以新增一些临时素材(即上传临时多媒体文件)。

    请注意:

    1、对于临时素材,每个素材(media_id)会在开发者上传或粉丝发送到微信服务器3天后自动删除(所以用户发送给开发者的素材,若开发者需要,应尽快下载到本地),以节省服务器资源。

    2media_id是可复用的。

    3、素材的格式大小等要求与公众平台官网一致。具体是,图片大小不超过2M,支持bmp/png/jpeg/jpg/gif格式,语音大小不超过2M,长度不超过60秒(公众平台官网可以在文章中插入小于30分钟的语音,但这些语音不能用于群发等场景,只能放在文章内,这方面接口暂不支持),支持mp3/wma/wav/amr格式

    4、需使用https调用本接口。

    调用接口地址

    https://api.weixin.qq.com/cgi-bin/media/upload?access_token=ACCESS_TOKEN&type=TYPE

    其他需要注意的问题:

    1、 文件上传时通过CURL POST方式提交的,POST内容需要是数组格式。

     

    2、 上传的文件必须先在你的服务器,然后获取到上传文件所在服务器的绝对路径。并且需要在绝对路径前面加上@以示区分。

    3、 在Window服务上,路径分隔符为斜杠,例子:@D:softlogo.jpg

    而在Linux服务器上,路径分隔符为反斜杠/ 例子:@/tmp/logo.jpg

    代码示例:

     

    获取临时素材

    公众号可以使用本接口从微信服务器下载临时的多媒体素材。

    接口调用URL

    http请求方式: GET,https调用

    https://api.weixin.qq.com/cgi-bin/media/get?access_token=ACCESS_TOKEN&media_id=MEDIA_ID

    参数说明

    参数

    是否必须

    说明

    access_token

    调用接口凭证

    media_id

    媒体文件ID

     

     

     

     

     

    返回说明

    正确情况下的返回HTTP头如下:

    HTTP/1.1 200 OK

    Connection: close

    Content-Type: image/jpeg

    Content-disposition: attachment; filename="MEDIA_ID.jpg"

    Date: Sun, 06 Jan 2013 10:20:18 GMT

    Cache-Control: no-cache, must-revalidate

    Content-Length: 339721

    curl -G "https://api.weixin.qq.com/cgi-bin/media/get?access_token=ACCESS_TOKEN&media_id=MEDIA_ID"

    发送消息
    发送客服消息

    当用户主动发消息给公众号的时候(包括发送信息、点击自定义菜单、订阅事件、扫描二维码事件),微信将会把消息数据推送给开发者,开发者在一段时间内可以调用客服消息接口,通过POST一个JSON数据包来发送消息给普通用户,在48小时内不限制发送次数。此接口主要用于客服等有人工消息处理环节的功能,方便开发者为用户提供更加优质的服务。

    调用的接口URL

    https://api.weixin.qq.com/cgi-bin/message/custom/send?access_token=ACCESS_TOKEN

    具体参考文档http://mp.weixin.qq.com/wiki/7/12a5a320ae96fecdf0e15cb06123de9f.html

    至于为什么需要客服接口呢?

    因为微信公众平台一直没有推出手机客服端,除了程序的自动应答,运营者还需要一些人工回复,而人工回复目前一般都是通过电脑端操作,有了客服接口可以使运营者使用手机回复。

    获取用户基本信息

    在关注者与公众号产生消息交互后,公众号可获得关注者的OpenID(加密后的微信号,每个用户对每个公众号的OpenID是唯一的。对于不同公众号,同一用户的openid不同)。公众号可通过本接口来根据OpenID获取用户基本信息,包括昵称、头像、性别、所在城市、语言和关注时间。

  • 相关阅读:
    Object-C支持多继承吗?可以实现多个接口吗?Category是什么?
    Action类为何要继承ActionSupport
    JAVA中的File类
    Oracle中奇怪的【不等于号】
    Oracle中INSTR、SUBSTR和NVL的用法
    【ERROR】Oracle11g两个监听同名进程的故障
    【ERROR】EXP-00091
    【ERROR】while loading shared libraries: /u01/app/oracle/product/11.2.0/lib/libclntsh.so.11.1: cannot
    【js】appendChild
    【js】正则表达式(II)
  • 原文地址:https://www.cnblogs.com/sushaolian/p/5786698.html
Copyright © 2020-2023  润新知