java的长字符串转化为短字符串
public class CustomEncrypt{
public static void main( String[] args ) {
/*
* c#给的正确测试用例: id=>mid
* 991135225=>001B4Lk5
* 981411932=>001A5Vj6
* 988914785=>001ABp8R
* 97879005=>0009x3GJ
*
* 981612013=>001A6Lmd
*
* 97949621=>0009xm3H
*
* 97919383=>0009xebZ
*
* 984113004=>001AhfYM
*
* 986013809=>001ApesV
*
* 97416233=>0009v7iF
*
* 9090103=>C8Kz
*
* 9194277359=>00ePhWJF
* 96521442=>0009rmwy
*/
String ids = "9734249,981411932,988914785,97879005,981612013,97949621,97919383,984113004,986013809,97416233,9090103,9194277359,96521442";
for(String id : ids.split( "," )){
String mid = idToMid(id);
System.out.println("mid:"+mid);
System.out.println("id:"+midToId(mid));
}
}
// / <summary>
// / The str62keys
// / </summary>
private static String str62keys = "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";
// / <summary>
// / 将Mid转换为Id
// / </summary>
// / <param name="str62">The STR62.</param>
// / <returns>System.String.</returns>
public static String midToId( String str62 ) {
String id = "";
// 从最后往前以4字节为一组读取字符
for ( int i = str62.length( ) - 4; i > -4; i = i - 4 ) {
int offset = i < 0 ? 0 : i;
int len = i < 0 ? str62.length( ) % 4 : 4;
long encode = encode62ToInt( left( str62, offset, len ) );
String str = String.valueOf( encode );
if ( offset > 0 )
str = leftPad( str, 7, '0' ); // 若不是第一组,则不足7位补0
id = str + id;
}
return id;
}
// / <summary>
// / 将Id转制为Mid
// / </summary>
// / <param name="mid">The mid.</param>
// / <returns>System.String.</returns>
public static String idToMid( String mid ) {
// long int_mid = long.Parse(mid);
String result = "";
for ( int i = mid.length( ) - 7; i > -7; i -= 7 ) {
int offset1 = ( i < 0 ) ? 0 : i;
int offset2 = i + 7;
String num = intToEnode62( left( mid, offset1, offset2 - offset1 ) );
result = num + result;
}
return result;
}
// / <summary>
// / Ints to enode62.
// / </summary>
// / <param name="mid">The mid.</param>
// / <returns>System.String.</returns>
private static String intToEnode62( String mid ) {
long int_mid = Long.parseLong( mid );
String result = "";
do {
long a = int_mid % 62;
result = str62keys.charAt( ( int ) a ) + result;
int_mid = ( int_mid - a ) / 62;
} while ( int_mid > 0 );
return leftPad( result, 4, '0' );
}
// / <summary>
// / Encode62s to int.
// / </summary>
// / <param name="str62">The STR62.</param>
// / <returns>System.Int64.</returns>
private static long encode62ToInt( String str62 ) {
long i10 = 0;
for ( int i = 0; i < str62.length( ); i++ ) {
double n = str62.length( ) - i - 1;
i10 += str62keys.indexOf( str62.charAt( i ) ) * Math.pow( 62, n );
}
String temp = leftPad( String.valueOf( i10 ), 7, '0' );
// Long.TryParse(temp, out i10);
try {
i10 = Long.parseLong( temp );
} catch ( Exception e ) {
// TODO: handle exception
} finally {
return i10;
}
}
// 左边补
public static String leftPad( String s, int size, char padChar ) {
int length = s.length( );
if ( length == 0 ) {
return s;
}
int pads = size - length;
if ( pads <= 0 ) {
return s;
}
return padding( pads, padChar ).concat( s );
}
// 填充
private static String padding( int repeat, char padChar ) {
if ( repeat < 0 ) {
throw new IndexOutOfBoundsException( "Cannot pad a negative amount: " + repeat );
}
char[] buf = new char[ repeat ];
for ( int i = 0; i < buf.length; i++ ) {
buf[ i ] = padChar;
}
return new String( buf );
}
/**
* 左起截取字符串
*
* @param s
* @param len
* @return
*/
public static String left( String s, int begin, int len ) {
int length = length( s );
if ( length <= len ) {
return s;
}
return s.substring( begin, begin > 0 ? begin + len : len );
}
/**
* 长度
*
* @param s
* @return
*/
public static int length( String s ) {
return s != null ? s.length( ) : 0;
}
}
java的长字符串转化为短字符串的更多相关文章
- PHP实现新浪长链接转化成短链接API
我们经常收到类似于这样的短信(如下图),发现其中的链接并不是常规的网址链接,而是个短小精悍的短链接,产品中经常需要这样的需求,如果在给用户下发的短信中是一个很长的连接,用户体验肯定很差,因此我们需要实 ...
- java 读取图片并转化为二进制字符串
本例子的目的在于测试往oracle数据库中插入blob字段 //以下代码源于:https://www.cnblogs.com/ywlx/p/4544179.html public static Str ...
- PHP基础语法: echo,var_dump, 常用函数:随机数:拆分字符串:explode()、rand()、日期时间:time()、字符串转化为时间戳:strtotime()可变参数的函数:PHP里数组长度表示方法:count($attr[指数组]);字符串长度:strlen($a)
PHP语言原理:先把代码显示在源代码中,再通过浏览器解析在网页上 a. 1.substr; //用于输出字符串中,需要的某一部分 <?PHP $a="learn php"; ...
- oc 之中的 汉字字符串转化成为拼音 汉字字符串的排序
在oc 之中的字符串为汉字的时候,我们经常要进行字符串比較,可是汉字不能比較,所以就要将汉字转化成为拼音,详细步骤例如以下: //可变字符串 必须是可变字符串. NSMutableString ...
- 【字符串处理算法】字符串包括的算法设计及C代码实现
一.需求描写叙述 给定一个长字符串和一个短字符串.编敲代码推断短字符串中的全部字符是否都在长字符串中.假设是,则长字符串包括短字符串:反之,不包括. 为了尽量包括大多数情况,字符串中能够包括大写和小写 ...
- java,url长链接生成短链接,短链接生成器,自定义字符串,对字符串md5混合KEY加密,根据短链接获得key值,不重复的随机数,不重复的随机字符串
java,url长链接生成短链接,短链接生成器,自定义字符串,对字符串md5混合KEY加密,根据短链接获得key值,不重复的随机数,不重复的随机字符串 package com.zdz.test; im ...
- 使用List把一个长字符串分解成若干个短字符串
把一个长字符串分解成若干个固定长度的短字符串,由于事先不知道长字符串的长度,以及短字符串的数量,只能使用List. public static void get_list_sbody(String s ...
- Java把长整型时间转成字符串日期
数据库里存放的是timestamp格式,前端取得后是这种:1436255550710长整型时间截转换成"2015-07-07"这种格式呢? import java.io.IOExc ...
- TSQL:判断某较短字符串在较长字符串中出现的次数。
给定一个较短字符串shortStr='ab',和一个较长字符串longStr='adkdabkwelabwkereabrsdweo2342ablk234lksdfsdf1abe': 判断shortSt ...
随机推荐
- opennebula kvm日志
Fri Jul :: [InM][I]: Command execution fail: 'if [ -x "/home/oneadmin/tmp/one/im/run_probes&quo ...
- 9-python 的ProxyHandler处理器(代理设置)
ProxyHandler处理器(代理设置) 使用代理IP,这是爬虫/反爬虫的第二大招,通常也是最好用的. 很多网站会检测某一段时间某个IP的访问次数(通过流量统计,系统日志等),如果访问次数多的不像正 ...
- 7-python自定义opener
Handler处理器 和 自定义Opener opener是 urllib2.OpenerDirector 的实例,我们之前一直都在使用的urlopen,它是一个特殊的opener(也就是模块帮我们构 ...
- 面试题:各大公司Java后端开发面试题总结 已看1 背1 有用 链接有必要看看
ThreadLocal(线程变量副本) --整理 Synchronized实现内存共享,ThreadLocal为每个线程维护一个本地变量. 采用空间换时间,它用于线程间的数据隔离,为每一个 ...
- c语言实践打印字母三角形
效果如下: int main(void) { char ch = 'A';//当前要打印的字符 ;//每行要打印字符的个数 ; i < ; i++,count++) { ; j < cou ...
- [docker]本地仓库的创建的使用
如果自己创建的镜像可以供其他同事使用,那就可以大大节约开发时间成本,docker的本地仓库正好可以满足这样的需求 1.在仓库服务器上创建本地仓库 baylor@baylor-virtual-machi ...
- javascript总结15:Break语句 与 continue语句
1 Break语句 解释:在循环体内,只要代码遇到break,程序立马结束当前循环. 当前循环指的是break语句所在的循环体. for (var i =1; i<10; i++){ if(i% ...
- delphi json用法
用法:uses Superobject, Sperjsondelphi里有json单元. procedure TForm2.SuperObjectClick(Sender: TObject); var ...
- mysql5.6数据库双机热备、主从备份
主题:mysql5.6数据库双机热备.主从备份 缘由: 在Web应用系统中,数据库性能是导致系统性能瓶颈最主要的原因之一.尤其是在大规模系统中,数据库集群已经成为必备的配置之一.集群的好处主要有:查询 ...
- 排序算法汇总(java实现,附源代码)
整理系统的时候发现了原来写的各种算法的总结,看了一下,大吃一惊,那时候的我还如此用心,具体的算法,有的已经模糊甚至忘记了,看的时候就把内容整理出来,顺便在熟悉一下,以后需要的时候就可以直接过来摘抄了. ...