在CMD里效验CDK指令是什么

在CMD里效验CDK指令是什么,第1张

CDK是序列号的校验码 用来验证序列号对不对的。序列号一般是没标的要自己读。给你个读序列号的程序改下端口就能用:

#include <reg51.h>

#include <intrins.h>

#define uchar unsigned char

#define uint unsigned int

sbit DQ = P2^0 //定义DS18B20端口DQ

sbit BEEP=P3^7 //蜂鸣器驱动线

bit presence

sbit LCD_RS = P2^6

sbit LCD_RW = P2^5

sbit LCD_EN = P2^4

uchar code cdis1[ ] = {" DS18B20 OK "}

uchar code cdis2[ ] = {""}

uchar code cdis3[ ] = {" DS18B20 ERR0R "}

uchar code cdis4[ ] = {" PLEASE CHECK "}

unsigned char data display[2] = {0x00,0x00}

unsigned char data RomCode[8] = {0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00}

unsigned char Temp

unsigned char crc

void beep()

#define delayNOP(){_nop_()_nop_()_nop_()_nop_()}

/*******************************************************************/

void delay1(int ms)

{

unsigned char y

while(ms--)

{

for(y = 0y<250y++)

{

_nop_()

_nop_()

_nop_()

_nop_()

}

}

}

/******************************************************************/

/**/

/*检查LCD忙状态 */

/*lcd_busy为1时,忙,等待。lcd-busy为0时,闲,可写指令与数据。 */

/**/

/******************************************************************/

bit lcd_busy()

{

bit result

LCD_RS = 0

LCD_RW = 1

LCD_EN = 1

delayNOP()

result = (bit)(P0&0x80)

LCD_EN = 0

return(result)

}

/*******************************************************************/

/* */

/*写指令数据到LCD */

/*RS=L,RW=L,E=高脉冲,D0-D7=指令码。 */

/* */

/*******************************************************************/

void lcd_wcmd(uchar cmd)

{

while(lcd_busy())

LCD_RS = 0

LCD_RW = 0

LCD_EN = 0

_nop_()

_nop_()

P0 = cmd

delayNOP()

LCD_EN = 1

delayNOP()

LCD_EN = 0

}

/*******************************************************************/

/* */

/*写显示数据到LCD */

/*RS=H,RW=L,E=高脉冲,D0-D7=数据。 */

/* */

/*******************************************************************/

void lcd_wdat(uchar dat)

{

while(lcd_busy())

LCD_RS = 1

LCD_RW = 0

LCD_EN = 0

P0 = dat

delayNOP()

LCD_EN = 1

delayNOP()

LCD_EN = 0

}

/*******************************************************************/

/* */

/* LCD初始化设定 */

/* */

/*******************************************************************/

void lcd_init()

{

delay1(15)

lcd_wcmd(0x01) //清除LCD的显示内容

lcd_wcmd(0x38) //16*2显示,5*7点阵,8位数据

delay1(5)

lcd_wcmd(0x38)

delay1(5)

lcd_wcmd(0x38)

delay1(5)

lcd_wcmd(0x0c) //显示开,关光标

delay1(5)

lcd_wcmd(0x06) //移动光标

delay1(5)

lcd_wcmd(0x01) //清除LCD的显示内容

delay1(5)

}

/*******************************************************************/

/* */

/* 设定显示位置 */

/* */

/*******************************************************************/

void lcd_pos(uchar pos)

{

lcd_wcmd(pos | 0x80) //数据指针=80+地址变量

}

/*******************************************************************/

/* */

/*us级延时函数 */

/* */

/*******************************************************************/

void Delay(unsigned int num)

{

while( --num )

}

/*******************************************************************/

/* */

/*初始化ds1820 */

/* */

/*******************************************************************/

Init_DS18B20(void)

{

DQ = 1 //DQ复位

Delay(8) //稍做延时

DQ = 0 //将DQ拉低

Delay(90) //精确延时 大于 480us

DQ = 1 //拉高总线

Delay(8)

presence = DQ //读取存在信号

Delay(100)

DQ = 1

return(presence)//返回信号,0=presence,1= no presence

}

/*******************************************************************/

/* */

/* 读一位(bit) */

/* */

/*******************************************************************/

uchar read_bit(void)

{

unsigned char i

DQ = 0 //将DQ 拉低开始读时间隙

DQ = 1 // then return high

for (i=0i<3i++) // 延时15μs

return(DQ) // 返回 DQ 线上的电平值

}

