下载网络图片上传至微信临时素材

下载网络图片上传至微信临时素材,获取madea_id;

读取本地图片同样适用,只需获取本地文件输入流,调用upLoadImageToWeChat()方法即可:

getMediaId
public String getMediaId(String imgUrl) {
    String mediaId = "";
    if (StringUtils.isNotEmpty(imgUrl)) {//下载图片
        OkHttpClient client = new OkHttpClient();
        Request req = new Request.Builder().url(imgUrl).build();
        Response resp = null;
        try {
            resp = client.newCall(req).execute();

            if (resp.isSuccessful()) {
                ResponseBody body = resp.body();
                //获取输入流
                InputStream inputStream = body.byteStream();
                //使用输入流发送图片至微信
                mediaId = upLoadImageToWeChat(inputStream, imgUrl);
            }
        } catch (IOException e) {
            logger.error("下载网络图片出错!{}", e);
            throw new ServiceException(e.getMessage(), e);
        }
    }
    return mediaId;
}
upLoadImageToWeChat
private String upLoadImageToWeChat(InputStream inputStream, String filename) throws IOException {
    String url = weChatMediaUploadUrl + "?access_token=" + loginService.getWeChatAccessToken() + "&type=image";

    URL urlObj = new URL(url);
    //连接
    HttpURLConnection con = (HttpURLConnection) urlObj.openConnection();
    String result = null;
    con.setDoInput(true);

    con.setDoOutput(true);

    con.setUseCaches(false); // post方式不能使用缓存

    // 设置请求头信息
    con.setRequestProperty("Connection", "Keep-Alive");
    con.setRequestProperty("Charset", "UTF-8");
    // 设置边界
    String BOUNDARY = "----------" + System.currentTimeMillis();
    con.setRequestProperty("Content-Type",
            "multipart/form-data; boundary="
                    + BOUNDARY);

    //获取输入流字节长度
    int length = inputStream.available();
    // 请求正文信息
    // 第一部分:
    StringBuilder sb = new StringBuilder();
    sb.append("--"); // 必须多两道线
    sb.append(BOUNDARY);
    sb.append("\r\n");
    sb.append("Content-Disposition: form-data;name=\"media\";filelength=\"" + length + "\";filename=\""
            + filename + "\"\r\n");
    sb.append("Content-Type:application/octet-stream\r\n\r\n");
    byte[] head = sb.toString().getBytes("utf-8");
    // 获得输出流
    OutputStream out = new DataOutputStream(con.getOutputStream());
    // 输出表头
    out.write(head);

    // 文件正文部分
    // 把文件已流文件的方式 推入到url中
    int bytes = 0;
    byte[] bufferOut = new byte[1024];
    while ((bytes = inputStream.read(bufferOut)) != -1) {
        out.write(bufferOut, 0, bytes);
    }
    inputStream.close();
    // 结尾部分
    byte[] foot = ("\r\n--" + BOUNDARY + "--\r\n").getBytes("utf-8");// 定义最后数据分隔线
    out.write(foot);
    out.flush();
    out.close();
    StringBuffer buffer = new StringBuffer();
    BufferedReader reader = null;
    try {
        // 定义BufferedReader输入流来读取URL的响应
        reader = new BufferedReader(new InputStreamReader(con.getInputStream()));
        String line = null;
        while ((line = reader.readLine()) != null) {
            buffer.append(line);
        }
        if (result == null) {
            result = buffer.toString();
        }
    } catch (IOException e) {
        System.out.println("发送POST请求出现异常!" + e);
        e.printStackTrace();
    } finally {
        if (reader != null) {
            reader.close();
        }
    }
    // 获取到返回HTTP结果
    Map<String, Object> map = JSONObject.parseObject(result, Map.class);
    if (map.containsKey("media_id")) {
        //微信临时文件保存3天,根据业务可以使用redis缓存该media_id,并起一定时任务每两天更新该值
        //redisTemplate.opsForValue().set(titleKey, map.get("media_id").toString(),25, TimeUnit.HOURS);
        return map.get("media_id").toString();
    } else {
        logger.error("小程序上传临时素材出错,返回信息为:  {}  " + JSON.toJSONString(result));
        throw new ServiceException("小程序上传临时素材出错,返回信息为:" + JSON.toJSONString(result));
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个使用 Node.js 调用企业微信上传临时素材 API 上传网络图片的示例代码: ```javascript const https = require('https'); const fs = require('fs'); const path = require('path'); const accessToken = 'your_access_token'; const baseUrl = 'https://qyapi.weixin.qq.com/cgi-bin/'; const imageUrl = 'https://example.com/image.png'; const uploadUrl = baseUrl + 'media/upload?access_token=' + accessToken + '&type=image'; https.get(imageUrl, (res) => { let data = ''; res.setEncoding('binary'); res.on('data', (chunk) => { data += chunk; }); res.on('end', () => { const fileName = path.basename(imageUrl); const fileData = new Buffer(data, 'binary'); const postData = { 'media': fileData }; const requestOptions = { method: 'POST', headers: { 'Content-Type': 'multipart/form-data' } }; const req = https.request(uploadUrl, requestOptions, (res) => { let body = ''; res.on('data', (chunk) => { body += chunk; }); res.on('end', () => { const response = JSON.parse(body); if (response.errcode === 0) { console.log('上传成功,素材 ID:' + response.media_id); } else { console.error('上传失败:' + response.errmsg); } }); }); const boundaryKey = Math.random().toString(16); const boundary = '----' + boundaryKey; const endBoundary = '\r\n--' + boundary + '--\r\n'; const contentDisposition = 'Content-Disposition: form-data; name="media"; filename="' + fileName + '"\r\n'; const contentType = 'Content-Type: image/png\r\n\r\n'; const payload = '--' + boundary + '\r\n' + contentDisposition + contentType + fileData.toString('binary') + endBoundary; req.write(payload); req.end(); }); }).on('error', (e) => { console.error('下载图片时发生错误:' + e.message); }); ``` 请将 `your_access_token` 替换为您的企业微信应用的 access_token,`imageUrl` 替换为您的网络图片的 URL。此代码将从指定的 URL 下载图片,并使用 multipart/form-data 格式,将图片文件上传到企业微信临时素材库中。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值