微信自定义分享,不含图片上传

前者时间,开发了3个资源消息类的花色,但销售部门举办微信推广时,分享的链接直接是网页链接加分享符号,即难看又非驴非马,于是商量了弹指间微信自定义的分享效用

一,下载地址:

  1)依据供给下载相应版本

    例 
Java:选择jsp+utf-8;

一,下载地址:

  1)依照需求下载相应版本

    例 
Java:选择jsp+utf-8;

EasyUI 时间插件使用安顿,easyui插件

未安顿自义定分享时,分享的页面:澳门葡京 1

二,放置在档次中

  1)解压下载文件,玉石俱焚命名为editor;

  2)复制文件放置在档次webapp目录下;

  3)把editor目录下的js文件(一个)剪切放在你的js文件目录下;

  4)复制editor内整个文件到js目录一份(不复制能够选择,但页面会报404荒谬,估摸是在开端化时供给拜访其余文件)

二,放置在档次中

  1)解压下载文件,同等看待命名为editor;

  2)复制文件放置在类型webapp目录下;

  3)把editor目录下的js文件(三个)剪切放在你的js文件目录下;

  4)复制editor内任何文书到js目录一份(不复制能够运用,但页面会报404荒唐,猜度是在开端化时索要拜访其他文件)

一,在类型中引入jquery-easyui

打响布署后:澳门葡京 2  

三,配置静态财富映射

  1)在Springmvc.xml配置文件中配置相应属性(前提是曾经在web.xml中配备了对应布署);

    web.xml配置:  

          <servlet>
          <servlet-name>portal</servlet-name>
微信自定义分享,不含图片上传。          <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
          <!– contextConfigLocation不是必须的,
假若不布置contextConfigLocation,

          springmvc的布局文件默许在:WEB-INF/servlet的name+”-servlet.xml”
