java调用微信分享

这篇文章主要是介绍如何使用java开发微信分享功能,因为工作,已经开发完成,可使用。下面有联系方式,可交流
如果想要自定义微信的分享功能,首先在自己的页面内首先使用AJAX。下面我具体举例。
首先是在页面内写入请求后台的AJAX

/**
     * 调用微信分享接口
     * */
    public void WXConfig(){
        String url = getPara("href");
        WXConfigController scan = new WXConfigController();
        Map<String, String> map = scan.sign(url);
        System.out.println("调用分享接口URL"+url);
        renderJson(map);
    }

1.这里当中有个是获得页面传来的当前地址href就是。
2.会调用一个方法类,这个可以个人习惯,也可以写在当前这个方法里,我只是写在另外的地方,调用而已。
3.返回一个json数据renderJson(map);
接下来就是进入我们调用的类了。WXConfigController的sign(url)这个方法,这个类不涉及调用其它类的方法,只有这一个类里面生成我们所需要的参数

package com.joffro.wine.controller.front;

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;
import com.jfinal.kit.PropKit;
import com.joffro.web.common.controller.ControllerPath;
import com.joffro.weixin.WeixinUtil;

@ControllerPath(controllerKey = "/Joffro/wxconfig")
public class WXConfigController extends FrontController {

    public static String accessToken = null;  

    public Map<String, String> sign(String url) {
        String aToken = WeixinUtil.getAccess_token("https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid="+你的APPID+"&secret="+你的appSecret+"");  
        String[] tokenOne = aToken.split(":");
        String[] token = tokenOne[1].split(",");
        char [] stringArr = token[0].toCharArray();
        String token3 = "" ;
        for(int i=1;i<stringArr.length-1;i++){
            String token2 = String.valueOf(stringArr[i]);
            token3 += token2;
        }
        String jsapi_ticket =WeixinUtil.getAccess_token("https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token="+token3+"&type=jsapi");
        String[] jsapi1 = jsapi_ticket.split(":");
        String[] jsapi2 = jsapi1[3].split(",");
        char [] stringArray = jsapi2[0].toCharArray();
        String ticket3 = "" ;
        for(int i=1;i<stringArray.length-1;i++){
            String ticket = String.valueOf(stringArray[i]);
            ticket3 += ticket;
        } 
        Map<String, String> ret = new HashMap<String, String>();  
        String nonce_str = create_nonce_str();  //随机串
        String timestamp = create_timestamp();  //时间戳
        String string1;  
        String signature = "";
        //注意这里参数名必须全部小写,且必须有序  
        string1 = "jsapi_ticket=" + ticket3 +  
                  "&noncestr=" + nonce_str +  
                  "&timestamp=" + timestamp +  
                  "&url=" + url;  
        System.out.println("string1="+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", ticket3);  
        ret.put("nonceStr", nonce_str);  
        ret.put("timestamp", timestamp);  
        ret.put("signature", signature);  
        ret.put("appId", PropKit.use("system.properties").get("appId"));   
        return ret;  
    }  
    /** 
     * 获取用户基本信息
     * @param hash 
     * @return 
     */ 
    public void getUserByopenid(){
        String aToken = WeixinUtil.getAccess_token("https://api.weixin.qq.com/sns/userinfo?access_token=ACCESS_TOKEN&openid=OPENID&lang=zh_CN");  

    }

    /** 
     * 随机加密 
     * @param hash 
     * @return 
     */  
    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;  
    }  

    /** 
     * 产生随机串--由程序自己随机产生 
     * @return 
     */  
    private static String create_nonce_str() {  
        return UUID.randomUUID().toString();  
    }  

    /** 
     * 由程序自己获取当前时间 
     * @return 
     */  
    private static String create_timestamp() {  
        return Long.toString(System.currentTimeMillis() / 1000);  
    }  
}

1.这里如果成功了就会进入这个方法。

wx.ready(function(){
        //分享朋友
        wx.onMenuShareAppMessage({
            title: '转盘大抽奖', // 分享标题
            desc: '转盘大抽奖,好奖等你拿', // 分享描述
            link: 'http://open.weixin.qq.com/connect/oauth2/authorize?appid='你的APPID'&redirect_uri=www.baidu.com', // 分享链接
            imgUrl: 'http://www.****.com/*****/static/img/line.png', // 分享图标
            trigger: function (res) {
                    alert(res.);
                },
            success: function () { 
                // 用户确认分享后执行的回调函数
                alert("分享成功");
                // 用户确认分享后执行的回调函数,跳转后台
                //获取openid
                var openid = $("#openid").val();
                location.href = "/*****/shareOk?openid="+openid;
            },
            cancel: function () { 
                // 用户取消分享后执行的回调函数
                alert("分享失败");
            }
        });
        //分享朋友圈
        wx.onMenuShareTimeline({
            title: '大抽奖', // 分享标题
            link: 'www.baidu.com', // 分享链接
            imgUrl: 'http://www.*****.com/******/static/img/line.png', // 分享图标
            success: function () { 
                alert("分享成功");
                // 用户确认分享后执行的回调函数,跳转后台
                //获取openid
                var openid = $("#openid").val();
                location.href = "/*******/shareOk?openid="+openid;  
            },
            cancel: function () { 
                // 用户取消分享后执行的回调函数
                alert("分享失败");
            }
        });

    });

成功进入,就会进入上面的JS,然后点击手机微信右上角的几个点,里面的分享,点击后,分享的就是我们自定义的内容。两个JS是在同一篇文件中。
如果有问题,可以沟通:QQ:767604112

  • 4
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值