一、网址缩短服务的原理一、网址缩短服务的原理一、网址缩短服务的原理网址缩短服务,并不是压缩算法。而是把原网址存储在数据库中,用短的参数做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('');
}
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。它很短。1000000006LAze二、next.js的动态路由如何获得参数二、next.js的动态路由如何获得参数二、next.js的动态路由如何获得参数建立文件:pages/[slug].js[slug]注意,该文件名由括号组成,代表是变量。这样,就可以通过http://ip/xxx 的形式,得到参数xxx。xxx关键代码:
import { useRouter } from 'next/router';
const router = useRouter();
const { slug } = router.query;
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;
}
});
db.findOne({ slug: slug }, function (err, doc) {
if(doc!=null){

window.location.href=doc.url;
}
});三、github及演示三、github及演示三、github及演示1、github地址:https://github.com/codetyphon ...https://github.com/codetyphon2、演示地址:https://nextshort.vercel.apphttps://nextshort.vercel.app总结总结总结