/*******************************************************************/

/* */

/* 读一个字节 */

/* */

/*******************************************************************/

ReadOneChar(void)

{

unsigned char i = 0

unsigned char dat = 0

//for (i = 8i >0i--)

// {

//read_bit()

//DQ = 0// 给脉冲信号

// dat >>= 1

//DQ = 1// 给脉冲信号

for (i=0i<8i++)

{ // 读取字节,每次读取一个字节

if(read_bit()) dat|=0x01<<i // 然后将其左移

//if(DQ)

// dat |= 0x80

Delay(4)

}

return (dat)

}

/*******************************************************************/

/* */

/* 写一位 */

/* */

/*******************************************************************/

void write_bit(char bitval) {

DQ = 0// 将DQ 拉低开始写时间隙

if(bitval==1) DQ =1 // 如果写1,DQ 返回高电平

Delay(5) // 在时间隙内保持电平值,

DQ = 1 // Delay函数每次循环延时16μs,因此delay(5) = 104μs

}

/*******************************************************************/

/* */

/* 写一个字节 */

/* */

/*******************************************************************/

WriteOneChar(unsigned char dat)

{

unsigned char i = 0

unsigned char temp

// for (i = 8i >0i--)

// {

for (i=0i<8i++) // 写入字节, 每次写入一位

{

//DQ = 0

//DQ = dat&0x01

//Delay(5)

//DQ = 1

temp = dat>>i

temp &= 0x01

write_bit(temp)

//dat>>=1

}

Delay(5)

}

/*******************************************************************/

/* */

/* 读取64位序列码 */

/* */

/*******************************************************************/

Read_RomCord(void)

{

unsigned char j

Init_DS18B20()

WriteOneChar(0x33) // 读序列码的操作

for (j = 0j <8j++)

{

RomCode[j] = ReadOneChar()

}

}

/*******************************************************************/

/* */

/*DS18B20的CRC8校验程序*/

/* */

/*******************************************************************/

uchar CRC8()

{

uchar i,xuchar crcbuff

crc=0

for(x = 0x <8x++)

{

crcbuff=RomCode[x]

for(i = 0i <8i++)

{

if(((crc ^ crcbuff)&0x01)==0)

crc >>= 1

else {

crc ^= 0x18 //CRC=X8+X5+X4+1

crc >>= 1

crc |= 0x80

}

crcbuff >>= 1

}

}

return crc

}

/*******************************************************************/

/* */

/* 数据转换与显示 */

/* */

/*******************************************************************/

Disp_RomCode()

{

uchar j

uchar H_num=0x40 //LCD第二行初始位置

for(j=0j<8j++)

{

Temp = RomCode[j]

display[0]=((Temp&0xf0)>>4)

if(display[0]>9)

{ display[0]=display[0]+0x37}

else{display[0]=display[0]+0x30}

lcd_pos(H_num)

lcd_wdat(display[0]) //高位数显示

H_num++

display[1]=(Temp&0x0f)

if(display[1]>9)

{display[1]=display[1]+0x37}

else {display[1]=display[1]+0x30}

lcd_pos(H_num)

lcd_wdat(display[1]) //低位数显示

H_num++

}

}

/*******************************************************************/

/* */

/* 蜂鸣器响一声*/

/* */

/*******************************************************************/

void beep()

{

unsigned char y

for (y=0y<100y++)

{

Delay(60)

BEEP=!BEEP //BEEP取反

}

BEEP=1 //关闭蜂鸣器

Delay(40000)

}

/*******************************************************************/

/* */

/* DS18B20 OK 显示菜单 */

/* */

/*******************************************************************/

void Ok_Menu ()

