使用next.js開發(fā)網址縮短服務的方法
一、網址縮短服務的原理
網址縮短服務,并不是壓縮算法。而是把原網址存儲在數據庫中,用短的參數做key,屆時取出原始url,并跳轉。
因此,短網址最適合用key/value數據庫。
那么,短網址的唯一參數,如何生成呢?其實用的就是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)路由如何獲得參數
建立文件:pages/[slug].js
注意,該文件名由括號組成,代表是變量。這樣,就可以通過http://ip/xxx 的形式,得到參數xxx。
關鍵代碼:
import { useRouter } from 'next/router';
const router = useRouter();
const { slug } = router.query;
得到slug后,去數據庫里找到并跳轉即可:
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ù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
bootstrap datetimepicker控件位置異常的解決方法
這篇文章主要為大家詳細介紹了bootstrap datetimepicker控件位置異常的解決方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-11-11
uniapp開發(fā)H5使用formData上傳文件解決方案
我們很多時候上傳文件就是使用FormData,然而uniapp默認不支持FormData類型數據的上傳,下面這篇文章主要給大家介紹了關于uniapp開發(fā)H5使用formData上傳文件的相關資料,需要的朋友可以參考下2023-12-12

