一元购幸运号码计算方式如下:
奖品的最后一个幸运号码分配完毕后,将公示该分配时间点前本期全部订单的最后6个提交并支付完成的订单时间。
将这6个时间的数值进行求和得出数值A,每个时间按时、分、秒的顺序组合,例如18:19:25则为181925。
数值B为奖品所需人次。
数值A除以数值B得到的余数+原始数10000001,得到最终幸运号码,拥有该幸运号码者,直接获得该奖品。
// 抓取最后6条幸运号码记录
List<HappyUserRecord> LastSixLuckyNumber = userLuckynumberService.getLastSix(Integer.parseInt(partakeRecord));
double lastSixSum = 0;
String lastSixInfo = "";
for (int i = 0; i < LastSixLuckyNumber.size(); i++) {
lastSixSum=lastSixSum+Float.parseFloat(Tools.getTime(LastSixLuckyNumber.get(i).getUpdatetime()));
// 根据用户参与id查询用户电话号码
String phoneNumber = LastSixLuckyNumber.get(i).getPhoneNumber();
lastSixInfo += Tools.getCreatetime(LastSixLuckyNumber.get(i).getUpdatetime())+"+"+Tools.getTime(LastSixLuckyNumber.get(i).getUpdatetime())+"+"+phoneNumber+"=";
}
int winningnumber = Integer.parseInt(commodityRecordInfo.getWinningnumber());
int luckyNumber = ((int)lastSixSum%winningnumber)+10000001;// 计算幸运号码
System.out.println("计算出来的幸运号码是:"+luckyNumber);// 计算出来的幸运号码
其中getLastSix方法的sql语句是:
SELECT id,userId,partakeRecord,phoneNumber,partakeNumber,payWay,createTime,updatetime FROM happy_user_record WHERE partakeRecord=#{id} ORDER BY id DESC limit 0,6
这是正常情况下计算幸运号码的方式,这种方式本身没什么问题,因为作为数字A,是通过支付时间来决定的,本身是不可预料的,所以在所有的一元购形式的APP或者网站中,都会公开这种计算幸运号码的方式,乍看之下并无作假方式。但是,如果预先有幸运号码了呢(预先的幸运号码也是通过随机选择)?再通过幸运号码反推出数字A,进而更改得到数字A的时间呢? 下一篇文章介绍默认幸运号码的中奖方式。