(一)、简要概述:
验证码在我们生活中已经随处可以见,因为验证码的随机性也就是验证码的安全性的显著提高,而且我们也可以根据对验证码字数的设置,让安全性更加的稳定,不可破。接下来吉士先生就带领大家实现验证码的实现。
1.思路分析
需要到的包:
随机包:
import java.util.Random Random r=new Random() r.netxtInt();
基本思路: 我们要知道数字0的ascil码十进制是: 48;大写字母A的十进制是65,小写字母a的十进制Ascii码是:97.所以首先我们要设置一个字符数组,目的是为了储存26+26+10=62个字符.然后进行初步判断进行得到小写字母a。然后通过65+i-26得到大写字母A。最后剩余的的补充数字.
2.代码展示:
package test; // 包名 import java.util.Random; public class test1 { //项目名 static int count=48; //目的是为了 数字0到9 public static void main(String []avgs) { Random r=new Random(); //随机数声明 char Eng[]=new char[62]; for(int i=0;i<Eng.length;i++) { if(i<=25) //得出来小写字母 { Eng[i]=(char) (97+i); } else if(i>25&&i<52) //得出来大写字母 { Eng[i]=(char)(65+i-26) ;//27 } else //得出来阿拉侬数字 { Eng[i]=(char)(count); count++; } } String s=" "; //进行合并复制 for(int i=0;i<6;i++) { int EngRandomIdex=r.nextInt(Eng.length); s=s+Eng[EngRandomIdex]; } System.out.println("验证码是:"+s); //输出 /* for(int i=0;i<Eng.length;i++) { System.out.println(Eng[i]+" "); }*/ } }
3.效果展示:
验证码
(二)、密码加密C++操作
1.基本思路和解析:
首先我们要知道c中有一个转义字符‘\b’,它是用来表示后退一步的。当后退一步的时候光标会移动到前一位数字的下面,当你输入一个数字便会覆盖你后退的那个数字(这个能够理解接下来的代码就没有问题了)
2.代码展示:
#include <iostream> #include <conio.h> #include <string.h> using namespace std; int main() { char s[100]; string s1 = "*"; char c; int i = 0; cout << "请输入您的密码:" << endl; while (1) { c = _getch(); if (c == '\r')break; //按下enter就会退出 if (c == '\b') //按下backspace键就会删除 { if (i > 0) //目的是删除储存进来的那个数组元素 { i--; } printf("\b"); //回退一格光标 printf(" "); //打印一个空格把要删除的字符覆盖了 printf("\b"); //再回退一格光标来掩饰掉打印的空格 continue; //不能省略,一旦省略就会出现删除不动的错误. } s[i++] = c; cout << "*"; } cout << "您输入的密码是:" ; for (int j = 0; j < i; j++) { cout << s[j]; } }
密码加密删除效果
(三)、QQ登入系统:
1.建设QQ登入系统的背景.
因为自己有一颗对系统非常敏感的心,所以在本人大一下学期也就是:2022年3月16日,于是啊,我下定决心尝试一个简介版的QQ登入系统。于是有了以下的基本想法.
2.基本头文件
#include <string.h> 目的是为了作比较
代码展示:
#include <iostream> #include <string.h> //判断字符数组相不相等的数据库 using namespace std; int main() { double D=1.5; int C; //int Q,S,M,X;//字符数组进行比较大小要用string ,切记char 后面不能跟字母 char Q[100],S[100],M[100],X[100]; cout<<"===================================欢迎使用 QQ==================================="<<endl; cout<<"您要选择那种方式:"<<endl; cout<<"1.登入"<<endl; cout<<"2.注册"<<endl; cin>>C; if(D>C) { cout<<"===================================您选择了账号登入==================================="<<endl; cout<<"请输入您的QQ/手机号:"<<endl; cin>>Q; cout<<"请输入您的密码:"<<endl; cin>>S; cout<<"登入成功!"<<endl; } else//如果用else语句,则不用加后面的表达式 { cout<<"===================================您选择了创建新账号==================================="<<endl; cout<<"请输入您的手机号:"<<endl; cin>>Q; cout<<"请输入您的验证码:"<<endl; cin>>S; cout<<"注册成功!"<<endl; cout<<"您的新账号为:2261203961"<<endl; cout<<"请设置您的QQ密码:"<<endl;//因为用的是int,如果用string可以 ,所以密码不能输入字符 cin>>M; cout<<"请再次输入您的密码:"<<endl; cin>>X; // if(X!=M) if(strcmp(X,M)!=0)//判断字符数组是否相等 { //while(X!=M) while(strcmp(X,M)!=0) { cout<<"和原输入的密码不吻合,请再次输入您的密码!"<<endl; cin>>X; } cout<<"登入成功!"<<endl; } else { cout<<"登入成功!"<<endl; } } return 0; }
效果展示:
(四)、抽奖系统:
基本思路:
题目要求我们进行随机抽取,且不能有重复中奖信息。首先我们需要使用静态数组进行操作设置奖项,然后设置一个空的数组,长度为静态数组的长度。然后设置一个回调函数,判断我们所引入的数组是否与中奖的名单相同,如果相同返回TURE,否则返回FALSE。然后在主函数中进行循环遍历,获得随机索引,然后再利用随机索引进行随即查找,判断,如果不同的话就行输出,相同继续循环.
代码展示:
package test; // 包名 import java.util.Random; public class test1 { //项目名 public static void main(String []avgs) { int number[]={2,588,888,1000,10000,4}; //共有奖项 int newNumber[]=new int[number.length]; //定义一个空的 int idex; //目的是为了游标 Random r=new Random(); for(int i=0;i<number.length; ) { idex=r.nextInt(number.length); //获得游标 int prize=number[idex]; //获奖 boolean flag=contains(newNumber,prize); if(!flag) { newNumber[i]=prize; i++; System.out.println("恭喜您获得:"+prize+"元奖励"); } System.out.println("再来一次!"); } } public static boolean contains(int number[],int prize) { for(int i=0;i<number.length;i++) { if(number[i]==prize) { return true; } } return false; } }
效果展示:
抽奖系统演练
(五)、抽奖系统优化:
基本思路:先乱序再排序
图解:
代码展示:
package test; // 包名 import java.util.Random; public class test1 { //项目名 public static void main(String []avgs) { Random r=new Random(); int number[]={2,588,888,1000,10000,4}; //共有奖项 for(int i=0;i<number.length;i++) { int index=r.nextInt(number.length); //先打乱再排序. int temp; temp=number[i]; number[i]=number[index]; number[index]=temp; } for(int i=0;i<number.length;i++) { System.out.println(number[i]); } } }
效果展示:
如有不解 ,可支持私聊!