处理冲突

overtrue 2015-04-24 10:42:01 +08:00
commit 178cf1bd68
20 changed files with 561 additions and 201 deletions

12
Home.md

@ -1,4 +1,7 @@
## 目录
微信 SDK 2.0 文档
- 基本使用
+ [安装](安装)
+ [配置与初始化](配置与初始化)
@ -12,15 +15,14 @@
+ [多客服的消息转发](多客服的消息转发)
+ [网页授权](网页授权)
+ [自定义菜单](自定义菜单)
+ [图片上传](图片上传)
+ [门店管理](门店管理)
+ [JSSDK](JSSDK)
+ [二维码](二维码)
+ [短链接](短链接)
- 其它
+ [错误处理](错误处理)
+ [自定义缓存](自定义缓存)
+ [签名计算](签名计算)
+ [获取JSSDK的Ticket](获取JSSDK的Ticket)
---
© 2015 overtrue.me
© 2015 overtrue.me

44
JSSDK.md Normal file

@ -0,0 +1,44 @@
本 SDK 同样由 `Overtrue\Wechat\Js` 提供了 JSSDK 相关的功能。
### 获取实例
```php
<?php
use Overtrue\Wechat\Js;
$appId = 'wx3cf0f39249eb0e60';
$secret = 'f1c242f4f28f735d4687abb469072a29';
$js = new Js($appId, $secret);
```
### API
- `$js->config(array $APIs, $debug = false, $json = false);` 获取JSSDK的配置数组`$json``true` 时返回 JSON 格式字符串,你可以直接使用到网页中
- `$js->setUrl($url)` 设置当前URL如果不想用默认读取的URL可以使用此方法手动设置通常不需要。
example:
我们可以生成js配置文件
```js
<script src="http://res.wx.qq.com/open/js/jweixin-1.0.0.js" type="text/javascript" charset="utf-8"></script>
<script type="text/javascript" charset="utf-8">
wx.config(<?php echo $js->config(array('onMenuShareQQ', 'onMenuShareWeibo'), true, true) ?>);
</script>
```
结果如下:
```js
<script src="http://res.wx.qq.com/open/js/jweixin-1.0.0.js" type="text/javascript" charset="utf-8"></script>
<script type="text/javascript" charset="utf-8">
wx.config({
debug: true,
appId: 'wx3cf0f39249eb0e60',
timestamp: 1430009304,
nonceStr: 'qey94m021ik',
signature: '4F76593A4245644FAE4E1BC940F6422A0C3EC03E',
jsApiList: ['onMenuShareQQ', 'onMenuShareWeibo']
});
</script>
```

53
二维码.md Normal file

@ -0,0 +1,53 @@
本 SDK 由 `Overtrue\Wechat\QRCode` 提供微信二维码创建与获取等服务。
目前有2种类型的二维码
1. 临时二维码是有过期时间的最长可以设置为在二维码生成后的7天即604800秒后过期但能够生成较多数量。临时二维码主要用于帐号绑定等不要求二维码永久保存的业务场景
2. 永久二维码是无过期时间的但数量较少目前为最多10万个。永久二维码主要用于适用于帐号绑定、用户来源统计等场景。
### 获取实例
```php
<?php
use Overtrue\Wechat\QRCode;
$appId = 'wx3cf0f39249eb0e60';
$secret = 'f1c242f4f28f735d4687abb469072a29';
$qrcode = new QRCode($appId, $secret);
```
## 方法
+ `Bag temporary($sceneId, $expireSeconds = null)` 创建临时二维码;
+ `Bag forever($sceneValue, $type = self::SCENE_QR_FOREVER)` 创建永久二维码,`$type`: `QR_LIMIT_SCENE` 为永久, `QR_LIMIT_STR_SCENE` 为永久的字符串参数值;
+ `string show($ticket)` 获取二维码网址,用法: `<img src="<?php $qrcode->show($qrTicket); ?>">`
+ `void download($ticket, $filename)` 下载二维码到本地,`$filename` 为带文件名的目标路径;
example:
创建临时二维码:
```php
$result = $qrcode->temporary(56, 6 * 24 * 3600);
$ticket = $result->ticket;// 或者 $result['ticket']
$expireSeconds = $result->expire_seconds; // 有效秒数
$url = $result->url; // 二维码图片解析后的地址,开发者可根据该地址自行生成需要的二维码图片
```
创建永久二维码:
```php
$result = $qrcode->forever(56);// 或者 $qrcode->forever("56", self::SCENE_QR_FOREVER_STR);
$ticket = $result->ticket; // 或者 $result['ticket']
$url = $result->url;
```
下载二维码到本地:
```php
$qrcode->download($ticket, __DIR__ . '/code.jpg');
```

11
升级日志.md Normal file