–>
          <init-param>
          <param-name>contextConfigLocation</param-name>
          <param-value>classpath:spring/springmvc.xml</param-value>
          </init-param>
          <load-on-startup>1</load-on-startup>
          </servlet>

          <servlet-mapping>
          <servlet-name>portal</servlet-name>
          <url-pattern>/</url-pattern>
          </servlet-mapping>

    Springmvc配置:    

          <mvc:resources mapping=”/umeditor/**”
location=”/umeditor/” />      
          <mvc:resources mapping=”/js/**” location=”/js/”
/>

三,配置静态财富映射

  1)在Springmvc.xml配置文件中布局相应属性(前提是早已在web.xml中布署了相应安排);

    web.xml配置:  

          <servlet>
          <servlet-name>portal</servlet-name>
          <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
          <!– contextConfigLocation不是必须的,
假如不布署contextConfigLocation,

          springmvc的布署文件私下认可在:WEB-INF/servlet的name+”-servlet.xml”
–>
          <init-param>
          <param-name>contextConfigLocation</param-name>
          <param-value>classpath:spring/springmvc.xml</param-value>
          </init-param>
          <load-on-startup>1</load-on-startup>
          </servlet>

          <servlet-mapping>
          <servlet-name>portal</servlet-name>
          <url-pattern>/</url-pattern>
          </servlet-mapping>

    Springmvc配置:    

          <mvc:resources mapping=”/umeditor/**”
location=”/umeditor/” />      
          <mvc:resources mapping=”/js/**” location=”/js/”
/>

二,静态财富映射

  1)<mvc:resources mapping=”/jquery-easyui-1.5.2/**”
location=”/easyui/” />

最初准备干活:

四,页面配置

  1)在head引入文件:    

        <meta http-equiv=”Content-Type” content=”text/html;
charset=utf-8″/>
        <link href=”umeditor/themes/default/css/umeditor.css”
type=”text/css” rel=”stylesheet”>
        <script type=”text/javascript”
src=”umeditor/third-party/jquery.min.js”></script>
        <script type=”text/javascript”
src=”umeditor/third-party/template.min.js”></script>
        <script type=”text/javascript” charset=”utf-8″
src=”js/umeditor.config.js”></script>
        <script type=”text/javascript” charset=”utf-8″
src=”js/umeditor.min.js”></script>
        <script type=”text/javascript”
src=”umeditor/lang/zh-cn/zh-cn.js”></script>

  2)画出div放置编辑器:        

        <!– 文本编辑器地方 –>
        <div id=”myEditor”
style=”width:1000px;height:240px;”>
          <p>提醒内容</p>
        </div>

  3)实例化编辑器:        

        <script type=”text/javascript”>
          //实例化编辑器
          var um = UM.getEditor(‘myEditor’);

        </script>

澳门葡京 ,  4)常用方法(别的见官网demo):        

        <input type=”button” value=”获取内容”
onclick=”getAllHtml()”>
        <input type=”button” value=”填充内容”
onclick=”setAllHtml()”>

 

        <script type=”text/javascript”>

        //获取内容
        function getAllHtml() {
        alert(UM.getEditor(‘myEditor’).getContent())
        }

        //填充内容
        function setAllHtml() {
        alert(UM.getEditor(‘myEditor’).setContent())
        }

        </script>

四,页面配置

  1)在head引入文件:    

        <meta http-equiv=”Content-Type” content=”text/html;
charset=utf-8″/>
        <link href=”umeditor/themes/default/css/umeditor.css”
type=”text/css” rel=”stylesheet”>
        <script type=”text/javascript”
src=”umeditor/third-party/jquery.min.js”></script>
        <script type=”text/javascript”
src=”umeditor/third-party/template.min.js”></script>
        <script type=”text/javascript” charset=”utf-8″
src=”js/umeditor.config.js”></script>
        <script type=”text/javascript” charset=”utf-8″
src=”js/umeditor.min.js”></script>
        <script type=”text/javascript”
src=”umeditor/lang/zh-cn/zh-cn.js”></script>

  2)画出div放置编辑器:        

        <!– 文本编辑器地方 –>
        <div id=”myEditor”
style=”width:1000px;height:240px;”>
          <p>提示内容</p>
        </div>

  3)实例化编辑器:        

        <script type=”text/javascript”>
          //实例化编辑器
          var um = UM.getEditor(‘myEditor’);

        </script>

  4)常用方法(别的见官网demo):        

        <input type=”button” value=”获取内容”
onclick=”getAllHtml()”>
        <input type=”button” value=”填充内容”
onclick=”setAllHtml()”>

 

        <script type=”text/javascript”>

        //获取内容
        function getAllHtml() {
        alert(UM.getEditor(‘myEditor’).getContent())
        }

        //填充内容
        function setAllHtml() {
        alert(UM.getEditor(‘myEditor’).setContent())
        }

        </script>

三,页面配置

  1)在head中引入:

        <link rel=”stylesheet” type=”text/css”
href=”jquery-easyui-1.5.2/themes/default/easyui.css”/>
        <link rel=”stylesheet” type=”text/css”
href=”jquery-easyui-1.5.2/themes/icon.css”/>
        <script type=”text/JavaScript”
src=”jquery-easyui-1.5.2/jquery.min.js”/></script>
        <script type=”text/javascript”
src=”jquery-easyui-1.5.2/jquery.easyui.min.js”/></script>
        <script type=”text/javascript”
src=”jquery-easyui-1.5.2/locale/easyui-lang-zh_CN.js”/></script><!– 
汉化  –>

  2)在急需利用时间的地方放置标签:          

        发轫日期:<input class=”easyui-datebox”
name=”begindate” id=”begindate”
        data-options=”formatter:myformatter,parser:myparser”></input>

  3)设置时间格式:

        <script type=”text/javascript”>

        <!– 设置时间格式 原来是12-11-2017
设置之后是2017-11-12 –>
        <script type=”text/javascript”>
        function myformatter(date) {
        var y = date.getFullYear();
        var m = date.getMonth() + 1;
        var d = date.getDate();
        return y + ‘-‘ + (m < 10 ? (‘0’ + m) : m) + ‘-‘
        + (d < 10 ? (‘0’ + d) : d);
        }
        function myparser(s) {
        if (!s)
        return new Date();
        var ss = (s.split(‘-‘));
        var y = parseInt(ss[0], 10);
        var m = parseInt(ss[1], 10);
        var d = parseInt(ss[2], 10);
        if (!isNaN(y) && !isNaN(m) && !isNaN(d)) {
        return new Date(y, m – 1, d);
        } else {
        return new Date();
          }
        }

        </script>

1.认证公众号的appId,appSecret

五,效果图

    澳门葡京 3  

五,效果图

    澳门葡京 4  

四,常用方法    

           获取时间:<input type=”button” value=”获取时间”
onclick=”getDate()”>
        填充时间:<input type=”button” value=”填充时间”
onclick=”setDate()”>

        <script type=”text/javascript”>

        //获取时间
        function getDate(){
        alert($(‘#begindate’).datebox(‘getValue’));
        }
        //填充时间
        function setDate(){
        $(“#begindate”).datebox(‘setValue’,’2017-11-11′);
        }

        </script>

2.各个获取微信音讯链接,封装在安插文件里(此部分查找微信自定义分享API,地址:)

五,效果图

澳门葡京 5

时间插件使用安插,easyui插件
一,在类型中引入jquery-easyui 二,静态财富映射 1)mvc:resources
mapping=”/jquery-easyui-1.5.2/**” location=”/easyui/…

 # 获取access_token请求地址
  getAccessTokenUrl: https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=%s&secret=%s
  #获取accessToken
  getAccessTokenOAuthUrl: https://api.weixin.qq.com/sns/oauth2/access_token?appid=%s&secret=%s&code=%s&grant_type=authorization_code
  # 获取用户基本信息请求地址
  getUserInfoUrl: https://api.weixin.qq.com/sns/userinfo?access_token=%s&openid=%s&lang=zh_CN
  #获取code
  getCodeUrl: https://open.weixin.qq.com/connect/oauth2/authorize?appid=%s&redirect_uri=%s&response_type=%s&scope=%s&state=%s#wechat_redirect
  #获取ticket
  getTicketUrl: https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token=%s&type=jsapi

3.controller层

       /**
     * 微信配置信息实体
     */
    @Autowired
    private WeiXinProperties weiXinProperties;
    //微信参数
    private String accessToken;
    private String jsApiTicket;
    //获取参数的时刻
    private Long getTiketTime = 0L;
    private Long getTokenTime = 0L;
    //参数的有效时间,单位是秒(s)
    private Long tokenExpireTime = 0L;
    private Long ticketExpireTime = 0L;

 /**
     * 微信自定义分享
     */
    @RequestMapping(value = "/getShareInfo", method = RequestMethod.POST)
    public Map<String, String> getShareInfo(HttpServletRequest request,
                                            HttpServletResponse response, String url) {
        //当前时间
        long now = System.currentTimeMillis();

        //判断accessToken是否已经存在或者token是否过期
        if (StringUtils.isBlank(accessToken) || (now - getTokenTime > tokenExpireTime * 1000)) {
            JSONObject tokenInfo = getAccessToken();
            if (tokenInfo != null) {
                accessToken = tokenInfo.getString("access_token");
                tokenExpireTime = tokenInfo.getLongValue("expires_in");
                //获取token的时间
                getTokenTime = System.currentTimeMillis();
                log.info("accessToken====>" + accessToken);
                log.info("tokenExpireTime====>" + tokenExpireTime + "s");
                log.info("getTokenTime====>" + getTokenTime + "ms");
            } else {
                log.info("====>tokenInfo is null~");
                log.info("====>failure of getting tokenInfo,please do some check~");
            }
        }
        //判断jsApiTicket是否已经存在或者是否过期
        if (StringUtils.isBlank(jsApiTicket) || (now - getTiketTime > ticketExpireTime * 1000)) {
            JSONObject ticketInfo = getJsApiTicket(accessToken);
            if (ticketInfo != null) {
                log.info("ticketInfo====>" + ticketInfo.toJSONString());
                jsApiTicket = ticketInfo.getString("ticket");
                ticketExpireTime = ticketInfo.getLongValue("expires_in");
                getTiketTime = System.currentTimeMillis();
                log.info("jsApiTicket====>" + jsApiTicket);
                log.info("ticketExpireTime====>" + ticketExpireTime + "s");
                log.info("getTiketTime====>" + getTiketTime + "ms");
            } else {
                log.info("====>ticketInfo is null~");
                log.info("====>failure of getting tokenInfo,please do some check~");
            }
        }
        //生成微信权限验证的参数
        Map<String, String> wechatParam = makeWXTicket(jsApiTicket, url);
        return wechatParam;

    }

    //获取accessToken
    private JSONObject getAccessToken() {
        //String accessTokenUrl = https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET
        //获取微信端的accessToken
        String requestUrl = String.format(weiXinProperties.getGetAccessTokenUrl(), weiXinProperties.getAppId(), weiXinProperties.getAppSecret());
        String result = send(requestUrl);
        JSONObject jsonObject = JSON.parseObject(result);
        return jsonObject;
    }

    //获取ticket
    private JSONObject getJsApiTicket(String access_token) {
        //String apiTicketUrl = https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token=ACCESS_TOKEN&type=jsapi
        // 通过acessToken 获取ticket
        String requestUrl = String.format(weiXinProperties.getGetTicketUrl(), access_token);
        String result = send(requestUrl);  //此部分用到了我们项目的工具类,整段复制本代码时,可以用以下代替
     //JSONObject jsonObject = httpUtils.doGet(requestUrl)
        JSONObject jsonObject = JSON.parseObject(result);
        return jsonObject;
    }

    //生成微信权限验证的参数
    public Map<String, String> makeWXTicket(String jsApiTicket, String url) {
        Map<String, String> ret = new HashMap<String, String>();
        String nonceStr = createNonceStr();
        String timestamp = createTimestamp();
        String string1;
        String signature = "";

        //注意这里参数名必须全部小写,且必须有序
        string1 = "jsapi_ticket=" + jsApiTicket +
                "&noncestr=" + nonceStr +
                "&timestamp=" + timestamp +
                "&url=" + url;
        log.info("String1=====>" + string1);
        try {
            MessageDigest crypt = MessageDigest.getInstance("SHA-1");
            crypt.reset();
            crypt.update(string1.getBytes("UTF-8"));
            signature = byteToHex(crypt.digest());
            log.info("signature=====>" + signature);
        } catch (NoSuchAlgorithmException e) {
            log.error("WeChatController.makeWXTicket=====Start");
            log.error(e.getMessage(), e);
            log.error("WeChatController.makeWXTicket=====End");
        } catch (UnsupportedEncodingException e) {
            log.error("WeChatController.makeWXTicket=====Start");
            log.error(e.getMessage(), e);
            log.error("WeChatController.makeWXTicket=====End");
        }

        ret.put("url", url);
        ret.put("jsapi_ticket", jsApiTicket);
        ret.put("nonceStr", nonceStr);
        ret.put("timestamp", timestamp);
        ret.put("signature", signature);
        ret.put("appid", weiXinProperties.getAppId());

        return ret;
    }

    /**
     * 发送请求
     *
     * @param url
     * @return
     * @throws Exception
     */
    String send(String url) {
        return HttpClientTools.post(url);
    }

    //字节数组转换为十六进制字符串
    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 createNonceStr() {
        return UUID.randomUUID().toString();
    }

    //生成时间戳
    private static String createTimestamp() {
        return Long.toString(System.currentTimeMillis() / 1000);
    }

