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

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

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

一、網址縮短服務的原理

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

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

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

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

相應地,每次生成后,都要讓一個10進制自增,這樣,每次就能根據唯一的10進制生成唯一的62進制。

為什么用10進制轉62進制呢?

因為,10進制的100000000轉為62進制,是6LAze。它很短。

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

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

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

關鍵代碼:

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

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

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

總結

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

相關文章

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

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

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

    JavaScript輸入框字數(shù)實時統(tǒng)計更新

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

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

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

    第二篇Bootstrap起步

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

    Javascript 面試題隨筆

    前天去面試遇到的一道題,面試的問題大概是當test.increase被調用時,test和test2的count值分別是多少
    2011-03-03
  • JS hashMap實例詳解

    JS hashMap實例詳解

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

    uni-app 自定義底部導航欄的實現(xiàn)

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

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

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

    利用js判斷手機是否安裝某個app的多種方案

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

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

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

最新評論