@ -0,0 +1,11 @@
# 2.0
- 【删除】移除 `Overtrue\Wechat\Wechat` 基类,便于处理多用户,各业务分散到独立的类中完成;
- 【删除】移除 `Menu::make()` 方法,改为 `new MenuItem($name, $type, $key)` 形式;
- 【新增】JSSDK 服务;
- 【新增】二维码服务;
- 【新增】异常消息添加中文错误消息;
- 【新增】门店服务;
- 【新增】素材添加完整 API 支持,支持永久素材等官方提供的所有功能;
- 【变更】消息中图片等附件不再自动上传,之前 `media($path)` 不再接受本地文件路径,只接受上传后的 `media_id` 值,上传请先使用素材管理服务进行上传,便于素材管理;
- 【变更】 `Wechat::service('cache')` 同样不存在了,更改为 new 服务(...), ex: `$userService = new Overtrue\Wechat\User($appId, $secret)`
- 【变更】 之前服务里的 `->all()` 方法均改名为 `->lists()`

@ -1,15 +1,15 @@
多客服的消息转发绝对是超级的简单:
多客服的消息转发绝对是超级的简单,转发的消息类型为 `transfer`
```php
use Overtrue\Wechat\Services\Message;
use Overtrue\Wechat\Message;
// 转发收到的消息给客服
$wechat->on('message', function($message) {
return Message::make('transfer');
$server->on('message', function($message) {
return Message::make('transfer');
});
$result = $wechat->serve();
$result = $server->serve();
echo $result;
```
@ -17,7 +17,9 @@
当然,你也可以指定转发给某一个客服:
```php
return Message::make('transfer')->account($account);
return Message::make('transfer')->account($account);
// 或者
return Message::make('transfer')->to($account);
```
return Message::make('transfer')->to($account);
```
更多关于多客服消息转发http://mp.weixin.qq.com/wiki/5/ae230189c9bd07a6b221f48619aeef35.html

@ -13,12 +13,11 @@
下载 [最新版zip包](https://github.com/overtrue/wechat/archive/master.zip) 或者下载指定版本: https://github.com/overtrue/wechat/releases
然后引入根目录的 `autoload.php` 即可:
```php
<?php
require "wechat/autoload.php"; // 路径请修改为你具体的实际路径
use Overtrue\Wechat\Wechat;
...
```

@ -1,16 +1,31 @@
微信的客服才能发送消息或者群发消息,而且还有时效限制,真恶心的说。。。
```php
$staff = $wechat->staff;
```
本 SDK 由 `Overtrue\Wechat\Staff` 提供客服相关服务。
+ `$staff->all();` 获取所有客服账号
+ `$staff->allOnline();` 获取所有在线的客服账号
+ `$staff->create($mail, $nickname, $password);` 添加客服帐号
+ `$staff->update($mail, $nickname, $password);` 修改客服帐号
+ `$staff->delete($mail, $nickname, $password);` 删除客服帐号
+ `$staff->avatar($mail, $avatarPath);` 设置客服帐号的头像
### 获取实例
```php
<?php
use Overtrue\Wechat\Staff;
$appId = 'wx3cf0f39249eb0e60';
$secret = 'f1c242f4f28f735d4687abb469072a29';
$userService = new Staff($appId, $secret);
```
### API
+ `$staff->lists();` 获取所有客服账号列表
+ `$staff->onlines();` 获取所有在线的客服账号列表
+ `$staff->create($email, $nickname, $password);` 添加客服帐号
+ `$staff->update($email, $nickname, $password);` 修改客服帐号
+ `$staff->delete($email, $nickname, $password);` 删除客服帐号
+ `$staff->avatar($email, $avatarPath);` 设置客服帐号的头像
+ `$staff->send($message)->to($openId);` 主动发送消息给用户
+ `$staff->send($message)->by('account@test')->to($openId);` 指定客服发送消息
关于更多客服接口信息请参考微信官方文档http://mp.weixin.qq.com/wiki/9/6fff6f191ef92c126b043ada035cc935.html
关于更多客服接口信息请参考微信官方文档http://mp.weixin.qq.com/wiki/9/6fff6f191ef92c126b043ada035cc935.html

@ -1,12 +1,31 @@
消息的监听再简单不过了,你不需要像其它 SDK 一样麻烦,这将会是前所未有的简单,你可以选择监听所有类型或者指定某种类型,以及作出相应的响应,比如回复一条应答消息。
在本 SDK 中,服务端的操作,例如:服务器认证,监听事件,接收用户消息等所有微信向我们自有服务器发起请求的,都交由 `Overtrue\Wechat\Server` 来处理。
### 获取服务端实例
```php
<?php
use Overtrue\Wechat\Server;
$appId = 'wx3cf0f39249eb0e60';
$token = 'hellotest';
$encodingAESKey = 'EJThPazwzO4k1cyXJnwQtL60zBdhWvFaHb4emv0dLVN';
$server = new Server($appId, $token, $encodingAESKey);
```
### 接收消息
#### 语法:
```php
$wechat->on('message', callable $callback); // 全部类型
// or
// or
$wechat->on('message', string $messageType, callable $callback); // 只监听指定类型
```
参数说明
#### 参数说明:
- `$messageType` string, 指定要处理的消息类型ex`image`
- `$callback` callable, 回调函数closure 匿名函数,或者一切可调用的方法或者函数
@ -16,20 +35,30 @@ $wechat->on('message', string $messageType, callable $callback); // 只监听指
example:
```php
<?php
use Overtrue\Wechat\Services\Message;
use Overtrue\Wechat\Server;
use Overtrue\Wechat\Message;
$appId = 'wx3cf0f39249eb0e60';
$secret = 'f1c242f4f28f735d4687abb469072a29';
$token = 'hellotest';
$encodingAESKey = 'EJThPazwzO4k1cyXJnwQtL60zBdhWvFaHb4emv0dLVN';
$server = new Server($appId, $token, $encodingAESKey);
// 监听所有类型
$wechat->on('message', function($message) {
return Message::make('text')->content('您好!'.$message->FromUserName);
$server->on('message', function($message) {
return Message::make('text')->content('您好!');
});
// 监听指定类型
$wechat->on('message', 'image', function($message) {
$server->on('message', 'image', function($message) {
return Message::make('text')->content('我们已经收到您发送的图片!');
});
$result = $wechat->serve();
$result = $server->serve();
echo $result;
```

@ -41,10 +41,10 @@
| 消息类型 | 类型名称 | 属性 | 除属性自身外提供的方法 |
|----------|----------|----------------------------------------------------------------------------------|-------------------------------------------|
| 文本 | `text` | `content` 内容 | |
| 图片 | `image` | `media_id` 媒体资源id | `media($path)` |
| 声音 | `voice` | `media_id` 媒体资源id | `media($path)` |
| 音乐 | `music` | `title` 标题 <br>`description` 描述 <br>`url` 音乐URL <br>`hq_url` 高清URL <br>`thumb_media_id` 封面资源id | `thumb($path)` |
| 视频 | `video` | `title` 标题 <br>`description` 描述 <br>`media_id` 媒体资源id <br>`thumb_media_id` 封面资源id | `media($path)` <br>`thumb($path)` |
| 图片 | `image` | `media_id` 媒体资源id | `media($mediaId)` |
| 声音 | `voice` | `media_id` 媒体资源id | `media($mediaId)` |
| 音乐 | `music` | `title` 标题 <br>`description` 描述 <br>`url` 音乐URL <br>`hq_url` 高清URL <br>`thumb_media_id` 封面资源id | `thumb($mediaId)` |
| 视频 | `video` | `title` 标题 <br>`description` 描述 <br>`media_id` 媒体资源id <br>`thumb_media_id` 封面资源id | `media($mediaId)` <br>`thumb($mediaId)` |
| 位置 | `location` | `lat` 地理位置纬度 <br>`lon` 地理位置经度 <br>`scale` 地图缩放大小 <br>`label` 地理位置信息 | |
| 链接 | `link` | `title` 标题 <br>`description` 描述<br>url 链接URL | |
@ -69,24 +69,27 @@ $wechat->on('event', 'subscribe', function($event){
这里有一点需要注意,当属性带下划线的时候,方法名是支持两种的:`media_id()` 或者 `mediaId()` 都一样。
### 上传媒体文件
### 上传素材文件
```php
$message = Message::make('image')->media('D:/test/demo.jpg');
<?php
use Overtrue\Wechat\Media;
// $appId = xxxx;
// $appSecret = xxxx;
// ...
$media = new Media($appId, $appSecret);
$imageId = $media->image(__DIR__ . '/demo.jpg'); // 上传并返回媒体ID
$message = Message::make('image')->media($imageId);
```
媒体文件你不用上传,也就是说 `media_id` 是我来维护,你直接传本地文件就好了。
方法 `media($file)` 会上传文件然后赋值到 `media_id` 属性。如果想要获取上传后的 `media_id`:
```php
$mediaId = $message->media_id;
```
> 请注意:方法`media($mediaId)`会直接赋值到`media_id`属性。不会自动上传文件。1.x 版本是会自动上传的2.x 已经不再提供。
#### 这里有两个方法用于设置媒体文件
#### 这里有两个方法用于设置素材ID
- `media($file)` 对应设置 `media_id`
- `thumb($file)` 对应设置 `thumb_media_id`
- `media($mediaId)` 对应设置 `media_id`
- `thumb($mediaId)` 对应设置 `thumb_media_id`
### 图文消息
@ -101,4 +104,6 @@ $news = Message::make('news')->items(function(){
Message::make('news_item')->title('测试标题4')->url('http://baidu.com/abc.php')->picUrl('http://www.baidu.com/demo.jpg'),
);
});
```
```
关于更多素材管理请参考:[素材管理](素材管理)

@ -1,12 +1,24 @@
## 用户
本 SDK 中上传素材通过 `Overtrue\Wechat\User`、`Overtrue\Wechat\Group` 提供用户与用户组管理服务。
```php
$userService = $wechat->user;
```
### 获取实例
```php
<?php
use Overtrue\Wechat\User;
$appId = 'wx3cf0f39249eb0e60';
$secret = 'f1c242f4f28f735d4687abb469072a29';
$userService = new User($appId, $secret);
```
## API
+ `$userService->get($openId);` 获取用户信息
+ `$userService->all($nextOpenId = null);` 获取用户列表, `$nextOpenId` 可选
+ `$userService->remark($openId, $remark);` 修改用户备注, 返回 `boolean`
+ `$userService->lists($nextOpenId = null);` 获取用户列表, `$nextOpenId` 可选
+ `$userService->remark($openId, $remark);` 修改用户备注, 返回boolean
+ `$userService->group($openId);` 获取用户所属用户组ID
example:
@ -16,13 +28,20 @@ $user = $userService->get($openId);
echo $user->nickname;
```
## 用户组
## 用户组
```php
$group = $wechat->group;
```
```php
<?php
+ `$group->all();` 获取所有分组
use Overtrue\Wechat\User;
$appId = 'wx3cf0f39249eb0e60';
$secret = 'f1c242f4f28f735d4687abb469072a29';
$group = new Group($appId, $secret);
```
+ `$group->lists();` 获取所有分组
+ `$group->update($groupId, $name);` 修改分组信息
+ `$group->moveUser($openId, $groupId);` 移动单个用户到指定分组
+ `$group->moveUsers(array $openIds, $groupId);` 批量移动用户到指定分组

@ -1,13 +1,32 @@
所有的事件都可以很方便的监听与处理,与监听消息一样,同样支持监听全部类型或者指定类型。
在本 SDK 中,服务端的操作,例如:服务器认证,监听事件,接收用户消息等所有微信向我们自有服务器发起请求的,都交由 `Overtrue\Wechat\Server` 来处理。
### 获取服务端实例
```php
$wechat->on('event', callable $callback);
// or
$wechat->on('event', string $eventType, callable $callback);
<?php
use Overtrue\Wechat\Server;
$appId = 'wx3cf0f39249eb0e60';
$token = 'hellotest';
$encodingAESKey = 'EJThPazwzO4k1cyXJnwQtL60zBdhWvFaHb4emv0dLVN';
$server = new Server($appId, $token, $encodingAESKey);
```
参数说明
### 监听事件:
#### 语法:
```php
$server->on('event', callable $callback);
// or
$server->on('event', string $eventType, callable $callback);
```
#### 参数说明:
- `$eventType` string, 指定要处理的消息类型ex`image`
- `$callback` callable, 回调函数Closure 匿名函数,或者一切可调用的方法或者函数
@ -21,28 +40,36 @@ $wechat->on('event', string $eventType, callable $callback);
Event 事件类型ex: subscribe
EventKey 事件 Key 值,与自定义菜单接口中 Key 值对应
example:
完整举例:
```php
<?php
use Overtrue\Wechat\Services\Message;
use Overtrue\Wechat\Server;
use Overtrue\Wechat\Message;
$appId = 'wx3cf0f39249eb0e60';
$secret = 'f1c242f4f28f735d4687abb469072a29';
$token = 'hellotest';
$encodingAESKey = 'EJThPazwzO4k1cyXJnwQtL60zBdhWvFaHb4emv0dLVN';
$server = new Server($appId, $token, $encodingAESKey);
// 监听所有事件
$wechat->on('event', function($event) {
error_log('收到取消关注事件取消关注者openid: ' . $event['FromUserName']);
$server->on('event', function($event) {
error_log('收到取消关注事件取消关注者openid: ' . $event['FromUserName']);
});
// 只监听指定类型事件
$wechat->on('event', 'subscribe', function($event) {
$server->on('event', 'subscribe', function($event) {
error_log('收到关注事件关注者openid: ' . $event['FromUserName']);
error_log('收到关注事件关注者openid: ' . $event['FromUserName']);
return Message::make('text')->content('感谢您关注');
});
$result = $wechat->serve();
echo $result;
$res = $server->serve();
echo $res; // or return $res; 在某些框架中需要返回字符串
```
关于事件类型请参考微信官方文档http://mp.weixin.qq.com/wiki/2/5baf56ce4947d35003b86a9805634b1e.html

30
短链接.md Normal file

@ -0,0 +1,30 @@
本 SDK 由 `Overtrue\Wechat\Url` 提供微信链接转换服务。
主要使用场景: 开发者用于生成二维码的原链接(商品、支付二维码等)太长导致扫码速度和成功率下降,将原长链接通过此接口转成短链接再生成二维码将大大提升扫码速度和成功率。
### 获取实例
```php
<?php
use Overtrue\Wechat\Url;
$appId = 'wx3cf0f39249eb0e60';
$secret = 'f1c242f4f28f735d4687abb469072a29';
$url = new Url($appId, $secret);
```
## 方法
+ `string short($url)` 长链接转短链接
example:
```php
$shortUrl = $url->short('http://overtrue.me/open-source');
//
```
微信官方文档http://mp.weixin.qq.com/wiki/10/165c9b15eddcfbd8699ac12b0bd89ae6.html

@ -1,18 +0,0 @@
Wechat基类提供了计算签名的方法
```php
$wechat->signature($params);
```
example:
```php
$params = array(
'token' => 'mock_token',
'time' => time(),
'nonce' => 'hello',
);
$signature = $wechat->signature($params);
// 313f67a0d1af958128c6761230fa1f1282ed027e
```

88
素材管理.md Normal file

@ -0,0 +1,88 @@
在微信里的图片,音乐,视频等等都需要先上传到微信服务器作为素材才可以在消息中使用。
> 请注意:
1. 限制:
- 图片image: 1M支持 bmp/png/jpeg/jpg/gif 格式
- 语音voice2M播放长度不超过 60s支持 mp3/wma/wav/amr 格式
- 视频video10MB支持MP4格式
- 缩略图thumb64KB支持JPG格式
2. `media_id` 是可复用的;
3. 素材分为 `临时素材``永久素材` 临时素材媒体文件在后台保存时间为3天即 3 天后 `media_id` 失效;
4. 新增的永久素材也可以在公众平台官网素材管理模块中看到;
5. 永久素材的数量是有上限的请谨慎新增。图文消息素材和图片素材的上限为5000其他类型为1000
本 SDK 中上传素材通过 `Overtrue\Wechat\Media` 提供素材管理服务。
### 获取实例
```php
<?php
use Overtrue\Wechat\Media;
$appId = 'wx3cf0f39249eb0e60';
$secret = 'f1c242f4f28f735d4687abb469072a29';
$media = new Media($appId, $secret);
```
### API列表
- `$media->image($path);`, 上传临时图片;
- `$media->voice($path);`, 上传临时声音;
- `$media->video($path, $title, $description);`, 上传临时视频;
- `$media->thumb($path);`, 上传临时缩略图,用于视频封面或者音乐封面;
- `$media->news(array $articles);`, 上传永久图文消息,图文没有临时;
- `$media->updateNews($mediaId, array $article, $index);`, 修改永久图文消息要更新的文章在图文消息中的位置多图文消息时此字段才有意义单图片忽略此参数第一篇为0
- `$media->forever()->image($path);` 上传永久图片;
- `$media->forever()->voice($path);` 上传永久声音;
- `$media->forever()->video($path);` 上传永久视频;
- `$media->forever()->thumb($path);` 上传永久缩略图;
- `$media->lists($type, $offset, $count);` 获取永久素材列表,参考:[微信公众平台开发者文档:获取永久素材列表](http://mp.weixin.qq.com/wiki/12/2108cd7aafff7f388f41f37efa710204.html)
- `$media->stats($type = null);` 获取素材计数,不指定 `$type` 则返回全部
- `$media->delete($mediaId);` 删除永久素材;
- `$media->download($mediaId, $filename);` 下载临时素材到本地,`$filename` 为目标路径带文件名,例如:`$media->download($mediaId, __DIR__ . '/test.jpg');`
- `$media->forever()->download($mediaId, $filename);` 下载永久素材到本地;
> 上传永久图文消息 `$articles` 结构为:
[{
"title": TITLE,
"thumb_media_id": THUMB_MEDIA_ID,
"author": AUTHOR,
"digest": DIGEST,
"show_cover_pic": SHOW_COVER_PIC(0 / 1),
"content": CONTENT,
"content_source_url": CONTENT_SOURCE_URL
},
//若新增的是多图文素材则此处应还有几段articles结构
]
字段说明:
- title: 标题
- thumb_media_i: 图文消息的封面图片素材id必须是永久mediaID
- autho: 作者
- diges: 图文消息的摘要,仅有单图文消息才有摘要,多图文此处为空
- show_cover_pic: 是否显示封面0为false即不显示1为true即显示
- content: 图文消息的具体内容支持HTML标签必须少于2万字符小于1M且此处会去除JS
- content_source_ur: 图文消息的原文地址即点击“阅读原文”后的URL
### 示例:
创建图片消息:
```php
<?php
use Overtrue\Wechat\Media;
$appId = 'wx3cf0f39249eb0e60';
$secret = 'f1c242f4f28f735d4687abb469072a29';
$media = new Media($appId, $secret);
$imageId = $media->image(__DIR__ . '/demo.jpg'); // 上传并返回媒体ID
$message = Message::make('image')->media($imageId);
```
更多请参考官方文档http://mp.weixin.qq.com/wiki/home/index.html `素材管理` 章节

@ -1,14 +1,27 @@
```php
$wechat->auth;
```
网页授权在本 SDK 中由 `Overtrue\Wechat\Auth` 提供服务。
```php
<?php
use Overtrue\Wechat\Auth;
$appId = 'wx3cf0f39249eb0e60';
$secret = 'f1c242f4f28f735d4687abb469072a29';
$auth = new Auth($appId, $secret);
```
+ 生成授权链接
+ 生成授权链接
```php
// 生成并返回
$wechat->auth->url($to, $scope = 'snsapi_base', $state = 'STATE');
$auth->url($to, $scope, $state = 'STATE');
// 直接跳转
$wechat->auth->redirect($to, $scope = 'snsapi_base', $state = 'STATE'); 直接跳转
$auth->redirect($to, $scope, $state = 'STATE'); 直接跳转
```
> 注意:
@ -22,36 +35,37 @@ example:
```php
// 只取 `openid`
$wechat->auth->url('http://overtrue.me', 'snsapi_base');
$url = $auth->url('http://overtrue.me', 'snsapi_base');
// 需要拉取用户信息
$wechat->auth->url('http://overtrue.me', 'snsapi_userinfo');
$url = $auth->url('http://overtrue.me', 'snsapi_userinfo');
```
+ 判断是否已经授权
```php
$wechat->auth->authorized();
$auth->authorized();
```
+ 获取授权用户
+ 获取授权用户
```php
$wechat->auth->user();
$auth->user();
```
## 示例:
```php
// 如果已经授权或者 SESSION 未过期
if ($wechat->auth->authorized() || Session::get('logged_open_id')) {
$user = $wechat->auth->user();// 获取已经登录后用户信息
if ($auth->authorized() || Session::get('logged_open_id')) {
$user = $auth->user();// 获取已经登录后用户信息
Session::set('logged_open_id', $user['open_id']);
//code 显示授权后的页面,或者跳转到其它授权才能访问的页面
//...
} else {
$to = "http://微信授权完成后跳回你的地址,就是当前代码所在的 URL";
$wechat->auth->redirect($to);
$auth->redirect($to);
}
```
@ -61,6 +75,17 @@ if ($wechat->auth->authorized() || Session::get('logged_open_id')) {
```php
return Redirect::to($wechat->auth->url($to, 'snsapi_base', 'STATE'));
=======
$auth->redirect($to);
}
```
### 在 [Laravel](http://laravel.com) 里使用
在 Laravel 里的跳转请使用 `url` 而不要使用 `redirect`, 因为在 Laravel 控制器方法必须返回字符串或者实现了 `__toString()` 的对象:
```php
return Redirect::to($auth->url($to, 'snsapi_base', 'STATE'));
```
更多关于微信网页授权 API 请参考: http://mp.weixin.qq.com/wiki/17/c0f37d5704f0b64713d5d2c37b468d75.html

@ -1,17 +1,24 @@
微信的access_token是不能太频繁的调用的所以需要缓存本 SDK 默认使用文件缓存,文件会创建在代码运行环境的临时目录里,使用 [sys_get_temp_dir()](http://php.net/manual/zh/function.sys-get-temp-dir.php) 函数获取的临时目录下。
微信的 `access_token` 是不能太频繁的调用的,所以需要缓存,本 SDK 默认使用文件缓存,文件会创建在代码运行环境的临时目录里,使用[sys_get_temp_dir()](http://php.net/manual/zh/function.sys-get-temp-dir.php) 函数获取的临时目录下。
如果你需要自定义缓存方式,那么 `Wechat` 提供了以下两个方法:
```php
<?php
use Overtrue\Wechat\Cache;
// 写入
$wechat->cache->setter(function($key, $value, $lifetime){
Cache::setter(function($key, $value, $lifetime){
return your_custom_set_cache($key, $value, $lifetime);
});
// 读取
$wechat->cache->getter(function($key){
Cache::getter(function($key){
return your_custom_get_cache($key);
});
```
`your_custom_set_cache` 为你自己的方法,这里是举例。
当你的 `getter` 没有返回缓存的值时,会重新请求 `access_token`

@ -1,14 +1,10 @@
# 自定义菜单
```php
$wechat->menu;
```
本 SDK 由 `Overtrue\Wechat\Menu``Overtrue\Wechat\MenuItem` 提供微信菜单的管理服务。
自定义菜单功能的使用场景:你自己做了网站后台,想要管理某个公众号的菜单,在后台填写表单后,经由 SDK 请求微信的服务器完成菜单设定。
## 概念
#### 菜单项 MenuItem
#### 菜单项 `MenuItem`
菜单的组成单位分为一级与二级一个微信菜单包含最多3个一级菜单项。一个一级菜单项可以包含最多5个二级菜单项。
@ -17,12 +13,27 @@
目前自定义菜单最多包括3个一级菜单每个一级菜单最多包含5个二级菜单。一级菜单最多4个汉字二级菜单最多7个汉字多出来的部分将会以“...”代替。请注意创建自定义菜单后由于微信客户端缓存需要24小时微信客户端才会展现出来。建议测试时可以尝试取消关注公众账号后再次关注则可以看到创建后的效果。
### 获取实例
```php
<?php
use Overtrue\Wechat\Menu;
use Overtrue\Wechat\MenuItem;
$appId = 'wx3cf0f39249eb0e60';
$secret = 'f1c242f4f28f735d4687abb469072a29';
$menu = new Menu($appId, $secret);
```
## 方法
+ `array $menu->get();` 读取菜单
+ `boolean $menu->set(array $menus);` 设置菜单,参数为一个包含最多三个一级菜单项的数组
+ `boolean $menu->delete();` 删除菜单
+ `MenuItem $menu->make($name, $type = null, $key = null)` 创建一个菜单项
+ `new MenuItem($name, $type = null, $key = null)` 创建一个菜单项
- `$name` 菜单项名称,比如:`今日歌曲`
- `$type` 菜单项类型,比如:`view`,`click`等,更多请参考 http://mp.weixin.qq.com/wiki `自定义菜单` 章节。
- `$key` 菜单项的值,当 `$type``view` 时为目标 URL其它为自定义 key。
@ -36,19 +47,20 @@
example:
```php
use Overtrue\Wechat\Services\Menu;
$button = new MenuItem("菜单");
$menus = array(
Menu::click("今日歌曲")->key('V1001_TODAY_MUSIC'),
Menu::make("菜单")->buttons(array(
Menu::view('搜索', 'http://www.soso.com/'),
Menu::view('视频', 'http://v.qq.com/'),
Menu::click('赞一下我们', 'V1001_GOOD'),
new MenuItem("今日歌曲", 'click', 'V1001_TODAY_MUSIC'),
$button->buttons(array(
new MenuItem('搜索', 'view', 'http://www.soso.com/'),
new MenuItem('视频', 'view', 'http://v.qq.com/'),
new MenuItem('赞一下我们', 'click', 'V1001_GOOD'),
)),
);
try {
Menu::set($menus);// 请求微信服务器
$menu->set($menus);// 请求微信服务器
echo '设置成功!';
} catch (\Exception $e) {
echo '设置失败:' . $e->getMessage();
@ -56,28 +68,12 @@ try {
```
如果你不想引入`Overtrue\Wechat\Services\Menu` 命名空间,也可以通过
`$wechat->menu->make($name, $type = null, $key = null)`
来创建,比如上面示例也可以写成:
```php
$wechat->menu->set(array(
$wechat->menu->make('今日歌曲', 'click', 'V1001_TODAY_MUSIC'),
$wechat->menu->make('菜单')->buttons(array(
$wechat->menu->make('搜索', 'view', 'http://www.soso.com/'),
$wechat->menu->make('视频', 'view', 'http://v.qq.com/'),
$wechat->menu->make('赞一下我们', 'click', 'V1001_GOOD'),
)),
));
```
生成结果:
```json
{
"button":[
{
{
"type":"click",
"name":"今日歌曲",
"key":"V1001_TODAY_MUSIC"
@ -85,7 +81,7 @@ $wechat->menu->set(array(
{
"name":"菜单",
"sub_button":[
{
{
"type":"view",
"name":"搜索",
"url":"http://www.soso.com/"
@ -106,13 +102,14 @@ $wechat->menu->set(array(
### 创建子菜单
`$wechat->menu->make()` 方法以及 `$wechat->menu->click()` 或者 `$wechat->menu->view()` 返回的对象均为 `Overtrue\Wechat\Services\MenuItem` 对象,`MenuItem` 对象有一个方法 `buttons(array $items)` 指定**二级菜单**(子菜单)。
`Overtrue\Wechat\MenuItem` 对象有一个方法 `buttons(array $items)` 指定**二级菜单**(子菜单)。
```php
$wechat->menu->make('菜单')->buttons(array(
$wechat->menu->make('搜索', 'view', 'http://www.soso.com/'),
$wechat->menu->make('视频', 'view', 'http://v.qq.com/'),
$wechat->menu->make('赞一下我们', 'click', 'V1001_GOOD'),
$button = new MenuItem('菜单');
$button->buttons(array(
new MenuItem('搜索', 'view', 'http://www.soso.com/'),
new MenuItem('视频', 'view', 'http://v.qq.com/'),
new MenuItem('赞一下我们', 'click', 'V1001_GOOD'),
));
```
@ -126,8 +123,6 @@ $wechat->menu->make('菜单')->buttons(array(
赞一下我们
```
但是这样看起来似乎没有那么直观的感觉。 :laughing:
## Laravel 示例
输入菜单数组(从你的网站后台表单创建):
@ -163,41 +158,46 @@ $wechat->menu->make('菜单')->buttons(array(
```php
<?php
use Overtrue\Wechat\Wechat;
use Overtrue\Wechat\Menu;
use Overtrue\Wechat\MenuItem;
class WechatController {
//...
public function setWechatMenu() {
$wechat = Wechat::make(Config::get('wechat'));
public function setWechatMenu()
{
$appId = 'wx3cf0f39249eb0e60';
$secret = 'f1c242f4f28f735d4687abb469072a29';
$menus = Input::get('menu'); // menu 是后台管理中心表单post过来的一个数组
$target = []; //
$menu = new Menu($appId, $secret);
// 构建你的菜单
foreach ($menus as $menu) {
// 创建一个菜单项
$item = $wechat->menu->make($menu['name'], $menu['type'], $menu['key']);
$menus = Input::get('menus'); // menus 是你自己后台管理中心表单post过来的一个数组
// 子菜单
if (!empty($menu['buttons'])) {
$buttons = [];
foreach ($menu['buttons'] as $button) {
$buttons[] = $wechat->menu->make($button['name'], $button['type'], $button['key']);
}
$item->buttons($buttons);
$target = [];
// 构建你的菜单
foreach ($menus as $menu) {
// 创建一个菜单项
$item = new MenuItem($menu['name'], $menu['type'], $menu['key']);
// 子菜单
if (!empty($menu['buttons'])) {
$buttons = [];
foreach ($menu['buttons'] as $button) {
$buttons[] = $new MenuItem($button['name'], $button['type'], $button['key']);
}
$target[] = $item;
$item->buttons($buttons);
}
$wechat->menu->set($target); // 失败会抛出异常
$target[] = $item;
}
return Redirect::back()->withMessage('菜单设置成功!');
$menu->set($target); // 失败会抛出异常
return Redirect::back()->withMessage('菜单设置成功!');
}
//...
}
}
```

@ -1,6 +0,0 @@
```php
$wechat->ticket->js();
$wechat->ticket->card();
```
> 待补充

@ -1,30 +1,45 @@
本项目的用法目前网上其它 SDK 用法不同,这里只需要像下面这样配置一次完成
本项目中提供了很多服务,每个服务需要的初始化参数可能会有不同
```php
<?php
### 服务端
- 类名:`Overtrue\Wechat\Server`
- 初始化参数:`__construct($appId, $token, $encodingAESKey)`
use Overtrue\Wechat\Wechat;
### 消息
- 类名:`Overtrue\Wechat\Message`
- 初始化参数:无
$options = [
'appId' => 'Your app id', // 必填
'secret' => 'Your secret', // 必填
'token' => 'Your token', // 必填
'encodingAESKey' => 'Your encoding AES Key' // 加密模式需要,其它模式不需要
];
### 用户
- 类名:`Overtrue\Wechat\User`
- 初始化参数:`__construct($appId, $appSecret)`
>>>>>>> origin/develop
$wechat = Wechat::make($options);
### 用户组
- 类名:`Overtrue\Wechat\Group`
- 初始化参数:`__construct($appId, $appSecret)`
$server = $wechat->on('message', function($message){
error_log("收到来自'{$message['FromUserName']}'的消息:{$message['Content']}");
});
### 菜单
- 类名:`Overtrue\Wechat\Menu`
- 初始化参数:`__construct($appId, $appSecret)`
>>>>>>> origin/develop
$result = $wechat->serve();
### JSSDK
- 类名:`Overtrue\Wechat\Menu`
- 初始化参数:`__construct($appId, $appSecret)`
// 您可以直接echo 或者返回给框架
echo $result;
```
`$wechat->serve()` 方法返回的值为字符串或者空,用于应答微信服务器的推送,消息或者事件等。比如你如果使用的是 [Laravel](http://laravel.com) ,你这里就应该 `return $wechat->serve();`
### 客服
- 类名:`Overtrue\Wechat\Staff`
- 初始化参数:`__construct($appId, $appSecret)`
## 注意
### 门店
- 类名:`Overtrue\Wechat\Store`
- 初始化参数:`__construct($appId, $appSecret)`
所有的错误(比如设置自定义菜单失败)均通过抛出异常形式来控制,请参考:[错误处理](https://github.com/overtrue/wechat/wiki/%E9%94%99%E8%AF%AF%E5%A4%84%E7%90%86)
### 二维码
- 类名:`Overtrue\Wechat\QRCode`
- 初始化参数:`__construct($appId, $appSecret)`
### 素材
- 类名:`Overtrue\Wechat\Media`
- 初始化参数:`__construct($appId, $appSecret)`
请在使用中不要忘记引入命名空间。关于命名空间的使用:[PHP官方文档](http://php.net/manual/zh/language.namespaces.php)

@ -1,15 +1,28 @@
所有的错误均使用异常抛出
所有的错误均使用异常抛出,异常类名为 `Overtrue\Wechat\Exception`, 你可以使用常规的异常处理方法来处理本 SDK 所有的异常:
比如使用 `[set_exception_handler](http://php.net/manual/zh/function.set-exception-handler.php)`:
```php
$wechat->error(function($error){
error_log("code:" . $error->getCode . ' error: ' . $error->getMessage());
set_exception_handler(function($exception){
error_log("code:" . $exception->getCode . ' exception: ' . $exception->getMessage());
});
```
<<<<<<< HEAD
这里的回调函数的第一个参数为继承自 [`Exception`](http://php.net/manual/zh/class.exception.php) 的异常类,名称为 `Overtrue\Wechat\Exception`,所以你可以使用 `Exception` 类的所有方法。
- `$error->getCode()` 错误码ex: `40001`
- `$error->getMessage()` 错误消息
- `$error->getLine()` 错误行
=======
这里的回调函数的第一个参数为继承自 `[Exception](http://php.net/manual/zh/class.exception.php)` 的异常类,所以你可以使用 [Exception](http://php.net/manual/zh/class.exception.php) 的所有方法。
- `$exception->getCode()` 错误码ex: `40001`
- `$exception->getMessage()` 错误消息
- `$exception->getLine()` 错误行(当然这个没啥意义)
[PHP 错误处理](http://php.net/manual/zh/book.errorfunc.php)
[PHP 异常类](http://php.net/manual/zh/class.exception.php)
>>>>>>> origin/develop
当请求微信服务器失败或者返回错误时同样会触发此逻辑错误代码请参考http://mp.weixin.qq.com/wiki/17/fa4e1434e57290788bde25603fa2fcbd.html