• 临时素材
    • 上传图片
    • 上传声音
    • 上传视频
    • 上传缩略图
    • 上传群发视频
    • 创建群发消息
    • 获取临时素材内容
    • 获取 JSSDK 上传的高清语音

    临时素材

    上传的临时多媒体文件有格式和大小限制,如下:

    • 图片(image): 2M,支持 JPG 格式
    • 语音(voice):2M,播放长度不超过 60s,支持 AMR\MP3 格式
    • 视频(video):10MB,支持 MP4 格式
    • 缩略图(thumb):64KB,支持 JPG 格式

    上传图片

    {warning} 注意:微信图片上传服务有敏感检测系统,图片内容如果含有敏感内容,如色情,商品推广,虚假信息等,上传可能失败。

    1. $app->media->uploadImage($path);

    上传声音

    1. $app->media->uploadVoice($path);

    上传视频

    1. $app->media->uploadVideo($path, $title, $description);

    上传缩略图

    用于视频封面或者音乐封面。

    1. $app->media->uploadThumb($path);

    上传群发视频

    上传视频获取 media_id 用以创建群发消息用。

    1. $app->media->uploadVideoForBroadcasting($path, $title, $description);
    2. //{
    3. // "media_id": "rF4UdIMfYK3efUfyoddYRMU50zMiRmmt_l0kszupYh_SzrcW5Gaheq05p_lHuOTQ",
    4. // "title": "TITLE",
    5. // "description": "Description"
    6. //}

    创建群发消息

    不要与上面 上传群发视频 搞混了,上面一个是上传视频得到 media_id,这个是使用该 media_id 加标题描述 创建一条消息素材 用来发送给用户。详情参见:消息群发

    1. $app->media->createVideoForBroadcasting($mediaId, $title, $description);
    2. //{
    3. // "type":"video",
    4. // "media_id":"IhdaAQXuvJtGzwwc0abfXnzeezfO0NgPK6AQYShD8RQYMTtfzbLdBIQkQziv2XJc",
    5. // "created_at":1398848981
    6. //}

    获取临时素材内容

    比如图片、语音等二进制流内容,响应为 EasyWeChat\Kernel\Http\StreamResponse 实例。

    1. $stream = $app->media->get($mediaId);
    2. if ($stream instanceof \EasyWeChat\Kernel\Http\StreamResponse) {
    3. // 以内容 md5 为文件名存到本地
    4. $stream->save('保存目录');
    5. // 自定义文件名,不需要带后缀
    6. $stream->saveAs('保存目录', '文件名');
    7. }

    获取 JSSDK 上传的高清语音

    1. $stream = $app->media->getJssdkMedia($mediaId);
    2. $stream->saveAs('保存目录', 'custom-name.speex');