时间:2021-05-25
一、网址缩短服务的原理
网址缩短服务,并不是压缩算法。而是把原网址存储在数据库中,用短的参数做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的动态路由如何获得参数
建立文件: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开发网址缩短服务的文章就介绍到这了,更多相关next.js开发网址缩短服务内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
next.js简介最近在学React.js,React官方推荐使用next.js框架作为构建服务端渲染的网站,所以今天来研究一下next.js的使用。next.
说明实现路由跳转、redux文件版本“next”:“^4.2.3”,“react”:“^16.2.0”,“react-dom”:“^16.2.0”Next.js
前言github:https://github.com/code-coder/next-mobile-complete-app已经用Next.js快两个月了,项
  网址缩短,顾名思义就是把网址缩短。通常用的服务器端代码转向,在Web2.0的今天,不得不说,这是一个潮流。已经有许多类似服务,借助缩短的
如果你在使用vue.js,那么我想你可能会对vue组件之间的通信感到崩溃。我在使用基于vue.js2.0的UI框架ElementUI开发网站的时候,就遇到了这种