微信支付开发收货地址共享接口

广告:宝塔服务器面板,一键全能部署及管理,送你10850元礼包,点我领取~~~

微信支付开发收货地址共享接口

本文介绍微信支付下的收货地址共享接口的开发过程。

一. 简介

微信收货地址共享,是指用户在微信浏览器内打开网页,填写过地址后,后续可以免填写支持快速选择,也可增加和编辑。此地址为用户属性,可在各商户的网页中共享使用。支持原生控件填写地址,地址数据会传递到商户。

地址共享是基于微信JavaScript API 实现,只能在微信内置浏览器中使用,其他浏览器调用无效。同时,需要微信5.0 版本才能支持,建议通过user agent 来确定用户当前的版本号后再调用地址接口。以iPhone 版本为例,可以通过useragent可获取如下微信版本示例信息:"Mozilla/5.0(iphone;CPU iphone OS 5_1_1 like Mac OS X)AppleWebKit/534.46(KHTML,like Geocko) Mobile/9B206MicroMessenger/5.0"其中5.0 为用户安装的微信版本号,商户可以判定版本号是否高于或者等于5.0。

地址格式微信地址共享使用的数据字段包括:

收货人姓名

地区,省市区三级

详细地址

邮编

联系电话

其中,地区对应是国标三级地区码,如“广东省-广州市-天河区”,对应的邮编是是510630。详情参考链接:http://www.stats.gov.cn/tjsj/tjbz/xzqhdm/201401/t20140116_501070.html

二. OAuth2.0授权

获取收货地址之前前需要调用 登录授权接口获取到一次OAuth2.0的Access Token 。所以需要做一次授权,这次授权是不弹出确认框的。其实质就是在用户访问

http://www.fangbei.org/wxpay/js_api_call.php
登录后复制

时跳转到

https://open.weixin.qq.com/connect/oauth2/authorize?appid=wx8888888888888888&redirect_uri=http://www.php.cn/
登录后复制

以此来获得code参数,并根据code来获得授权access_token及openid,这个access token将用于收货地址共享接口。

其实现的详细流程可参考 微信公众平台开发OAuth2.0网页授权

二、获取随机字符串

生成随机字符串的方法如下

三、生成签名

参与addrSign 签名的字段包括:appId、url(调用JavaScript API的网页url)、timestamp、noncestr、accessToken对所有待签名参数按照字段名的ASCII 码从小到大排序(字典序)后,使用URL 键值对的格式(即key1=value1&key2=value2…)拼接成字符串string1。这里需要注意的是签名过程中所有参数名均为小写字符,例如appId 在排序后字符串则为appid;对string1作签名算法,字段名和字段值都采用原始值,不进行URL 转义。具体签名算法为addrSign = SHA1(string1)。这里给出生成addrSign 的具体示例如下:

appId=wx17ef1eaef46752cburl=http://open.weixin.qq.com/timeStamp=1384841012nonceStr=123456accessToken=OezXcEiiBSKSxW0eoylIeBFk1b8VbNtfWALJ5g6aMgZHaqZwK4euEskSn78Qd5pLsfQtuMdgmhajVM5QDm24W8X3tJ18kz5mhmkUcI3RoLm7qGgh1cEnCHejWQo8s5L3VvsFAdawhFxUuLmgh5FRA
登录后复制

i:经过a过程键值对排序后得到string1 为:

accesstoken=OezXcEiiBSKSxW0eoylIeBFk1b8VbNtfWALJ5g6aMgZHaqZwK4euEskSn78Qd5pLsfQtuMdgmhajVM5QDm24W8X3tJ18kz5mhmkUcI3RoLm7qGgh1cEnCHejWQo8s5L3VvsFAdawhFxUuLmgh5FRA&appid=wx17ef1eaef46752cb&noncestr=123456&timestamp=1384841012&url=http://open.weixin.qq.com/?code=CODE&state=STATE
登录后复制

ii:经过b过程签名后可得到:

