如何生成t.cn短网址?

作者在 2023-08-14 00:27:52 发布以下内容

什么是短网址?🧐

短网址的诞生原因?

因为现在很多系统的需求要求URL链接上要带上很多参数,让URL变的非常长,以至于浏览器的地址可能装不下(各个浏览器限制长度不一致),所以我们需要把长网址转成对应的短网址。

说起短网址(短链接),很多人都已不再陌生。

不过想要把一串长长的网址,缩短成精简的链接,却没那么简单。

短网址最核心的就是如何让用户请求的是短链接而响应的确是长链接的内容?

长网址通过特殊的算法缩小到 一定长度,然后利用DB或者其他存储系统(这里是为了能够更快的响应)把长链接和短链接相互映射。

经过一段时间的摸索,已经搞定算法这个最艰难的步骤,分享出来给大家🤓


一、先简单封装一个过滤非法链接
// 过滤非法网址
  filter_url (url) {
    var chinese_reg = /(http[s]?:\/\/[^ ]+)/

    if (url.trim().length === 0) {
      console.log('请输入长网址!');
      return
    } else if (!chinese_reg.test(url)) {
      console.log('请输入正确的长网址');
      return
    }
    return url
  }



二、在初始化方法中写入这个实例共用的数据
// 初始化方法
  constructor () {
    // token
    this.token = "Z1QljZOZiT4NTG"

    // 请求地址
    this.req_url = 'http://api.txapi.cn/v1/short_url/tcn'

    // 需要缩短的长网址
    this.request_url = ''
  }



三、在封装一个run函数,让整个示例跑起来🤓
// run函数
  run (url) {

    this.request_url = this.filter_url(url)

    if(!this.request_url){
      return
    }

    this.shorten_url(this.req_url, this.token, this.request_url).then(res => {
      console.log(res); // 查询结果
    })
  }



最后附上完整代码😉
const axios = require('axios')

class Parse {
  // 初始化方法
  constructor () {
    // token
    this.token = "Z1QljZOZiT4NTG"

    // 请求地址
    this.req_url = 'http://api.txapi.cn/v1/short_url/tcn'

    // 需要缩短的长网址
    this.request_url = ''
  }

  // 缩短网址
  shorten_url (url, token, data) {
    let p = new Promise(function (resolve, reject) {
      axios({
        url: url,
        method: 'GET',
        params: {
          token: token,
          url: data
        }
      }).then(resp => {
        if(resp.data.code != 200 && resp.data.msg != "ok"){
          console.log("查询失败")
        } else {
          resolve(resp.data)
        }
      })
    })
    return p
  }

  // 过滤非法网址
  filter_url (url) {
    var chinese_reg = /(http[s]?:\/\/[^ ]+)/

    if (url.trim().length === 0) {
      console.log('请输入长网址!');
      return
    } else if (!chinese_reg.test(url)) {
      console.log('请输入正确的长网址');
      return
    }
    return url
  }

  // run函数
  run (url) {

    this.request_url = this.filter_url(url)

    if(!this.request_url){
      return
    }

    this.shorten_url(this.req_url, this.token, this.request_url).then(res => {
      console.log(res); // 查询结果
    })
  }
}

if(__filename === process.mainModule.filename) {
  // new一个Parse对象
  const p = new Parse()

  // 调用run方法
  p.run('https://www.baidu.com/')
}

Api接口 | 阅读 348 次
文章评论,共0条
游客请输入验证码
浏览6444次
文章归档
最新评论