欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue實(shí)現(xiàn)將自己網(wǎng)站(h5鏈接)分享到微信中形成小卡片的超詳細(xì)教程

 更新時(shí)間:2023年02月23日 09:10:09   作者:穆雄雄  
在微信小程序中,可以很簡(jiǎn)單的分享一個(gè)頁(yè)面,比微信H5簡(jiǎn)單多了,下面這篇文章主要給大家介紹了關(guān)于vue實(shí)現(xiàn)將自己網(wǎng)站(h5鏈接)分享到微信中形成小卡片的超詳細(xì)教程,需要的朋友可以參考下

最新更新

2022年12月24日23:58:30

發(fā)現(xiàn)了個(gè)問(wèn)題,解決了好久,問(wèn)題如下:

當(dāng)我直接將鏈接發(fā)送到微信中的時(shí)候,然后打開(kāi),發(fā)現(xiàn)分享出去還是個(gè)鏈接。當(dāng)我將鏈接分享到QQ時(shí),發(fā)現(xiàn)是自定義卡片形式。我將QQ的卡片在分享到微信里面時(shí),打開(kāi)分享到微信,是自定義卡片形式。

這個(gè)問(wèn)題看了好久,淘寶找人花80沒(méi)有解決,退款給我了,各大技術(shù)群?jiǎn)柫藗€(gè)遍,也沒(méi)有解決,CSDN懸賞問(wèn)答,也未能解決,最后發(fā)現(xiàn)是:
微信不支持直接進(jìn)去鏈接分享,不然分享的還是鏈接,需要從微信的入口進(jìn)去,比如先將內(nèi)容生成二維碼,然后掃描進(jìn)去在分享,就可以了?。?!

前言

我們?cè)诜窒砉娞?hào)信息到微信或者群中的時(shí)候,會(huì)出現(xiàn)一個(gè)小卡片,如下所示:

但是呢,這種小卡片只能走微信的接口來(lái)實(shí)現(xiàn),比如我們從公眾號(hào)、小程序中分享的內(nèi)容可以是這樣的。如果我們將自己的博客分享到微信的話(huà),只會(huì)出現(xiàn)個(gè)鏈接。

那么,試問(wèn)一下你,分享出來(lái)個(gè)這樣的鏈接,你會(huì)去點(diǎn)嗎?會(huì)不會(huì)以為這就是個(gè)釣魚(yú)鏈接。

今天,我們就來(lái)看看,如何將我們自己的站,搞一個(gè)和微信一樣的分享卡片出來(lái)。

準(zhǔn)備工作

  • 注冊(cè)一個(gè)公眾號(hào),該公眾號(hào)需要能認(rèn)證的(企業(yè)認(rèn)證)
  • 準(zhǔn)備好你的站,前端展示的是vue,別的可以自己對(duì)應(yīng)的轉(zhuǎn)換。
  • 后端用java實(shí)現(xiàn)的,別的語(yǔ)言自己轉(zhuǎn)換一下即可。

請(qǐng)注意,公眾號(hào)可以是訂閱號(hào),也可以是服務(wù)號(hào),但是必須是需要企業(yè)可以認(rèn)證的,個(gè)人雖然說(shuō)有的也可以認(rèn)證,但是沒(méi)有調(diào)用分享接口的權(quán)限。

前端業(yè)務(wù)實(shí)現(xiàn)(超詳細(xì))

weixin-js-sdk幫助文檔在這里,可以提現(xiàn)看看,免得后面看到之后,顯得那么陌生~

幫助文檔

下面我們來(lái)介紹一下實(shí)現(xiàn)步驟:

打開(kāi)微信公眾平臺(tái),在“公眾號(hào)設(shè)置”的“功能設(shè)置”里填寫(xiě)“JS接口安全域名”。

不設(shè)置會(huì)被攔截,沒(méi)法使用,大家可以仔細(xì)看看是如何設(shè)置的,第三點(diǎn)最重要:

在【基本配置】里面,配置一下你的ip白名單,不設(shè)置沒(méi)法獲取access_token,沒(méi)有toekn,一切都免談。

3. 在vue項(xiàng)目中,安裝weixin-js-sdk的依賴(lài):

npm install weixin-js-sdk --save

在需要分享的vue頁(yè)面中寫(xiě)代碼,先引入安裝好的依賴(lài)。

// 引入wxjs
import wx from "weixin-js-sdk"; 

methods中實(shí)現(xiàn)分享的功能:

