微信分享朋友圈或好友java代码

 

1、获取AccessToken

AccessToken获取方法

2、获取 JsApiTicket  

JsApiTicket 获取方法

3、根据 ticket 和 要分享的页面url地址去签名


import cn.hutool.setting.dialect.Props;

import java.io.UnsupportedEncodingException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.util.Formatter;
import java.util.HashMap;
import java.util.Map;
import java.util.UUID;


public  class WXShareUtil {
	private static Props props = new Props("wei-xin.properties", "utf-8");
	private static String appId = props.getStr("app_id");

	public static Map<String, Object> sign(String jsapi_ticket,String url) {
		Map<String, Object> ret = new HashMap<String, Object>();
		String nonce_str = create_nonce_str();
			String timestamp = create_timestamp();
			String string1;
			String signature = "";
			// 注意这里参数名必须全部小写,且必须有序
			string1 = "jsapi_ticket=" + jsapi_ticket + "&noncestr=" + nonce_str
					+ "&timestamp=" + timestamp + "&url=" + url;
			//System.out.println(string1+"==================================");
			try {
				MessageDigest crypt = MessageDigest.getInstance("SHA-1");
				crypt.reset();
			crypt.update(string1.getBytes("UTF-8"));
			signature = byteToHex(crypt.digest());
		} catch (NoSuchAlgorithmException e) {
			e.printStackTrace();
		} catch (UnsupportedEncodingException e) {
			e.printStackTrace();
		}
		ret.put("url", url);
		ret.put("jsapi_ticket", jsapi_ticket);
		ret.put("nonceStr", nonce_str);
		ret.put("timestamp", timestamp);
		ret.put("signature", signature);
		ret.put("appid",appId);
		return ret;
	}

	private static String byteToHex(final byte[] hash) {
		Formatter formatter = new Formatter();
		for (byte b : hash) {
			formatter.format("%02x", b);
		}
		String result = formatter.toString();
		formatter.close();
		return result;
	}

	private static String create_nonce_str() {
		return UUID.randomUUID().toString();
	}

	private static String create_timestamp() {
		return Long.toString(System.currentTimeMillis() / 1000);
	}
}

4、调用

       // 根据你的实际情况获取accessToken  和 jsApi_ticket
 
        //获取accessToken
        String accessToken = WXRedisParam.getAccessToken(app_id,appSecret);
        //获取jsApi_ticket
        String ticket = WXRedisParam.getJsApiTicket(accessToken,app_id);
        Map<String, Object> sign = WXShareUtil.sign(ticket,url);
        String link = WeChatCode.links_start+userId+","+goodId+ WeChatCode.links_end;
        //link = WXUtils.longToShort(link);//获取微信短链接
        JSONObject object = new JSONObject();
        object.put("sign",sign);
        object.put("url",link);
        object.put("img",good.getPic());
        object.put("title",good.getTitle());
        object.put("desc",good.getAccount());
        return object;

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
2021已然来临,在此之际debug抽空撸了一套 类似“QQ空间”、“新浪微博”、“微信朋友圈”PC版的互联网社交软件系统,并将其录制成了视频,特此分享给诸位进行学习,以掌握、巩固更多的技术栈和项目、产品开发经验! 言归正常,下面以问答的方式重点介绍下本门课程/系统的相关内容!  (1)问题一:这是一门什么样的课程? 本门课程是一门项目实战课程,基于Spring Boot2.X开发的一款类似“新浪微博”、“QQ空间”、“微信朋友圈”PC版的互联网社交软件,包含完整的门户网前端 以及 后台系统管理端,可以说是一套相当完整的系统!,大纲图如下所示:  而整个系统的系统架构设计如下图所示(注意:该图表示的是整个系统架构将经历N个阶段的演进,目前初定是4个阶段的演进,分别是架构1.0、2.0、3.0、4.0 !)   (2)问题二:可以学到哪些技术? 本课程对应着系统架构1.0,即第一阶段,主要的目标在于实现一个完整的系统,可以学到的技术还是比较多的:Spring Boot2.X、Java基础、Java8、JUC、NIO、微服务、分布式、系统架构设计、SpringMVC、MySQL、Lucene、多线程、并发编程、Bootstrap、HTML5、CSS3、JQuery、AdminLTE、VUE、LayUI相关组件等等 从架构2.0,即第二阶段的内容(对应第2门课程)开始将慢慢融入更多地技术栈,用以解决更多的业务、性能和服务拆分等问题!本门课程是后续其他阶段对应的课程的奠基,因此如果想要学习后续架构2.0、3.0、4.0的演进,则必须得先学习本门课程!   (3)问题三:系统运行起来有效果图看吗?   (4)问题四:学习本课程之前有什么要求? 要求的话,主要有两点,一是要有一定的Spring Boot、MySQL 以及 Web开发基础;二是最好学过Debug录制的 “企业权限管理平台(Spring Boot2.X+Shiro+Vue)”项目实战课程,因为本门课程“仿微博系统全程实战”的后台管理正是基于 “企业权限管理平台”项目二次开发的,因此建议最好先撸了那个课程再来学习本门课程! 友情提示:“企业权限管理平台(Spring Boot2.X+Shiro+Vue)”项目实战课程的购买学习地址:https://edu.csdn.net/course/detail/25646  (TIP:可以考虑购买组合套餐课程哦,更加实惠!!!)  岁末将至,人心浮躁 当此之际,应当沉下心,摒弃浮躁 要相信技术是第一生产力 相信技术改变生活、技术成就梦想! 特别是那些即将在过完年准备跳槽面试的小伙伴,本系统将可以为你增添几分亮点!!!  寄语:购买本课程的小伙伴将可获得本课程完整的视频教程、系统源代码数据库、课件PPT以及其他相关的工具跟资料,还可以进专属技术交流群交流技术!!!
要实现在微信分享朋友圈的功能,需要使用JavaScript编写对应的代码。具体的流程如下: 1. 添加微信JS-SDK库文件:在HTML页面中引入微信JS-SDK的库文件,这样才能使用微信提供的接口功能。 2. 获取签名:在后台服务器中,使用自己的微信公众号AppID和AppSecret等信息,请求微信接口获取签名。这个签名是用来验证当前网页是否为可信来源,以防止恶意篡改。 3. 配置微信分享参数:将获取到的签名和其他相关信息配置到前端代码中。需要设置分享的标题、描述、跳转链接等参数。 4. 注册分享事件:监听用户点击分享按钮的动作,触发分享朋友圈的操作。 5. 生成海报:可以使用Canvas或其他HTML5技术,在页面中绘制出想要分享的内容,比如文本、图片等。 6. 上传海报图片:将生成的海报转换为图片格式,并上传到服务器上。这可以通过将Canvas的数据转换为Base64编码的图像数据,然后通过AJAX请求将图像数据上传到服务器。 7. 分享海报:使用微信的接口,将上传到服务器的海报图片链接分享朋友圈。 8. 监听分享结果:根据微信接口返回的结果,可以对分享成功或失败的情况进行处理,例如弹出提示信息。 以上就是实现在微信分享朋友圈并生成海报的大致步骤。通过合理的代码编写和配置,就可以在微信中实现自定义的朋友圈分享功能。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值