{

uchar m

lcd_init() //初始化LCD

lcd_pos(0) //设置显示位置为第一行的第1个字符

m = 0

while(cdis1[m] != 'C 自动请求重发')

{ //显示字符

lcd_wdat(cdis1[m])

m++

}

lcd_pos(0x40)//设置显示位置为第二行第1个字符

m = 0

while(cdis2[m] != '接受到的是110111001说明传输的就是这段序列号,假设传输的二进制信息为*****,则由G(x)=11001可知

需要将****后面加4个0然后去除以11001 得到的余数再加到****后面就是110111001

又可知余数是1001 则 原来要传送的信息为11011 则110110000除11001得到的余数如果是1001 就说明再传送过程中没有出错 若不是则说明 出错了

经计算 余数貌似是1011 则说明出错了')

{

lcd_wdat(cdis2[m]) //显示字符

m++

}

}

/*******************************************************************/

/* */

/* DS18B20 ERROR 显示菜单 */

/* */

/*******************************************************************/

void Error_Menu ()

{

uchar m

lcd_init() //初始化LCD

lcd_pos(0) //设置显示位置为第一行的第1个字符

m = 0

while(cdis3[m] != '数据链路层使用帧尾的FCS(帧循环校验序列)完成差错控制

网络层使用数据包中的校验和进行差错校验

传输层使用序列号、确认号、校验和进行差错控制</pre>

<div class="replyask-box u-154740002-e " id="replyask-1741526">

<h4 class="ask">追问</h4>

<div class="replyask-content">

<pre class="replyask-text" id="content-1741526">谢谢!有具体点的吗!</pre>

</div>

<div class="replyask-data" id="data-1741526">

<input type="hidden" name="raid" value="1741526" />

<input type="hidden" name="mapUrl" value="" />

<input type="hidden" name="refer" value="" />

<input type="hidden" name="pid" value="" />

</div>

</div>

<div class="replyask-box u-64187941-e last" id="replyask-1782339">

<h4 class="reply">回答</h4>

<div class="replyask-content">

<pre class="replyask-text" id="content-1782339">数据链路层的帧尾有fcs,当发送方发送帧之前会对帧中的数据进行校验,采用CRC算法,将得到的数值封装到帧尾,也就是fcs。接收方收到该帧后,用同样的算法对帧中的数据进行计算,将得到的数值与帧尾的fcs进行比较,如果一致则该帧正确,如不一致,则该帧错误。

网络层的IP数据包的包头部分由校验和一项,也是发送发将校验值加入,接收方使用相同算法计算后比较。

传输层的校验和作用同上。还可以通过序列号确认号避免报文重传。')

{ //显示字符

lcd_wdat(cdis3[m])

m++

}

lcd_pos(0x40)//设置显示位置为第二行第1个字符

m = 0

while(cdis4[m] != '还有链路标识,流量控制等等,差错检测多用方阵码校验.')

{

lcd_wdat(cdis4[m]) //显示字符

m++

}

}

/*******************************************************************/

/* */

/* 主函数 */

/* */

/*******************************************************************/

void main()

{

P0 = 0xff

P2 = 0xff

while(1)

{

Ok_Menu ()

Read_RomCord() //读取64位序列码

CRC8() //CRC效验

if(crc==0) //CRC效验正确

{

Disp_RomCode()//显示64位序列码

beep()

}

while(!presence)

{

Init_DS18B20()

delay1(1000)

}

Error_Menu ()

do

{

Init_DS18B20()

beep()

}

while(presence)

}

}

/*******************************************************************/fsc

步骤如下:

1、首先双击运行电脑上的Steam客户端,在登录界面,输入账号密码,登录自己的账户。

2、登录之后,在首页点击需要激活的“游戏”,然后点击“激活产品”,之后点击“下一步”。

3、之后会出现用户协议的弹窗,在这里点击“我同意”。输入购买好的CDKEY,注意不要空格。

4、最后点击下一步,如果CDKEY输入没有错误的话,就会出现激活成功提示,游戏就出现在库中了。

CDKEY是大部分商业软件都需要使用序列码(或CDKEY码) 安装序列码,简称密钥

在网络上兑换物品,一般商家会给你一串密钥,这串密钥就叫cdkey,去商家给你的网站上输入密钥选择你DNF角色所在地,即可兑换物品。

CDKEY就像钥匙,只不过这把钥匙打开的不是门,而是一个礼品兑换码。

CDKEY的组成一般是由大写或小写英文字母和阿拉伯数字组成,密钥有多少字符由官方协定,没有固定字符数量。

扩展资料:

DNF的CDKEY兑换流程:

1.在搜索引擎中搜索关键词“DNFCDK”,选择第一个官方网站。

2.在界面“奖品中心”中,在“请输入CDKEY”这一栏输入自己的礼品密钥。

3.选择自己需要领取此礼包的账号,点击选择“区服”“服务器”再选择角色。

4.最后一步输入右侧的验证码,点击界面中的“确定”即可领取礼品。

参考资料来源:百度百科—CDKEY


欢迎分享,转载请注明来源:夏雨云

原文地址:https://www.xiayuyun.com/zonghe/540998.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-06-26
下一篇2023-06-26

发表评论

登录后才能评论

评论列表(0条)

    保存