getShareInfo() {
      //獲取url鏈接(如果有#需要這么獲?。?
      var url = encodeURIComponent(window.location.href.split("#")[0]);
 		//獲取url鏈接(如果沒(méi)有#需要這么獲?。?
     // var url = encodeURIComponent(window.location.href);

      getSing(url).then(res => {
        wx.config({
          debug: false, // 開(kāi)啟調(diào)試模式,調(diào)用的所有 api 的返回值會(huì)在客戶(hù)端 alert 出來(lái),若要查看傳入的參數(shù),可以在 pc 端打開(kāi),參數(shù)信息會(huì)通過(guò) log 打出,僅在 pc 端時(shí)才會(huì)打印。
          appId: res.data.appId, // 必填,公眾號(hào)的唯一標(biāo)識(shí)
          timestamp: parseInt(res.data.timestamp), // 必填,生成簽名的時(shí)間戳
          nonceStr: res.data.nonceStr, // 必填,生成簽名的隨機(jī)串
          signature: res.data.signature, // 必填,簽名
          jsApiList: [
            "updateAppMessageShareData",
            "updateTimelineShareData"
          ] // 必填,需要使用的 JS 接口列表
        });
        wx.ready(() => {
          var shareData = {
            title: "每日新聞",
            desc: "2022年12月20日21:47:55每日新聞",
            link: window.location.href,
            imgUrl: "https://blogobs.88688.team/blog/l-logo-y.jpg"
          };
          //自定義“分享給朋友”及“分享到QQ”按鈕的分享內(nèi)容
          wx.updateAppMessageShareData(shareData);
          //自定義“分享到朋友圈”及“分享到 QQ 空間”按鈕的分享內(nèi)容(1.4.0)
          wx.updateTimelineShareData(shareData);
        });
        //錯(cuò)誤了會(huì)走 這里
        wx.error(function (res) {
          console.log("微信分享錯(cuò)誤信息", res);
        });
      });
    },

代碼說(shuō)明:

  • url 是我們要分享頁(yè)面的鏈接,需要傳遞到后端進(jìn)行加密簽名(后端的代碼我們待會(huì)兒看)
  • getSing方法是后端進(jìn)行簽名的方法,安全起見(jiàn),所有config初始化中的關(guān)鍵信息,都從后端往回拿。
  • jsApiList是我們需要實(shí)現(xiàn)的功能的方法列表,逗號(hào)隔開(kāi)。

created中調(diào)用一下getShareInfo方法:

// 調(diào)用分享的事件
    this.getShareInfo();

前端內(nèi)容就這些,下面我們看看后端做了哪些操作。

后端代碼實(shí)現(xiàn)(超詳細(xì))

獲取token:為什么要獲取token,微信公眾號(hào)開(kāi)發(fā)中,不管你做啥操作,都需要這個(gè)token,并且有效時(shí)間是7200s,也就是兩個(gè)小時(shí),兩小時(shí)后就失效,下面是java中獲取token的代碼:

 /**
     * 獲取access_token的值
     * @return
     */
    @GetMapping("/getToken")
    public String getToken() {
        String token = "";
        String path = "token?grant_type=client_credential&appid=" + APPID + "&secret=" + APPSECRET;
        String body = HttpUtil.createGet(WX_GZH_API + path)
                .execute()
                .body();
        log.info("獲取了token,返回?cái)?shù)據(jù)" + body);
        JSONObject object = JSON.parseObject(body);
        //獲取token
        token = object.getString("access_token");
        //失效時(shí)間
        String expires_in = object.getString("expires_in");
        //將token值的值放在redis里面
        redisService.setCacheObject("gzh_access_token", token,7190,TimeUnit.SECONDS);
        return token;

    }

WX_GZH_API :

//公眾號(hào)請(qǐng)求的地址
    public static String WX_GZH_API = "https://api.weixin.qq.com/cgi-bin/";

APPID APPSECRET換成你自己的就行。

獲取api_ticket,這個(gè)是用在簽名里面的,直接請(qǐng)求接口獲取就行。

/**
     * 獲取jsapi_ticket
     * @return
     */
    @GetMapping("/getJsapiTicket")
    public String getJsapiTicket() {
        //獲取redis里面的token
        Object access_token = redisService.getCacheObject("gzh_access_token");
        if (access_token==null) {
            access_token = getToken();
        }
        String path = "ticket/getticket?access_token=" + access_token.toString() + "&type=jsapi";
        String body = HttpUtil.createGet(WX_GZH_API + path)
                .execute()
                .body();
        log.info("獲取了JsapiTicket,返回?cái)?shù)據(jù)" + body);
        JSONObject object = JSON.parseObject(body);
        //獲取ticket
        String ticket = object.getString("ticket");
        //錯(cuò)誤碼
        Integer errcode = object.getInteger("errcode");
        if(errcode==0){
            //將ticket值的值放在redis里面
            redisService.setCacheObject("gzh_ticket", ticket,7190,TimeUnit.SECONDS);
        }
        return ticket;
    }

這兩個(gè)方法我都寫(xiě)了緩存,和是失效時(shí)間,并且在用的時(shí)候都會(huì)去判斷緩存里面有沒(méi)有值,沒(méi)有的話(huà),我們?cè)偃フ?qǐng)求重新獲取,而不是每次都請(qǐng)求獲取,這樣會(huì)造成接口請(qǐng)求頻繁受到限制的問(wèn)題。

