• 微博mid和id转换


    mid为62进制编码,id为常见的10进制编码。

    id从低位到高位,7个数字为一组,转换为62进制,并顺序合并,即转换为mid。

    mid从地位到高位,4个字母为一组,转换为10进制,并右移7位,计算和,得到id。

    7位的10进制数最大为9999999,转换为62进制后为FXsj;8位的10进制数最大为99999999,转换为62进制后为9FXsj。

    7位分隔10进制数,能保证最多获得4位62进制数。

    参考了http://blog.csdn.net/dier4836/article/details/7827908,但是他的mid计算id有问题。

    package com.founder.weibocrawler.util;
    
    public class WeiboIDUtils {
    
        public static void main(String[] args) {
            System.out.println(Mid2Id("D5DVt7A9n"));
            System.out.println(Id2Mid("3913451191807261"));
        }
    
        public static String Mid2Id(String mid) {
            long id = 0L;
            // 从最后往前以4字节为一组读取字符
            int count = 0;
            for (int i = mid.length() - 4; i > -4; i = i - 4) {
                int offset = i < 0 ? 0 : i;
                int len = i < 0 ? mid.length() % 4 : 4;
                String str = Encode62ToLong(mid.substring(offset, offset + len)).toString();
                // 不足7位补0
                if (offset != 0)
                    str = String.format("%07d", Long.valueOf(str));
                id = (long) (Long.valueOf(str) * Math.pow(10, 7 * count) + id);
                count++;
            }
            return id + "";
        }
    
        public static String Id2Mid(String id) {
            String mid = "";
            for (int i = id.length() - 7; i > -7; i = i - 7) {
                int offset = i < 0 ? 0 : i;
                int len = i < 0 ? id.length() % 7 : 7;
                String str = LongToEnode62(Long.valueOf(id.substring(offset, offset + len)));
                mid = str + mid;
            }
            return mid;
        }
    
        private static String str62keys = "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";
    
        public static Long Encode62ToLong(String str62) {
            long long10 = 0;
            for (int i = 0; i < str62.length(); i++) {
                double n = str62.length() - i - 1;
                long10 += Long.valueOf(str62keys.indexOf(str62.substring(i, i + 1)) * (long) Math.pow(62, n) + "");
            }
            return long10;
        }
    
        public static String LongToEnode62(long long10) {
            String str62 = "";
            int offset = 0;
            while (long10 != 0) {
                offset = Integer.valueOf(long10 % 62 + "");
                str62 = str62keys.substring(offset, offset + 1) + str62;
                long10 = (long) Math.floor(long10 / 62.0);
            }
            return str62;
        }
    }
  • 相关阅读:
    2.舵机
    1.呼吸灯
    Python学习笔记——Matplot库
    计算机仿真技术学习笔记(一)
    48、从堆和栈上建立对象哪个快?(考察堆和栈的分配效率比较)
    47、抖动你知道是什么吗?它也叫颠簸现象
    46、交换空间与虚拟内存的关系
    44、程序从堆中动态分配内存时,虚拟内存上怎么操作的
    43、一般情况下在Linux/windows平台下栈空间的大小
    42、一个由C/C++编译的程序占用的内存分为哪几个部分?
  • 原文地址:https://www.cnblogs.com/mahuan2/p/5948490.html
Copyright © 2020-2023  润新知