GO语言 短URL生成

简介: 短URL介绍链接:1)https://segmentfault.com/a/11900000120883452)http://www.voidcn.com/article/p-ydjqllgt-ed.

短URL介绍链接:
1)https://segmentfault.com/a/1190000012088345
2)http://www.voidcn.com/article/p-ydjqllgt-ed.html
3)https://pathbox.github.io/2018/02/22/short-url-build-system/

开始撸代码:

package main

import (
    "crypto/md5"
    "fmt"
    "strconv"
    "strings"
)
var chars = strings.Split("abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789", "")

// 1) 哈希实现
func hashShortUrl(url string) {
    hex := fmt.Sprintf("%x", md5.Sum([]byte(url)))
    resUrl := make([]string, 4)
    for i := 0;i < 4;i++ {
        val, _ := strconv.ParseInt(hex[i*8:i*8+8], 16, 0)
        lHexLong := val & 0x3fffffff
        outChars := ""
        for j := 0;j < 6;j++ {
            outChars += chars[0x0000003D & lHexLong]
            lHexLong >>= 5
        }
        resUrl[i] = outChars
    }
    fmt.Println(resUrl)
}

// 2) 自增长算法
func autoShortUrl(id int64) string {
    return GetString62(Encode62(id))
}

func Encode62(id int64) []int64 {
    tempE := []int64{}

    for id > 0 {
        tempE = append(tempE, id % 62)
        id /= 62
    }
    return tempE
}

func GetString62(indexA []int64) string {
    res := ""

    for _, val := range indexA {
        res += chars[val]
    }
    return reverseString(res)
}

// 反转字符串
func reverseString(s string) string {
    runes := []rune(s)
    for from, to := 0, len(runes) - 1;from < to;from, to = from + 1, to - 1 {
        runes[from], runes[to] = runes[to], runes[from]
    }
    return string(runes)
}

func main()  {
    fmt.Println(autoShortUrl(123))
}
目录
相关文章
|
13天前
|
存储 监控 算法
员工上网行为监控中的Go语言算法:布隆过滤器的应用
在信息化高速发展的时代,企业上网行为监管至关重要。布隆过滤器作为一种高效、节省空间的概率性数据结构,适用于大规模URL查询与匹配,是实现精准上网行为管理的理想选择。本文探讨了布隆过滤器的原理及其优缺点,并展示了如何使用Go语言实现该算法,以提升企业网络管理效率和安全性。尽管存在误报等局限性,但合理配置下,布隆过滤器为企业提供了经济有效的解决方案。
54 8
员工上网行为监控中的Go语言算法:布隆过滤器的应用
|
1月前
|
存储 Go 索引
go语言中数组和切片
go语言中数组和切片
41 7
|
1月前
|
Go 开发工具
百炼-千问模型通过openai接口构建assistant 等 go语言
由于阿里百炼平台通义千问大模型没有完善的go语言兼容openapi示例,并且官方答复assistant是不兼容openapi sdk的。 实际使用中发现是能够支持的,所以自己写了一个demo test示例,给大家做一个参考。
|
1月前
|
程序员 Go
go语言中结构体(Struct)
go语言中结构体(Struct)
103 71
|
1月前
|
存储 Go 索引
go语言中的数组(Array)
go语言中的数组(Array)
106 67
|
1月前
|
Go 索引
go语言for遍历数组或切片
go语言for遍历数组或切片
105 62
|
1月前
|
并行计算 安全 Go
Go语言中的并发编程:掌握goroutines和channels####
本文深入探讨了Go语言中并发编程的核心概念——goroutine和channel。不同于传统的线程模型,Go通过轻量级的goroutine和通信机制channel,实现了高效的并发处理。我们将从基础概念开始,逐步深入到实际应用案例,揭示如何在Go语言中优雅地实现并发控制和数据同步。 ####
|
8天前
|
算法 安全 Go
Go 语言中实现 RSA 加解密、签名验证算法
随着互联网的发展,安全需求日益增长。非对称加密算法RSA成为密码学中的重要代表。本文介绍如何使用Go语言和[forgoer/openssl](https://github.com/forgoer/openssl)库简化RSA加解密操作,包括秘钥生成、加解密及签名验证。该库还支持AES、DES等常用算法,安装简便,代码示例清晰易懂。
40 12
|
1月前
|
存储 Go
go语言中映射
go语言中映射
38 11
|
1月前
|
Go
go语言for遍历映射(map)
go语言for遍历映射(map)
39 12