邀请码生成器Java代码

邀请码生成器Java代码importjava.util.Random;/***邀请码生成器,算法原理:*1)获取id:1127738*2)使用自定义进制转为:gpm6*3)转为字符串,并在后面加’o’字符:gpm6o*4)在后面随机产生若干

import
java.util.Random;
 
/**
 
* 邀请码生成器,算法原理:<br/>
 
* 1) 获取id: 1127738 <br/>
 
* 2) 使用自定义进制转为:gpm6 <br/>
 
* 3) 转为字符串,并在后面加'o'字符:gpm6o <br/>
 
* 4)在后面随机产生若干个随机数字字符:gpm6o7 <br/>
 
* 转为自定义进制后就不会出现o这个字符,然后在后面加个'o',这样就能确定唯一性。最后在后面产生一些随机字符进行补全。<br/>
 
* @author jiayu.qiu
 
*/
public
class
ShareCodeUtil {
 
    
/** 自定义进制(0,1没有加入,容易与o,l混淆) */
    
private
static
final
char
[] r=
new
char
[]{

'q'
,
'w'
,
'e'
,
'8'
,
'a'
,
's'
,
'2'
,
'd'
,
'z'
,
'x'
,
'9'
,
'c'
,
'7'
,
'p'
,
'5'
,
'i'
,
'k'
,
'3'
,
'm'
,
'j'
,
'u'
,
'f'
,
'r'
,
'4'
,
'v'
,
'y'
,
'l'
,
't'
,
'n'
,
'6'
,
'b'
,
'g'
,
'h'
};
 
    
/** (不能与自定义进制有重复) */
    
private
static
final
char
b=
'o'
;
 
    
/** 进制长度 */
    
private
static
final
int
binLen=r.length;
 
    
/** 序列最小长度 */
    
private
static
final
int
s=
6
;
 
    
/**
     
* 根据ID生成六位随机码
     
* @param id ID
     
* @return 随机码
     
*/
    
public
static
String toSerialCode(
long
id) {
        
char
[] buf=
new
char
[
32
];
        
int
charPos=
32
;
 
        
while
((id / binLen) >
0
) {
            
int
ind=(
int
)(id % binLen);
            
// System.out.println(num + "-->" + ind);
            
buf[--charPos]=r[ind];
            
id /= binLen;
        
}
        
buf[--charPos]=r[(
int
)(id % binLen)];
        
// System.out.println(num + "-->" + num % binLen);
        
String str=
new
String(buf, charPos, (
32
- charPos));
        
// 不够长度的自动随机补全
        
if
(str.length() < s) {
            
StringBuilder sb=
new
StringBuilder();
            
sb.append(b);
            
Random rnd=
new
Random();
            
for
(
int
i=
1
; i < s - str.length(); i++) {
            
sb.append(r[rnd.nextInt(binLen)]);
            
}
            
str+=sb.toString();
        
}
        
return
str;
    
}
 
    
public
static
long
codeToId(String code) {
        
char
chs[]=code.toCharArray();
        
long
res=0L;
        
for
(
int
i=
0
; i < chs.length; i++) {
            
int
ind=
0
;
            
for
(
int
j=
0
; j < binLen; j++) {
                
if
(chs[i] == r[j]) {
                    
ind=j;
                    
break
;
                
}
            
}
            
if
(chs[i] == b) {
                
break
;
            
}
            
if
(i >
0
) {
                
res=res * binLen + ind;
            
}
else
{
                
res=ind;
            
}
            
// System.out.println(ind + "-->" + res);
        
}
        
return
res;
    
}
}

今天的文章邀请码生成器Java代码分享到此就结束了,感谢您的阅读。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/66269.html

(0)
编程小号编程小号

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注