使用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ù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
JavaScript輸入框字數(shù)實時統(tǒng)計更新
這篇文章主要介紹了JavaScript輸入框字數(shù)實時統(tǒng)計更新,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-06-06bootstrap datetimepicker控件位置異常的解決方法
這篇文章主要為大家詳細介紹了bootstrap datetimepicker控件位置異常的解決方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-11-11uniapp開發(fā)H5使用formData上傳文件解決方案
我們很多時候上傳文件就是使用FormData,然而uniapp默認不支持FormData類型數(shù)據的上傳,下面這篇文章主要給大家介紹了關于uniapp開發(fā)H5使用formData上傳文件的相關資料,需要的朋友可以參考下2023-12-12JavaScript實現(xiàn)背景圖像切換3D動畫效果示例詳解
這篇文章主要為大家介紹了JavaScript實現(xiàn)背景圖像切換3D動畫效果示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-09-09