4.引入share.js.要分享的页面

$(function(){
    var url = location.href.split('#').toString();//url不能写死
    $.ajax({
        type : "post",
        url : "/user/login/getShareInfo",
        dataType : "json",
        async : false,
        data:{url:url},
        success : function(data) {
            wx.config({
                debug: false,////生产环境需要关闭debug模式
                appId: data.appid,//appId通过微信服务号后台查看
                timestamp: data.timestamp,//生成签名的时间戳
                nonceStr: data.nonceStr,//生成签名的随机字符串
                signature: data.signature,//签名
                jsApiList: [//需要调用的JS接口列表
                    'checkJsApi',//判断当前客户端版本是否支持指定JS接口
                    'onMenuShareTimeline',//分享给好友
                    'onMenuShareAppMessage'//分享到朋友圈
                ]
            });
        },
        error: function(xhr, status, error) {
            //alert(status);
            //alert(xhr.responseText);
        }
    })
});

5.在要享受的页面中引入,微信分享的主导js和share.js

<script type=”text/javascript”
src=”/resources/js/jweixin-1.2.0.js”></script>

<script type=”text/javascript”
src=”/resources/js/share.js”></script>

6.在时下页面<script>中,此部分能够直接写到share.js中

        /*分享代码*/
        wx.ready(function() {
            // config信息验证后会执行ready方法,所有接口调用都必须在config接口获得结果之后,config是一个客户端的异步操作,所以如果需要在页面加载时就调用相关接口,则须把相关接口放在ready函数中调用来确保正确执行。对于用户触发时才调用的接口,则可以直接调用,不需要放在ready函数中。
            console.log('weixin 验证成功');
            // 分享到朋友圈
            wx.onMenuShareTimeline({
                title: detail_title, // 分享标题
                link: link, // 分享链接,该链接域名或路径必须与当前页面对应的公众号JS安全域名一致
                imgUrl: 'http://develop.fangxinyuesao.com/resources/images/logo.png', // 分享图标
                success: function() {
                    // 用户确认分享后执行的回调函数
                },
                cancel: function() {
                    // 用户取消分享后执行的回调函数
                }
            });

            // 分享给朋友
            wx.onMenuShareAppMessage({
                title: detail_title, // 分享标题
                desc: '来自妇幼头条的分享', // 分享描述
                link: link, // 分享链接,该链接域名或路径必须与当前页面对应的公众号JS安全域名一致
                imgUrl: 'http://develop.fangxinyuesao.com/resources/images/logo.png', // 分享图标
                type: '', // 分享类型,music、video或link,不填默认为link
                dataUrl: '', // 如果type是music或video,则要提供数据链接,默认为空
                success: function() {
                    // 用户确认分享后执行的回调函数
                },
                cancel: function() {
                    // 用户取消分享后执行的回调函数
                }
            });

        });

        wx.error(function(res) {
            // config信息验证失败会执行error函数,如签名过期导致验证失败,具体错误信息可以打开config的debug模式查看,也可以在返回的res参数中查看,对于SPA可以在这里更新签名。
            console.log('weixin 验证失败');
            console.log(res);
        });

 

注意事项:分享要设置网站白名单,电脑端调试时,推荐使用微信WEB开发工具

 

相关文章

发表评论

电子邮件地址不会被公开。 必填项已用*标注

*
*
Website