亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

使用next.js開發(fā)網(wǎng)址縮短服務(wù)的方法

 更新時(shí)間:2020年06月17日 09:23:03   作者:codetyphon  
這篇文章主要介紹了使用next.js開發(fā)網(wǎng)址縮短服務(wù),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

一、網(wǎng)址縮短服務(wù)的原理

網(wǎng)址縮短服務(wù),并不是壓縮算法。而是把原網(wǎng)址存儲(chǔ)在數(shù)據(jù)庫(kù)中,用短的參數(shù)做key,屆時(shí)取出原始url,并跳轉(zhuǎn)。

因此,短網(wǎng)址最適合用key/value數(shù)據(jù)庫(kù)。

那么,短網(wǎng)址的唯一參數(shù),如何生成呢?其實(shí)用的就是10進(jìn)制轉(zhuǎn)62進(jìn)制。

function string10to62(number) {
 var chars = '0123456789abcdefghigklmnopqrstuvwxyzABCDEFGHIGKLMNOPQRSTUVWXYZ'.split(''),
  radix = chars.length,
  qutient = +number,
  arr = [];
 do {
  let mod = qutient % radix;
  qutient = (qutient - mod) / radix;
  arr.unshift(chars[mod]);
 } while (qutient);
 return arr.join('');
}

相應(yīng)地,每次生成后,都要讓一個(gè)10進(jìn)制自增,這樣,每次就能根據(jù)唯一的10進(jìn)制生成唯一的62進(jìn)制。

為什么用10進(jìn)制轉(zhuǎn)62進(jìn)制呢?

因?yàn)椋?0進(jìn)制的100000000轉(zhuǎn)為62進(jìn)制,是6LAze。它很短。

二、next.js的動(dòng)態(tài)路由如何獲得參數(shù)

建立文件:pages/[slug].js

注意,該文件名由括號(hào)組成,代表是變量。這樣,就可以通過(guò)http://ip/xxx 的形式,得到參數(shù)xxx。

關(guān)鍵代碼:

import { useRouter } from 'next/router';
const router = useRouter();
const { slug } = router.query;

得到slug后,去數(shù)據(jù)庫(kù)里找到并跳轉(zhuǎn)即可:

db.findOne({ slug: slug }, function (err, doc) {
 if(doc!=null){
  window.location.href=doc.url;
 }
});

三、github及演示

1、github地址:https://github.com/codetyphon ...

2、演示地址:https://nextshort.vercel.app

總結(jié)

到此這篇關(guān)于使用next.js開發(fā)網(wǎng)址縮短服務(wù)的文章就介紹到這了,更多相關(guān)next.js開發(fā)網(wǎng)址縮短服務(wù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 原生js實(shí)現(xiàn)autocomplete插件

    原生js實(shí)現(xiàn)autocomplete插件

    這篇文章主要介紹了原生js實(shí)現(xiàn)autocomplete插件的相關(guān)資料,需要的朋友可以參考下
    2016-04-04
  • JavaScript輸入框字?jǐn)?shù)實(shí)時(shí)統(tǒng)計(jì)更新

    JavaScript輸入框字?jǐn)?shù)實(shí)時(shí)統(tǒng)計(jì)更新

    這篇文章主要介紹了JavaScript輸入框字?jǐn)?shù)實(shí)時(shí)統(tǒng)計(jì)更新,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • bootstrap datetimepicker控件位置異常的解決方法

    bootstrap datetimepicker控件位置異常的解決方法

    這篇文章主要為大家詳細(xì)介紹了bootstrap datetimepicker控件位置異常的解決方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • 第二篇Bootstrap起步

    第二篇Bootstrap起步

    這篇文章主要介紹了第二篇Bootstrap起步的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2016-06-06
  • Javascript 面試題隨筆

    Javascript 面試題隨筆

    前天去面試遇到的一道題,面試的問(wèn)題大概是當(dāng)test.increase被調(diào)用時(shí),test和test2的count值分別是多少
    2011-03-03
  • JS hashMap實(shí)例詳解

    JS hashMap實(shí)例詳解

    這篇文章主要介紹了JS hashMap實(shí)例詳解的相關(guān)資料,包括刪除鍵值、獲取鍵值的相關(guān)知識(shí),非常不錯(cuò)具有參考借鑒價(jià)值,需要的朋友一起看看吧
    2016-05-05
  • uni-app 自定義底部導(dǎo)航欄的實(shí)現(xiàn)

    uni-app 自定義底部導(dǎo)航欄的實(shí)現(xiàn)

    這篇文章主要介紹了uni-app 自定義底部導(dǎo)航欄的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • uniapp開發(fā)H5使用formData上傳文件解決方案

    uniapp開發(fā)H5使用formData上傳文件解決方案

    我們很多時(shí)候上傳文件就是使用FormData,然而uniapp默認(rèn)不支持FormData類型數(shù)據(jù)的上傳,下面這篇文章主要給大家介紹了關(guān)于uniapp開發(fā)H5使用formData上傳文件的相關(guān)資料,需要的朋友可以參考下
    2023-12-12
  • 利用js判斷手機(jī)是否安裝某個(gè)app的多種方案

    利用js判斷手機(jī)是否安裝某個(gè)app的多種方案

    這篇文章主要介紹了利用js檢測(cè)手機(jī)是否安裝某個(gè)app的多種方案,當(dāng)判斷后如果安裝了直接打開,如果有沒(méi)有安裝將自動(dòng)跳轉(zhuǎn)到下載的界面,有需要的朋友可以參考借鑒,下面來(lái)一起看看吧。
    2017-02-02
  • JavaScript實(shí)現(xiàn)背景圖像切換3D動(dòng)畫效果示例詳解

    JavaScript實(shí)現(xiàn)背景圖像切換3D動(dòng)畫效果示例詳解

    這篇文章主要為大家介紹了JavaScript實(shí)現(xiàn)背景圖像切換3D動(dòng)畫效果示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-09-09

最新評(píng)論