微信素材管理之获取永久素材和删除永久素材

注意:获取永久素材/删除永久素材/新增永久素材 需要认证号,且接口限制为10

/**
     * 获取素材列表[永久]
     * $material_type [类型] image/video/voice/news 图片 视频 语音 图文
     * QVqFyY4hY4_xpPf_lO2OG1fIslTDY4wzkgg72IOeoDo
     * QVqFyY4hY4_xpPf_lO2OG80_sJiK4v2BGGq1-cwQSLU
     */
    function getMaterial($material_type="image",$offset=0,$count=20){
        $access_token=$this->getAccessToken();  
        $type = $material_type;
        $url = 'https://api.weixin.qq.com/cgi-bin/material/batchget_material?access_token='.$access_token;
        $filedata = array(
            'type' => $type,
            'offset' => $offset,
            'count' => $count
        );
        $filedata = json_encode($filedata,true);
        $result = $this->https_request($url, $filedata);
        $result = json_decode($result, true);
        dump($result);
    }

    /**
     * 删除永久素材
     * 
     */
    function delMaterial($media_id){
        $access_token = $this -> getAccessToken();
        $url="https://api.weixin.qq.com/cgi-bin/material/del_material?access_token=".$access_token;
        if(empty($media_id)){
            $this-> error('素材ID不能为空');
        }
        $filedata = array( 'media_id'=> $media_id);
        $filedata = json_encode($filedata,true);
        $result = $this->https_request($url, $filedata);
        $result = json_decode($result, true);
        if($result['errcode']==0){
            echo "素材删除成功";
        }elseif ($result['errcode']==40007) {
            echo "素材ID不正确";
        }
        dump($result);

    }

    //https请求(支持GET和POST)
    protected function https_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, 1);
        $output = curl_exec($curl);
        curl_close($curl);
        return $output;
    }
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
在Spring Boot中开发微信素材永久上传接口需要进行以下步骤: 1. 导入必要的依赖:首先在pom.xml文件中添加相关的依赖,如Spring Web、Spring Boot DevTools以及第三方库如Apache HttpComponents等。 2. 创建Access Token获取接口:微信接口需要Access Token进行身份验证。可以创建一个Controller类,定义一个调用微信API获取Access Token的方法,并使用Scheduled定时任务来定期刷新Access Token。在该方法中,可以使用HttpComponents库来发送请求并解析返回的JSON数据,最后将获取到的Access Token存储在一个全局变量中。 3. 创建素材上传接口:同样,创建一个Controller类,并定义一个用于处理上传素材的方法。在该方法中,需要先获取到之前获取的Access Token,然后使用HttpComponents库发送POST请求,将素材文件内容作为请求的Body发送给微信API。 4. 处理上传结果:根据微信API返回的结果,可以采取不同的处理方式。如果上传成功,可以将返回的MediaId等相关信息保存到数据库中。如果上传失败,可以返回相应的错误信息。 5. 配置文件设置:在application.properties或application.yml(根据实际使用的配置文件类型而定)中设置微信公众号的相关配置信息,如AppID、AppSecret等。在Controller类中可以通过@Value注解来读取并使用这些配置信息。 6. 异常处理:当出现异常情况时,可以使用Spring Boot的全局异常处理机制来统一处理异常,返回相应的错误信息。 通过以上步骤,我们可以在Spring Boot中开发一个用于微信素材永久上传的接口。接口可以通过访问URL来调用,将素材文件上传到微信服务器,并将上传结果返回给调用方。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

若水印象

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值