出餐宝算法


import java.util.HashMap;
import java.util.Map;

public class IdConvertUtil {


    public IdConvertUtil() {
    }



    /**
     * @param encodedStr
     * @return
     */
    public static long decode(String radixs,String encodedStr) {
        //将 0 开头的字符串进行替换
        if (radixs.length() < 2) {
            throw new IllegalArgumentException("自定义进制最少两个字符哦!");
        }

        int rl = radixs.length();
        long result = 0;

        // 创建一个映射表,将字符映射到它们在 radixs 中的位置
        Map<Character, Integer> charToIndex = new HashMap<>();
        for (int i = 0; i < radixs.length(); i++) {
            charToIndex.put(radixs.charAt(i), i);
        }

        // 逐字符解析并计算原始数字
        for (int i = 0; i < encodedStr.length(); i++) {
            char c = encodedStr.charAt(i);
            int index = charToIndex.get(c);
            result = result * rl + index;
        }

        return result;
    }
    public static String encode(String radixs, long num) {
        if (num < 0L) {
            throw new RuntimeException("暂不支持负数!");
        } else {
            return encode(radixs, num, 64);
        }
    }

    private static String encode(String radixs, long num, int maxLength) {
        if (radixs.length() < 2) {
            throw new RuntimeException("自定义进制最少两个字符哦!");
        } else {
            int rl = radixs.length();
            long tmpNum = num;
            char[] aa = new char[maxLength];
            int i = aa.length;

            do {
                --i;
                aa[i] = radixs.charAt((int)(tmpNum % (long)rl));
                tmpNum /= (long)rl;
            } while(tmpNum > 0L);

            return new String(aa, i, aa.length - i);
        }
    }

}


@SpringBootTest
class DemoTest {

    private static final String MT_RADIX = "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";

    private static final String ELE_RADIX = "123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ";

    private static final String MT_ORDER_BARCODE_PREFIX = "M";

    private static final String ELE_ORDER_BARCODE_PREFIX = "E";
    
    //饿了么加密
    @Test
    void eleDencodeDemo()  {
        String code="EjL2ej3X2Y1c";
        String orderString = code.substring(1);
        Long orderId = IdConvertUtil.decode(ELE_RADIX, orderString);
        System.out.println(orderId);
    }
    //饿了么解密
    @Test
    void eleEncodeDemo()  {
        Long orderId = 8081450162781547971L;
        String code = ELE_ORDER_BARCODE_PREFIX+IdConvertUtil.encode(ELE_RADIX, orderId);
        System.out.println(code);
    }
    //美团加密
    @Test
    void mtDencodeDemo()  {
        String code="MOxSjpscvVb1";
        String orderString = code.substring(1);
        Long orderId = IdConvertUtil.decode(MT_RADIX, StrUtil.reverse(orderString));
        System.out.println(orderId);
    }
     //美团解密
    @Test
    void mtEncodeDemo()  {
        Long orderId = 1000762581577063424L;
        String code = MT_ORDER_BARCODE_PREFIX+ StrUtil.reverse(IdConvertUtil.encode(MT_RADIX, orderId));
        System.out.println(code);
    }
}

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值