前沿拓展:
cdkey生成器
CDK生成器肯定有毒沙良師般保紹致請判景。。建議別用。。
一、前言
在很多商業(yè)軟件中,需要提供一些可以試運(yùn)行的版本,這樣就需要配套密鑰機(jī)制來控制,縱觀大部分的試用版軟件,基本上采用以下幾種機(jī)制來控制。
1:遠(yuǎn)程聯(lián)網(wǎng)激活,每次啟動都聯(lián)網(wǎng)查看使用時(shí)間等,這種方法最完美,缺點(diǎn)是沒法聯(lián)網(wǎng)的設(shè)備就歇菜了。
2:通過獲取本地的硬盤+CPU等硬件的編號,做一個(gè)運(yùn)算,生成一個(gè)激活碼,超過半數(shù)的軟件會采用此方法,缺點(diǎn)是不能自由控制軟件的其他參數(shù),比如軟件中添加的設(shè)備數(shù)量的控制。
3:設(shè)定一個(gè)運(yùn)行到期時(shí)間+數(shù)量限制+已運(yùn)行時(shí)間的密鑰文件,發(fā)給用戶配套軟件使用,缺點(diǎn)是如果僅僅設(shè)置的是運(yùn)行到期時(shí)間,用戶可以更改電腦時(shí)間來獲取更長的使用時(shí)間,在電腦不聯(lián)網(wǎng)的情況下。
本demo采用拋磚引玉的形式,用第三種方法來實(shí)現(xiàn),密鑰文件采用最簡單的異或加密,可以自行改成其他加密方法。
二、實(shí)現(xiàn)的功能可以控制軟件使用時(shí)間??梢钥刂栖浖\(yùn)行時(shí)間??梢钥刂圃O(shè)備的數(shù)量??梢栽诠ぞ呱蠁雍屯V狗?wù)。可以查看已重啟過幾次。可以清空復(fù)位重啟次數(shù)。三、效果圖
四、完整代碼#include “frmmain.h”
#include “ui_frmmain.h”
#include “qmessagebox.h”
#include “qfile.h”
#include “qprocess.h”
#include “qdebug.h”
frmMain::frmMain(QWidget *parent) : QWidget(parent), ui(new Ui::frmMain)
{
ui->setupUi(this);
this->initForm();
qDebug() << this->getCpuName() << this->getCpuId() << this->getDiskNum();
}
frmMain::~frmMain()
{
delete ui;
}
void frmMain::initForm()
{
QStringList min;
min << “1” << “5” << “10” << “20” << “30”;
for (int i = 1; i <= 24; i++) {
min << QString::number(i * 60);
}
ui->cboxMin->addItems(min);
ui->cboxMin->setCurrentIndex(1);
ui->dateEdit->setDate(QDate::currentDate());
for (int i = 5; i <= 150; i = i + 5) {
ui->cboxCount->addItem(QString(“%1″).arg(i));
}
}
QString frmMain::getWMIC(const QString &cmd)
{
//獲取cpu名稱:wmic cpu get Name
//獲取cpu核心數(shù):wmic cpu get NumberOfCores
//獲取cpu線程數(shù):wmic cpu get NumberOfLogicalProcessors
//查詢cpu序列號:wmic cpu get processorid
//查詢主板序列號:wmic baseboard get serialnumber
//查詢BIOS序列號:wmic bios get serialnumber
//查看硬盤:wmic diskdrive get serialnumber
QProcess p;
p.start(cmd);
p.waitForFinished();
QString result = QString::fromLocal8Bit(p.readAllStandardOutput());
QStringList list = cmd.split(” “);
result = result.remove(list.last(), Qt::CaseInsensitive);
result = result.replace(“r”, “”);
result = result.replace(“n”, “”);
result = result.simplified();
return result;
}
QString frmMain::getCpuName()
{
return getWMIC(“wmic cpu get name”);
}
QString frmMain::getCpuId()
{
return getWMIC(“wmic cpu get processorid”);
}
QString frmMain::getDiskNum()
{
return getWMIC(“wmic diskdrive where index=0 get serialnumber”);
}
QString frmMain::getXorEncryptDecrypt(const QString &data, char key)
{
//采用異或加密,也可以自行更改算法
QByteArray buffer = data.toLatin1();
int size = buffer.size();
for (int i = 0; i < size; i++) {
buffer[i] = buffer.at(i) ^ key;
}
return QLatin1String(buffer);
}
void frmMain::on_btnOk_clicked()
{
bool useDate = ui->ckDate->isChecked();
bool useRun = ui->ckRun->isChecked();
bool useCount = ui->ckCount->isChecked();
if (!useDate && !useRun && !useCount) {
if (QMessageBox::question(this, “詢問”, “確定要生成沒有任何限制的密鑰嗎?”) != QMessageBox::Yes) {
return;
}
}
QString strDate = ui->dateEdit->date().toString(“yyyy-MM-dd”);
QString strRun = ui->cboxMin->currentText();
QString strCount = ui->cboxCount->currentText();
QString key = QString(“%1|%2|%3|%4|%5|%6”).arg(useDate).arg(strDate).arg(useRun).arg(strRun).arg(useCount).arg(strCount);
QFile file(QApplication::applicationDirPath() + “/key.db”);
file.open(QFile::WriteOnly | QIODevice::Text);
file.write(getXorEncryptDecrypt(key, 110).toLatin1());
file.close();
QMessageBox::information(this, “提示”, “生成密鑰成功,將 key.db 文件拷貝到對應(yīng)目錄即可!”);
}
void frmMain::on_btnClose_clicked()
{
this->close();
}
拓展知識:
前沿拓展:
cdkey生成器
CDK生成器肯定有毒沙良師般保紹致請判景。。建議別用。。
一、前言
在很多商業(yè)軟件中,需要提供一些可以試運(yùn)行的版本,這樣就需要配套密鑰機(jī)制來控制,縱觀大部分的試用版軟件,基本上采用以下幾種機(jī)制來控制。
1:遠(yuǎn)程聯(lián)網(wǎng)激活,每次啟動都聯(lián)網(wǎng)查看使用時(shí)間等,這種方法最完美,缺點(diǎn)是沒法聯(lián)網(wǎng)的設(shè)備就歇菜了。
2:通過獲取本地的硬盤+CPU等硬件的編號,做一個(gè)運(yùn)算,生成一個(gè)激活碼,超過半數(shù)的軟件會采用此方法,缺點(diǎn)是不能自由控制軟件的其他參數(shù),比如軟件中添加的設(shè)備數(shù)量的控制。
3:設(shè)定一個(gè)運(yùn)行到期時(shí)間+數(shù)量限制+已運(yùn)行時(shí)間的密鑰文件,發(fā)給用戶配套軟件使用,缺點(diǎn)是如果僅僅設(shè)置的是運(yùn)行到期時(shí)間,用戶可以更改電腦時(shí)間來獲取更長的使用時(shí)間,在電腦不聯(lián)網(wǎng)的情況下。
本demo采用拋磚引玉的形式,用第三種方法來實(shí)現(xiàn),密鑰文件采用最簡單的異或加密,可以自行改成其他加密方法。
二、實(shí)現(xiàn)的功能可以控制軟件使用時(shí)間??梢钥刂栖浖\(yùn)行時(shí)間??梢钥刂圃O(shè)備的數(shù)量??梢栽诠ぞ呱蠁雍屯V狗?wù)??梢圆榭匆阎貑⑦^幾次。可以清空復(fù)位重啟次數(shù)。三、效果圖
四、完整代碼#include “frmmain.h”
#include “ui_frmmain.h”
#include “qmessagebox.h”
#include “qfile.h”
#include “qprocess.h”
#include “qdebug.h”
frmMain::frmMain(QWidget *parent) : QWidget(parent), ui(new Ui::frmMain)
{
ui->setupUi(this);
this->initForm();
qDebug() << this->getCpuName() << this->getCpuId() << this->getDiskNum();
}
frmMain::~frmMain()
{
delete ui;
}
void frmMain::initForm()
{
QStringList min;
min << “1” << “5” << “10” << “20” << “30”;
for (int i = 1; i <= 24; i++) {
min << QString::number(i * 60);
}
ui->cboxMin->addItems(min);
ui->cboxMin->setCurrentIndex(1);
ui->dateEdit->setDate(QDate::currentDate());
for (int i = 5; i <= 150; i = i + 5) {
ui->cboxCount->addItem(QString(“%1″).arg(i));
}
}
QString frmMain::getWMIC(const QString &cmd)
{
//獲取cpu名稱:wmic cpu get Name
//獲取cpu核心數(shù):wmic cpu get NumberOfCores
//獲取cpu線程數(shù):wmic cpu get NumberOfLogicalProcessors
//查詢cpu序列號:wmic cpu get processorid
//查詢主板序列號:wmic baseboard get serialnumber
//查詢BIOS序列號:wmic bios get serialnumber
//查看硬盤:wmic diskdrive get serialnumber
QProcess p;
p.start(cmd);
p.waitForFinished();
QString result = QString::fromLocal8Bit(p.readAllStandardOutput());
QStringList list = cmd.split(” “);
result = result.remove(list.last(), Qt::CaseInsensitive);
result = result.replace(“r”, “”);
result = result.replace(“n”, “”);
result = result.simplified();
return result;
}
QString frmMain::getCpuName()
{
return getWMIC(“wmic cpu get name”);
}
QString frmMain::getCpuId()
{
return getWMIC(“wmic cpu get processorid”);
}
QString frmMain::getDiskNum()
{
return getWMIC(“wmic diskdrive where index=0 get serialnumber”);
}
QString frmMain::getXorEncryptDecrypt(const QString &data, char key)
{
//采用異或加密,也可以自行更改算法
QByteArray buffer = data.toLatin1();
int size = buffer.size();
for (int i = 0; i < size; i++) {
buffer[i] = buffer.at(i) ^ key;
}
return QLatin1String(buffer);
}
void frmMain::on_btnOk_clicked()
{
bool useDate = ui->ckDate->isChecked();
bool useRun = ui->ckRun->isChecked();
bool useCount = ui->ckCount->isChecked();
if (!useDate && !useRun && !useCount) {
if (QMessageBox::question(this, “詢問”, “確定要生成沒有任何限制的密鑰嗎?”) != QMessageBox::Yes) {
return;
}
}
QString strDate = ui->dateEdit->date().toString(“yyyy-MM-dd”);
QString strRun = ui->cboxMin->currentText();
QString strCount = ui->cboxCount->currentText();
QString key = QString(“%1|%2|%3|%4|%5|%6”).arg(useDate).arg(strDate).arg(useRun).arg(strRun).arg(useCount).arg(strCount);
QFile file(QApplication::applicationDirPath() + “/key.db”);
file.open(QFile::WriteOnly | QIODevice::Text);
file.write(getXorEncryptDecrypt(key, 110).toLatin1());
file.close();
QMessageBox::information(this, “提示”, “生成密鑰成功,將 key.db 文件拷貝到對應(yīng)目錄即可!”);
}
void frmMain::on_btnClose_clicked()
{
this->close();
}
拓展知識:
前沿拓展:
cdkey生成器
CDK生成器肯定有毒沙良師般保紹致請判景。。建議別用。。
一、前言
在很多商業(yè)軟件中,需要提供一些可以試運(yùn)行的版本,這樣就需要配套密鑰機(jī)制來控制,縱觀大部分的試用版軟件,基本上采用以下幾種機(jī)制來控制。
1:遠(yuǎn)程聯(lián)網(wǎng)激活,每次啟動都聯(lián)網(wǎng)查看使用時(shí)間等,這種方法最完美,缺點(diǎn)是沒法聯(lián)網(wǎng)的設(shè)備就歇菜了。
2:通過獲取本地的硬盤+CPU等硬件的編號,做一個(gè)運(yùn)算,生成一個(gè)激活碼,超過半數(shù)的軟件會采用此方法,缺點(diǎn)是不能自由控制軟件的其他參數(shù),比如軟件中添加的設(shè)備數(shù)量的控制。
3:設(shè)定一個(gè)運(yùn)行到期時(shí)間+數(shù)量限制+已運(yùn)行時(shí)間的密鑰文件,發(fā)給用戶配套軟件使用,缺點(diǎn)是如果僅僅設(shè)置的是運(yùn)行到期時(shí)間,用戶可以更改電腦時(shí)間來獲取更長的使用時(shí)間,在電腦不聯(lián)網(wǎng)的情況下。
本demo采用拋磚引玉的形式,用第三種方法來實(shí)現(xiàn),密鑰文件采用最簡單的異或加密,可以自行改成其他加密方法。
二、實(shí)現(xiàn)的功能可以控制軟件使用時(shí)間??梢钥刂栖浖\(yùn)行時(shí)間??梢钥刂圃O(shè)備的數(shù)量。可以在工具上啟動和停止服務(wù)??梢圆榭匆阎貑⑦^幾次??梢郧蹇諒?fù)位重啟次數(shù)。三、效果圖
四、完整代碼#include “frmmain.h”
#include “ui_frmmain.h”
#include “qmessagebox.h”
#include “qfile.h”
#include “qprocess.h”
#include “qdebug.h”
frmMain::frmMain(QWidget *parent) : QWidget(parent), ui(new Ui::frmMain)
{
ui->setupUi(this);
this->initForm();
qDebug() << this->getCpuName() << this->getCpuId() << this->getDiskNum();
}
frmMain::~frmMain()
{
delete ui;
}
void frmMain::initForm()
{
QStringList min;
min << “1” << “5” << “10” << “20” << “30”;
for (int i = 1; i <= 24; i++) {
min << QString::number(i * 60);
}
ui->cboxMin->addItems(min);
ui->cboxMin->setCurrentIndex(1);
ui->dateEdit->setDate(QDate::currentDate());
for (int i = 5; i <= 150; i = i + 5) {
ui->cboxCount->addItem(QString(“%1″).arg(i));
}
}
QString frmMain::getWMIC(const QString &cmd)
{
//獲取cpu名稱:wmic cpu get Name
//獲取cpu核心數(shù):wmic cpu get NumberOfCores
//獲取cpu線程數(shù):wmic cpu get NumberOfLogicalProcessors
//查詢cpu序列號:wmic cpu get processorid
//查詢主板序列號:wmic baseboard get serialnumber
//查詢BIOS序列號:wmic bios get serialnumber
//查看硬盤:wmic diskdrive get serialnumber
QProcess p;
p.start(cmd);
p.waitForFinished();
QString result = QString::fromLocal8Bit(p.readAllStandardOutput());
QStringList list = cmd.split(” “);
result = result.remove(list.last(), Qt::CaseInsensitive);
result = result.replace(“r”, “”);
result = result.replace(“n”, “”);
result = result.simplified();
return result;
}
QString frmMain::getCpuName()
{
return getWMIC(“wmic cpu get name”);
}
QString frmMain::getCpuId()
{
return getWMIC(“wmic cpu get processorid”);
}
QString frmMain::getDiskNum()
{
return getWMIC(“wmic diskdrive where index=0 get serialnumber”);
}
QString frmMain::getXorEncryptDecrypt(const QString &data, char key)
{
//采用異或加密,也可以自行更改算法
QByteArray buffer = data.toLatin1();
int size = buffer.size();
for (int i = 0; i < size; i++) {
buffer[i] = buffer.at(i) ^ key;
}
return QLatin1String(buffer);
}
void frmMain::on_btnOk_clicked()
{
bool useDate = ui->ckDate->isChecked();
bool useRun = ui->ckRun->isChecked();
bool useCount = ui->ckCount->isChecked();
if (!useDate && !useRun && !useCount) {
if (QMessageBox::question(this, “詢問”, “確定要生成沒有任何限制的密鑰嗎?”) != QMessageBox::Yes) {
return;
}
}
QString strDate = ui->dateEdit->date().toString(“yyyy-MM-dd”);
QString strRun = ui->cboxMin->currentText();
QString strCount = ui->cboxCount->currentText();
QString key = QString(“%1|%2|%3|%4|%5|%6”).arg(useDate).arg(strDate).arg(useRun).arg(strRun).arg(useCount).arg(strCount);
QFile file(QApplication::applicationDirPath() + “/key.db”);
file.open(QFile::WriteOnly | QIODevice::Text);
file.write(getXorEncryptDecrypt(key, 110).toLatin1());
file.close();
QMessageBox::information(this, “提示”, “生成密鑰成功,將 key.db 文件拷貝到對應(yīng)目錄即可!”);
}
void frmMain::on_btnClose_clicked()
{
this->close();
}
拓展知識:
前沿拓展:
cdkey生成器
CDK生成器肯定有毒沙良師般保紹致請判景。。建議別用。。
一、前言
在很多商業(yè)軟件中,需要提供一些可以試運(yùn)行的版本,這樣就需要配套密鑰機(jī)制來控制,縱觀大部分的試用版軟件,基本上采用以下幾種機(jī)制來控制。
1:遠(yuǎn)程聯(lián)網(wǎng)激活,每次啟動都聯(lián)網(wǎng)查看使用時(shí)間等,這種方法最完美,缺點(diǎn)是沒法聯(lián)網(wǎng)的設(shè)備就歇菜了。
2:通過獲取本地的硬盤+CPU等硬件的編號,做一個(gè)運(yùn)算,生成一個(gè)激活碼,超過半數(shù)的軟件會采用此方法,缺點(diǎn)是不能自由控制軟件的其他參數(shù),比如軟件中添加的設(shè)備數(shù)量的控制。
3:設(shè)定一個(gè)運(yùn)行到期時(shí)間+數(shù)量限制+已運(yùn)行時(shí)間的密鑰文件,發(fā)給用戶配套軟件使用,缺點(diǎn)是如果僅僅設(shè)置的是運(yùn)行到期時(shí)間,用戶可以更改電腦時(shí)間來獲取更長的使用時(shí)間,在電腦不聯(lián)網(wǎng)的情況下。
本demo采用拋磚引玉的形式,用第三種方法來實(shí)現(xiàn),密鑰文件采用最簡單的異或加密,可以自行改成其他加密方法。
二、實(shí)現(xiàn)的功能可以控制軟件使用時(shí)間??梢钥刂栖浖\(yùn)行時(shí)間。可以控制設(shè)備的數(shù)量??梢栽诠ぞ呱蠁雍屯V狗?wù)??梢圆榭匆阎貑⑦^幾次??梢郧蹇諒?fù)位重啟次數(shù)。三、效果圖
四、完整代碼#include “frmmain.h”
#include “ui_frmmain.h”
#include “qmessagebox.h”
#include “qfile.h”
#include “qprocess.h”
#include “qdebug.h”
frmMain::frmMain(QWidget *parent) : QWidget(parent), ui(new Ui::frmMain)
{
ui->setupUi(this);
this->initForm();
qDebug() << this->getCpuName() << this->getCpuId() << this->getDiskNum();
}
frmMain::~frmMain()
{
delete ui;
}
void frmMain::initForm()
{
QStringList min;
min << “1” << “5” << “10” << “20” << “30”;
for (int i = 1; i <= 24; i++) {
min << QString::number(i * 60);
}
ui->cboxMin->addItems(min);
ui->cboxMin->setCurrentIndex(1);
ui->dateEdit->setDate(QDate::currentDate());
for (int i = 5; i <= 150; i = i + 5) {
ui->cboxCount->addItem(QString(“%1″).arg(i));
}
}
QString frmMain::getWMIC(const QString &cmd)
{
//獲取cpu名稱:wmic cpu get Name
//獲取cpu核心數(shù):wmic cpu get NumberOfCores
//獲取cpu線程數(shù):wmic cpu get NumberOfLogicalProcessors
//查詢cpu序列號:wmic cpu get processorid
//查詢主板序列號:wmic baseboard get serialnumber
//查詢BIOS序列號:wmic bios get serialnumber
//查看硬盤:wmic diskdrive get serialnumber
QProcess p;
p.start(cmd);
p.waitForFinished();
QString result = QString::fromLocal8Bit(p.readAllStandardOutput());
QStringList list = cmd.split(” “);
result = result.remove(list.last(), Qt::CaseInsensitive);
result = result.replace(“r”, “”);
result = result.replace(“n”, “”);
result = result.simplified();
return result;
}
QString frmMain::getCpuName()
{
return getWMIC(“wmic cpu get name”);
}
QString frmMain::getCpuId()
{
return getWMIC(“wmic cpu get processorid”);
}
QString frmMain::getDiskNum()
{
return getWMIC(“wmic diskdrive where index=0 get serialnumber”);
}
QString frmMain::getXorEncryptDecrypt(const QString &data, char key)
{
//采用異或加密,也可以自行更改算法
QByteArray buffer = data.toLatin1();
int size = buffer.size();
for (int i = 0; i < size; i++) {
buffer[i] = buffer.at(i) ^ key;
}
return QLatin1String(buffer);
}
void frmMain::on_btnOk_clicked()
{
bool useDate = ui->ckDate->isChecked();
bool useRun = ui->ckRun->isChecked();
bool useCount = ui->ckCount->isChecked();
if (!useDate && !useRun && !useCount) {
if (QMessageBox::question(this, “詢問”, “確定要生成沒有任何限制的密鑰嗎?”) != QMessageBox::Yes) {
return;
}
}
QString strDate = ui->dateEdit->date().toString(“yyyy-MM-dd”);
QString strRun = ui->cboxMin->currentText();
QString strCount = ui->cboxCount->currentText();
QString key = QString(“%1|%2|%3|%4|%5|%6”).arg(useDate).arg(strDate).arg(useRun).arg(strRun).arg(useCount).arg(strCount);
QFile file(QApplication::applicationDirPath() + “/key.db”);
file.open(QFile::WriteOnly | QIODevice::Text);
file.write(getXorEncryptDecrypt(key, 110).toLatin1());
file.close();
QMessageBox::information(this, “提示”, “生成密鑰成功,將 key.db 文件拷貝到對應(yīng)目錄即可!”);
}
void frmMain::on_btnClose_clicked()
{
this->close();
}
拓展知識:
原創(chuàng)文章,作者:九賢生活小編,如若轉(zhuǎn)載,請注明出處:http://xiesong.cn/73862.html