最近遇到一个友盟分享url到微信的巨坑,分享时设置一个thumb,当如果修改thumb缩略图硬是不起作用,一直显示之前的缩略图。卸载了App重装,再分享同一个url,带上新的thumb还是不起作用。找了各种原因,也打开友盟的日志,都没有有价值报错。我猜是不是友盟自作聪明的将url?和thumb作了缓存,可是他没想到,我分享带缩略图可能会改的。我们公司的app分享时就要求有修改分享时缩略图的功能。
有了这个猜测之后,我就试图在分享的url后面添加一个时间戳,以抵消友盟做的url对应thumb缓存,终于凑效,再次分享显示的就是我新设置的缩略图。这个坑耽误了我一天时间,终于解决了。
public void share(SHARE_MEDIA media, String targeturl, String shareContent, String title, Object shareImageUrl) {
//友盟可能是缓存了,加个时间戳
if (targeturl.contains("?")) {
targeturl = targeturl.concat("&time=" + System.currentTimeMillis());
} else {
targeturl = targeturl.concat("?time=" + System.currentTimeMillis());
}
UMWeb web = new UMWeb(targeturl);
web.setTitle(title);//标题
web.setThumb(getUMImage(shareImageUrl)); //缩略图
web.setDescription(shareContent);//描述
final ShareAction shareAction = new ShareAction(mActivity);
shareAction
.withMedia(web)
.setPlatform(media)
.setCallback(new UMShareListener() {
@Override
public void onStart(SHARE_MEDIA share_media) {
Lg.d(TAG, "share on start");
//FiveStarDialog.showDialogIfNeed((AppCompatActivity) mActivity);
if (mIsShow)
showDialog(null);
}
@Override
public void onResult(SHARE_MEDIA share_media) {
Lg.d(TAG, "share on complete");
Log.d("ShareOrLogin", "share=>onResult:" + share_media);
if (mOnShareListener != null) {
if (!(mActivity instanceof PosterShareActivity) && !(mActivity instanceof TemplateShareActivity))
FiveStarDialog.showDialogIfNeed((AppCompatActivity) mActivity);
mOnShareListener.onShareSuccess();
}
hideDialog();
}
@Override
public void onError(SHARE_MEDIA share_media, Throwable throwable) {
Lg.d(TAG, "share on error");
if (mOnShareListener != null) {
mOnShareListener.onShareFail(throwable == null ? "" : throwable.getMessage());
}
hideDialog();
}
@Override
public void onCancel(SHARE_MEDIA share_media) {
Lg.d(TAG, "share on cancel");
hideDialog();
}
}).share();
hideDialog();
}
除了上面的坑,友盟还有一个坑。就是分享到微信时,如果图片超出微信的要求范围,友盟内部就不使用图片了,而是使用app的图标,我并不需要使用app的图标, 谁让他这么干的,友盟老是自作聪明,将原来可以暴露出来的问题,搞的不好排查。这位兄弟也是遇到同样的问题,https://www.jianshu.com/p/f01d6ee200e1解决方法就是使用友盟的Scale压缩方式。
|