addrSign=SHA1(accesstoken=OezXcEiiBSKSxW0eoylIeBFk1b8VbNtfWALJ5g6aMgZHaqZwK4euEskSn78Qd5pLsfQtuMdgmhajVM5QDm24W8X3tJ18kz5mhmkUcI3RoLm7qGgh1cEnCHejWQo8s5L3VvsFAdawhFxUuLmgh5FRA&appid=wx17ef1eaef46752cb&noncestr=123456&timestamp=1384841012&url=http://open.weixin.qq.com/?code=CODE&state=STATE)=ca604c740945587544a9cc25e58dd090f200e6fb
登录后复制

实现代码如下

四、获得收货地址

编辑并获取用户收货地址editAddress接口,在网页前端调用。参数列表:

参数必填说明appId是公众号appIDscope是填写“jsapi_address”,获得编辑地址权限signType是签名方式,目前仅支持SHA1addrSign是签名,由各参数一起参与签名生成timeStamp是时间戳nonceStr是随机字符串

调用方法如下

参数返回:

返回值说明err_msgedit_address:ok获取编辑收货地址成功edit_address:fail获取编辑收货地址失败username收货人姓名telNumber收货人电话addressPostalCode邮编proviceFirstStageName国标收货地址第一级地址addressCitySecondStageName国标收货地址第二级地址addressCountiesThirdStageName国标收货地址第三级地址addressDetailInfo详细收货地址信息nationalCode收货地址国家码

五、示例

六、完整代码

<?php/*    方倍工作室 http://www.fangbei.org/    CopyRight 2014 All Rights Reserved*/define('APPID',         "wx—b7559b828e3c13e");define('APPSECRET',     "2b21b42d0c497de9a691a6bb5048a601");class class_weixin{    var $appid = APPID;    var $appsecret = APPSECRET;    //构造函数,获取Access Token    public function __construct($appid = NULL, $appsecret = NULL)    {        if($appid && $appsecret){            $this->appid = $appid;            $this->appsecret = $appsecret;        }    }    //生成OAuth2的URL    public function oauth2_authorize($redirect_url, $scope, $state = NULL)    {        $url = "https://open.weixin.qq.com/connect/oauth2/authorize?appid=".$this->appid."&redirect_uri=".$redirect_url."&response_type=code&scope=".$scope."&state=".$state."#wechat_redirect";        return $url;    }    //生成OAuth2的Access Token    public function oauth2_access_token($code)    {        $url = "https://api.weixin.qq.com/sns/oauth2/access_token?appid=".$this->appid."&secret=".$this->appsecret."&code=".$code."&grant_type=authorization_code";        $res = $this->http_request($url);        return json_decode($res, true);    }    //生成随机字符串    function create_noncestr($length = 16)     {        $chars = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";        $str = "";        for ($i = 0; $i < $length; $i++ ){            $str.= substr($chars, mt_rand(0, strlen($chars)-1), 1);        }        return $str;    }    //生成签名    function get_biz_sign($bizObj)    {        //参数小写        foreach ($bizObj as $k => $v){            $bizParameters[strtolower($k)] = $v;        }        //字典序排序        ksort($bizParameters);        //URL键值对拼成字符串        $buff = "";        foreach ($bizParameters as $k => $v){            $buff .= $k."=".$v."&";        }        //去掉最后一个多余的&        $buff2 = substr($buff, 0, strlen($buff) - 1);        //sha1签名        return sha1($buff2);    }    //HTTP请求(支持HTTP/HTTPS,支持GET/POST)    protected function http_request($url, $data = null)    {        $curl = curl_init();        curl_setopt($curl, CURLOPT_URL, $url);        curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, FALSE);        curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, FALSE);        if (!empty($data)){            curl_setopt($curl, CURLOPT_POST, 1);            curl_setopt($curl, CURLOPT_POSTFIELDS, $data);        }        curl_setopt($curl, CURLOPT_RETURNTRANSFER, TRUE);        $output = curl_exec($curl);        curl_close($curl);        return $output;    }}
登录后复制

<?phprequire_once('wxaddr.class.php');$weixin = new class_weixin();$url = 'http://'.$_SERVER['HTTP_HOST'].$_SERVER['REQUEST_URI'];if (!isset($_GET["code"])){    $jumpurl = $weixin->oauth2_authorize($url, "snsapi_base", "fangbei");    Header("Location: $jumpurl");}else{    $oauth2_access_token = $weixin->oauth2_access_token($_GET["code"]);    $access_token = $oauth2_access_token['access_token'];}$timestamp = strval(time());$noncestr = $weixin->create_noncestr();$obj['appId']               = $weixin->appid;$obj['url']                 = $url;$obj['timeStamp']           = $timestamp;$obj['noncestr']            = $noncestr;$obj['accesstoken']         = $access_token;$signature  = $weixin->get_biz_sign($obj);?><!DOCTYPE html><html>    <head>        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">        <title>获取共享收货地址</title>        <meta name="viewport" content="width=device-width,height=device-height,inital-scale=1.0,maximum-scale=1.0,user-scalable=no;">        <script language="javascript">            function callpay()            {                WeixinJSBridge.invoke('editAddress',{                    "appId" : "<?php echo $obj['appId'];?>",                    "scope" : "jsapi_address",                    "signType" : "sha1",                    "addrSign" : "<?php echo $signature;?>",                    "timeStamp" : "<?php echo $timestamp;?>",                    "nonceStr" : "<?php echo $noncestr;?>",                },function(res){                     alert(JSON.stringify(res));                      document.form1.address1.value         = res.proviceFirstStageName;                    document.form1.address2.value         = res.addressCitySecondStageName;                    document.form1.address3.value         = res.addressCountiesThirdStageName;                    document.form1.detail.value           = res.addressDetailInfo;                    document.form1.national.value         = res.nationalCode;                    document.form1.user.value            = res.userName;                    document.form1.phone.value            = res.telNumber;                    document.form1.postcode.value         = res.addressPostalCode;                    document.form1.errmsg.value         = res.err_msg;                });            }        </script>    </head>    <body>        <form name="form1" target="_blank">            <table border="1">                <colgroup><col width="20%"><col width="80%"></colgroup>                <TR><th>结果</th><th><INPUT value="" name="errmsg" id="9"></th>                <TR><th>国家码</th><th><INPUT value="" name="national" id="6"></th>                <TR><th>国家</th><th><INPUT value="" name="address3" id="3"></th>                <TR><th>省</th><th><INPUT value="" name="address1" id="1"></th>                <tr><th>市</th><th><INPUT value="" name="address2" id="2"></th>                <TR><th>详细</th><th><INPUT value="" name="detail"   id="4"></th>                <TR><th>收货人</th><th><INPUT value="" name="user" id="7"></th>                <TR><th>电话</th><th><INPUT value="" name="phone"    id="5"></th>                <TR><th>邮编</th><th><INPUT value="" name="postcode" id="8"></th>            </table>        </form>        <div>            <button type="button" onclick="callpay()">获取收货地址</button>        </div>    </body></html>
登录后复制

更多微信支付开发收货地址共享接口 相关文章请关注PHP中文网!

9543建站博客
一个专注于网站开发、微信开发的技术类纯净博客。
作者头像
admin创始人

肥猫,知名SEO博客站长,14年SEO经验。

上一篇:自定义实现小程序的动画弹框、提示框
下一篇:怎么用css设置字体颜色

发表评论

关闭广告
关闭广告