開(kāi)始簽名:

    /**
     * 開(kāi)始簽名
     */
    @GetMapping("/getSing")
    public ResponseResult getSing(String url){
        //從redis里面獲取ticket
        Object ticket = redisService.getCacheObject("gzh_ticket");
        if(ticket==null){
            ticket = getJsapiTicket();
        }
        Map<String, String> ret = WeChatUtils.sign(ticket.toString(), url);
        JSONObject objectData = new JSONObject();
        for (Map.Entry entry : ret.entrySet()) {
            objectData.put(entry.getKey().toString(),entry.getValue());
        }
        objectData.put("appId", APPID);
        return ResponseResult.success(objectData);
    }

簽名的幾個(gè)工具類(lèi)如下所示:

//******************************************
    // 公眾號(hào)網(wǎng)頁(yè)開(kāi)發(fā)
    //******************************************
    public static Map<String, String> sign(String jsapi_ticket, String url) {
        Map<String, String> ret = new HashMap<String, String>();
        String nonce_str = create_nonce_str();
        String timestamp = create_timestamp();
        String string1;
        String signature = "";

        //注意這里參數(shù)名必須全部小寫(xiě),且必須有序
        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 | 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);

        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);
    }

加密簽名接口請(qǐng)求如下:

然后我們就實(shí)現(xiàn)了,你試試你的可以不。

總結(jié)

到此這篇關(guān)于vue實(shí)現(xiàn)將自己網(wǎng)站(h5鏈接)分享到微信中形成小卡片的文章就介紹到這了,更多相關(guān)vue將網(wǎng)站分享到微信小卡片內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 解決vue cli使用typescript后打包巨慢的問(wèn)題

    解決vue cli使用typescript后打包巨慢的問(wèn)題

    這篇文章主要介紹了解決vue cli使用typescript后打包巨慢的問(wèn)題,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • Element UI 自定義正則表達(dá)式驗(yàn)證方法

    Element UI 自定義正則表達(dá)式驗(yàn)證方法

    今天小編就為大家分享一篇Element UI 自定義正則表達(dá)式驗(yàn)證方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-09-09
  • vue中實(shí)現(xiàn)路由跳轉(zhuǎn)的三種方式超詳細(xì)教程

    vue中實(shí)現(xiàn)路由跳轉(zhuǎn)的三種方式超詳細(xì)教程

    這篇文章主要介紹了vue中實(shí)現(xiàn)路由跳轉(zhuǎn)的三種方式超詳細(xì)教程,其中聲明式router-link實(shí)現(xiàn)跳轉(zhuǎn)最簡(jiǎn)單的方法,可用組件router-link來(lái)替代a標(biāo)簽,每種方式給大家講解的非常詳細(xì)需要的朋友可以參考下
    2022-11-11
  • 一文快速詳解前端框架 Vue 最強(qiáng)大的功能

    一文快速詳解前端框架 Vue 最強(qiáng)大的功能

    組件是 vue.js最強(qiáng)大的功能之一,而組件實(shí)例的作用域是相互獨(dú)立的,這就意味著不同組件之間的數(shù)據(jù)無(wú)法相互引用。這篇文章主要介紹了一文快速詳解前端框架 Vue 最強(qiáng)大的功能,需要的朋友可以參考下
    2019-05-05
  • Vue3使用element-plus組件不顯示問(wèn)題

    Vue3使用element-plus組件不顯示問(wèn)題

    這篇文章主要介紹了Vue3使用element-plus組件不顯示問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • 在vue中封裝可復(fù)用的組件方法

    在vue中封裝可復(fù)用的組件方法

    下面小編就為大家分享一篇在vue中封裝可復(fù)用的組件方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-03-03
  • Vue的v-model的幾種修飾符.lazy,.number和.trim的用法說(shuō)明

    Vue的v-model的幾種修飾符.lazy,.number和.trim的用法說(shuō)明

    這篇文章主要介紹了Vue的v-model的幾種修飾符.lazy,.number和.trim的用法說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-08-08
  • vue使用luckyexcel實(shí)現(xiàn)在線(xiàn)表格及導(dǎo)出導(dǎo)入方式

    vue使用luckyexcel實(shí)現(xiàn)在線(xiàn)表格及導(dǎo)出導(dǎo)入方式

    這篇文章主要介紹了vue使用luckyexcel實(shí)現(xiàn)在線(xiàn)表格及導(dǎo)出導(dǎo)入方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-05-05
  • vue項(xiàng)目強(qiáng)制清除頁(yè)面緩存的例子

    vue項(xiàng)目強(qiáng)制清除頁(yè)面緩存的例子

    今天小編就為大家分享一篇vue項(xiàng)目強(qiáng)制清除頁(yè)面緩存的例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-11-11
  • vue?elementUi中的tabs標(biāo)簽頁(yè)使用教程

    vue?elementUi中的tabs標(biāo)簽頁(yè)使用教程

    Tabs 組件提供了選項(xiàng)卡功能,默認(rèn)選中第一個(gè)標(biāo)簽頁(yè),下面這篇文章主要給大家介紹了關(guān)于vue?elementUi中的tabs標(biāo)簽頁(yè)使用的相關(guān)資料,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2023-03-03

最新評(píng)論