简单 短链 shorturl python实现

该博客介绍了如何使用62进制将数据库中的自增id转化为5位或6位的短链,并提供了相应的Python代码实现。通过将0-9、a-z和A-Z组合,可以生成唯一的短链,并能进行有效的长链与短链之间的相互转化。主要涉及了字符串操作和进制转换的知识。
摘要由CSDN通过智能技术生成
实现原理

在数据库中把 短链和长链进行映射; 表字段 id(自增), longurl, shorturl;
使用 0-9a-zA-Z 组合成五位(62^5) 或者六位(62^6) 字符来表示字段id ; 短链 和 id 进行相互转化,使用进制即可达到映射及唯一的效果;

python 代码实现
from random import shuffle

secret = 'abcdefghijklmnopqrstuvwxyz0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ'
# secret = 'YTiqlfv682MtKzV0RjLgpWJwmXAbcNkIoyPZda9ExO3S7FBnGU15eHshDuQCr4'

# 字符串打乱
def random_string(s):
    s = list(s)
    shuffle(s)
    print("".join(s))
    return "".join(s)


# 十进制转换到62进制
def encode62(id):
    num_list = []
    while (id > 0):
        remainder = id % 62
        num_list.insert(0, secret[remainder])
        id = id // 62
    return "".join(num_list).rjust(6, secret[0])


# 62进制转换到十进制
def decode62(secret_str):
    num_list = list(map(secret.index, secret_str))
    num_sum = 0
    for i, num in enumerate(num_list[::-1]):
        num_sum += num * 62**i
    return num_sum

print(encode62(138))
print(decode62(encode62(138)))
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值