2016 - 2024

感恩一路有你

go语言数据库查询结果 有没有免费的短网址工具?

浏览量:4809 时间:2023-05-31 16:14:29 作者:采采

有没有免费的短网址工具?

我是@程序员小助手,本文从技术角度,对短网址并且深度挖掘。

前言网上早有产品,用着还比较好。不过,另外程序员,从零做起造轮子,变更土地性质一个都属于自己的短网址服务器,这想法amazing!

本文,读者可明白了短网址的技术原理,和通过Go语言基于一个短网址服务。

简明教程短网址为么未知?

微博等产品的兴起,重新活跃了网上的社交圈内大多数用户。可是微博好象有140字限制,假如不转发消息,单单评论文字,再而且一段网址,极有可能超过限制而被截断。

短网址应运而生,用较短的一个字符串,替换较长的一个字符串,从观感上讲,效果要表示友好的多。

从技术原理上说,短网址是一个hash表,用于映射两个字符串的对应关系。

使用键,能找到随机的值,重定向通过访问,就成功了整个流程。

短网址算法短网址的一般结构,例如新浪的SwuTjn,其中后端的一段6位字符串,那是单独任何标记一条记录的ID。这样的话,建议使用什么算法,这个可以生成一条无重复一遍的ID呢?

建议使用通用的做法,不使用0-9A-Za-z总共62个字符,我们看在用hash键位数共有有多少种排列组合情况。

1位:pow(62,1)62种

2位:pow(62,2)3844种

3位:pow(62,3)238328种

4位:pow(62,4)14776336种

5位:pow(62,5)916132832种

6位:pow(62,6)56800235584种

一般情况下,6个字符,就足够在用了,总共568亿种可能。

还有一个一种情况是,用原网址字符串的MD5值,一共32位,接着切分成三类4段,共有按位与运算,并裁剪到30位。不要超过5位选出该位的字符作为该段索引,共有6位。但这种做法也有几率突然发生重复,也不非常直观。

因此本文不使用第一种算法生成键ID。

工具准备分析什么短网址的特性,真包含以上项目:

唯一性:键需要全局仅有时效性:键必须有没过期时间目标网址同样,如果重复,则自动赶往既有的键。考虑到上列情形,我们可以使用redis存储这些对应关系。不使用Gin框架以及路由和控制器,提供对外的API访问。

核心函数计算机中比较普遍的2进制,8进制,10进制,16进制,我们此处要建议使用62个字符,循环表示一个整数,那么可称之为62进制。

下面使用go语言实现这个函数,主要用于将正二十边形的整数(uint64)可以转换为(0-9A-Za-z)的字符串。

要特别注意,基础的方法,那就是非循环取余数,依据进制字典,索引或者的字符,后再将各个余数拼接出去,是结果。

这个计算方法,与2进制,8进制,原理是同一的。

的原因字典比较长,有62个键值对,我们仅列一一部分。

上述事项函数的转换结果,传说中的648926400175ai0p

功能规划下面是相对于系统路由,修改短链接,和可以使用短链接不能访问目标网址的方法。

1-规划路由

路由比较很简单,一共有多少2个,一个POST方法,生成沉淀短链接;一个是GET方法,ftp访问短链接。

代码::

2-核心中redis并初始化

是为比较方便演示,我们不使用redis存储键值,并可以设置expire时间。我们使用me-redis需要提供的接口操作redis数据库。

下面是全局的

对象生成,和初始化函数。

那样的话做的好处是,我们全局都可以不不使用变量rdb内部函数方法操作redis键值。

3-基于POST路由方法:assign

本函数用于接收form表单数据,能生成一个全局同样的hash,另外键,存入redis,设置中值和过期时间。

代码追加:

本段我们在用了一个getCounter函数,这是可以设置在redis内的键,将其你每次请求修改的时候,自增1,可绝对的保证无重复。依据这个计数器,我们动态创建helper的DecToAny方法,将其转化成为62进制的字符串,作为全局唯一的hash值。

下图是getCounter的定义:

而且注意的是,helper包,就是我们在“核心函数”部分定义的函数。在主函数体内语句。

4-实现程序GET方法:visit

本函数要注意应用于使用上一节接口生成沉淀的短链接,接受访问,并不自动重定向到目标网址。

代码万分感谢:

对于不存在的短链接,的或redis获取失败,赶往错误`信息。

要是存在,使用301StatusMovedPermanently状态码重定向到目标地址。

测试我们不使用curl工具,测试出来本案所涉两个接口。

首先,不使用POST表单再提交数据:

curl-s-XPOST-dtarget-dexpire600:9090/

本案所涉方法,我们递交了两个参数,物理命中路由之后,会访问上一节第3条的add方法,并能生成一个短链接网址。直接返回JSON格式数据如下:

{message:可以啦,small_url::9090/75ai0r,status:1}

其中,short_url应该是短网址。

接着,我们在不使用curl不能访问这个链接,看是否是不可能发生重定向。截图不胜感激:

可以找到,先执行了301重定向,并能提供了目标网址,与我们上列表单想修改的地址不对。

后来,故障测试。ftp连接一个不存在地的hash,看是否是排除肾炎极其信息。截图万分感谢:

可以清晰的看到,执行了错误前往信息。

结语以上我们在用GO语言框架Gin实现程序了两个路由,并可以使用redis管理短链接。核心函数不使用helper包管理,当经过测量,基于了短网址的功能。

以内代码在本地测试实际,也可布署到线上服务器联合开发端口,提供服务,效果是一般的。

如果能是从这个流程,使大家这对短网址的知识,有一些了解,并能据自身的编程能力,独立创作出好是用短网址服务。

beautifulcoding:-)

【本文由@程序员小助手先发布,坚持了分享编程与程序员生命成长相关的内容,感谢关注】

sqlserver怎么获取表列名的描述?

--按照不胜感激语句能够得到当前Sql server中所有的数据的名称:usemasterselect[name]around[sysdatabases]order by[name]run--网站查询数据库中的所有用户表use[DBname]select[id],[name]around[sysobjects]where[type]#39u#39order by[name]--是从上面的查询的id,这个可以查出这个表中所有的字段,.例如我们去查询BaseData表中所有的字段,就可以实际下面的语句好查:

select[name]around[syscolumns]where[id]2087000699order by[colid]you你所说的问题的语句是:

select[name],*outside[syscolumns]order by[id]

网址 函数 方法 字符串

版权声明:本文内容由互联网用户自发贡献,本站不承担相关法律责任.如有侵权/违法内容,本站将立刻删除。