calculate MAC,Lisence,Checksum and generate muti-file
/*************************************************************************
* calculate MAC,Lisence,Checksum and generate muti-file
* 声明:
* 1. 以升序的方式批量生成MAC地址方法;
* 2. 以升序、降序的方式批量生成数字形式的Lisence方法;
* 3. 以累加的方式计算MAC地址、Lisence的Checksum;
* 4. 不提供源数据处理文件,仅仅是处理数据代码;
* 5. 本软件主要是为后续软件开发提供更好的解决数据处理的方式。
* 6. 本人并没有对代码进行优化,主要是考虑到保留编写代码过程中的一些细节。
*
* 2015-8-24 晴 深圳 南山平山村 曾剑锋
************************************************************************/
#include <stdio.h>
#include <string.h>
#include <stdlib.h> #define debug #ifdef debug
#define Debug(...) fprintf(stdout,"debug: " __VA_ARGS__);
#else
#define Debug(...)
#endif int htoi( char s[] );
int createDir( const char *sPathName );
int changeLisenceByte( char * lisenceByte, int number );
void calculateNextMacAddress( int mac[], int i );
void calculateNextLisence( char lisence[], int i ); int main ( int argc, char ** argv ) { int i = ;
int ret = ;
int count = ;
int mac[] = {};
char lisence[] = {};
FILE *mtd5OutFile = NULL;
FILE *mtd6OutFile = NULL;
char readBuffer[] = {}; if ( argc != ) { // check arguments number
printf ( " USAGE:\n" );
printf ( " macLis <mac> <lisence> <count>\n" );
printf ( " example:\n" );
printf ( " macLis 11:22:33:44:55:66 20150609622300214 10 \n" );
return -;
} printf ( "mac : %s\n", argv[] );
printf ( "lisence : %s\n", argv[] );
printf ( "count : %s\n", argv[] ); for ( i = ; i < ; i++ ) {
argv[][ ( i + ) * - ] = '\0'; // change ':' to '\0'
mac[i] = htoi ( argv[] + ( i * ) );
}
Debug ( "mac : %2x:%2x:%2x:%2x:%2x:%2x\n", mac[], mac[], mac[], mac[], mac[], mac[] ); memcpy ( lisence, argv[], sizeof(lisence) - );
Debug ( "lisence : %s\n", lisence ); count = atoi ( argv[] ); // how many diretory to generate
Debug ( "count : %d\n", count); FILE *mtd5SourceFile = fopen ( "temp5", "rb" ); // open input file with binary
FILE *mtd6SourceFile = fopen ( "temp6", "rb" ); char dirPath[] = {};
char outMtd5FilePath[] = {};
char outMtd6FilePath[] = {};
char macString[] = {};
long sum = ; for ( i = ; i < count ; i++ ) { sprintf ( dirPath, "%03d", i ); // generator diretory
sprintf ( outMtd5FilePath, "%03d/temp5", i ); // generator temp5 file
sprintf ( outMtd6FilePath, "%03d/temp6", i ); // generator temp6 file createDir( dirPath );
mtd5OutFile = fopen ( outMtd5FilePath, "w+b" ); // open output file with binary
mtd6OutFile = fopen ( outMtd6FilePath, "w+b" ); rewind ( mtd5SourceFile ); // go head
rewind ( mtd6SourceFile ); // copy file content
while ( ret = fread ( readBuffer, , sizeof(readBuffer), mtd5SourceFile ) )
fwrite ( readBuffer, , sizeof(readBuffer), mtd5OutFile ); // copy file content
while ( ret = fread ( readBuffer, , sizeof(readBuffer), mtd6SourceFile ) )
fwrite ( readBuffer, , sizeof(readBuffer), mtd6OutFile ); // generate mac string and write to file
sprintf ( macString, "%c%c%c%c%c%c", mac[], mac[], mac[], mac[], mac[], mac[] );
fseek(mtd5OutFile, (0x670) + , SEEK_SET);
fwrite ( macString, , , mtd5OutFile );
fseek(mtd6OutFile, (0x30) + , SEEK_SET);
fwrite ( macString, , , mtd6OutFile ); // write Lisence number to file
fseek(mtd5OutFile, (0x680) + , SEEK_SET);
fwrite ( lisence, , , mtd5OutFile );
fseek(mtd6OutFile, (0x40) + , SEEK_SET);
fwrite ( lisence, , , mtd6OutFile ); // clear the data has used
bzero ( dirPath, sizeof(dirPath) );
bzero ( outMtd5FilePath, sizeof(outMtd5FilePath) );
bzero ( outMtd6FilePath, sizeof(outMtd5FilePath) ); // change MAC address with increase number 1
calculateNextMacAddress( mac, );
// change lisence with decrease number 1
calculateNextLisence( lisence, - ); /**
* go to calculate checksum
*/ // read check data from file
bzero ( readBuffer, sizeof(readBuffer) );
fseek ( mtd5OutFile, (0x640) + 0x0d, SEEK_SET );
fread ( readBuffer, , *, mtd5OutFile); // add all data as checksum, be carefull to use unsigned char to keep data was byte
int j = ;
sum = ;
for ( j = ; j < ( * ); j++ )
sum += ( unsigned char ) readBuffer[j]; // must type change to keep is positive
char checkSum[] = {};
sprintf ( checkSum, "%04x", sum );
Debug ( " temp5 checkSum: %s\n", checkSum ); // write checksum to file
fseek ( mtd5OutFile, (0x640) + 0x08, SEEK_SET );
fwrite ( &sum, , , mtd5OutFile); bzero ( readBuffer, sizeof(readBuffer) );
bzero ( checkSum, sizeof(checkSum) ); // work way as above
fseek ( mtd6OutFile, (0x000) + 0x09, SEEK_SET );
fread ( readBuffer, , *, mtd6OutFile); sum = ;
for ( j = ; j < ( * ); j++ )
sum += ( unsigned char ) readBuffer[j]; // must type change to keep is positive
sprintf ( checkSum, "%04x", sum );
Debug ( " temp6 checkSum: %s\n", checkSum ); fseek ( mtd6OutFile, (0x000) + 0x04, SEEK_SET );
fwrite ( &sum, , , mtd6OutFile); bzero ( readBuffer, sizeof(readBuffer) ); // flush to file and close
fflush ( mtd5OutFile );
fclose ( mtd5OutFile ); fflush ( mtd6OutFile );
fclose ( mtd6OutFile );
} fclose ( mtd5SourceFile );
fclose ( mtd6SourceFile ); return ;
} int htoi(char s[])
{
int i;
int n = ; // skip "0x" or "0X"
if (s[] == '' && (s[]=='x' || s[]=='X')) {
i = ;
} else {
i = ;
} for (; (s[i] >= '' && s[i] <= '') || (s[i] >= 'a' && s[i] <= 'z') || (s[i] >='A' && s[i] <= 'Z'); ++i) { if (tolower(s[i]) > '') {
n = * n + ( + tolower(s[i]) - 'a');
} else {
n = * n + (tolower(s[i]) - '');
} } return n;
} int createDir(const char *sPathName)
{
char DirName[];
int i;
int len = strlen ( DirName ); strcpy ( DirName, sPathName ); if ( DirName[ len- ] != '/' )
strcat ( DirName, "/" ); len = strlen ( DirName ); for ( i = ; i < len; i++ ) {
if ( DirName[i] == '/' ) {
DirName[i] = ;
if( access ( DirName, NULL ) != ) {
if(mkdir(DirName, )==-) {
perror("mkdir error");
return -;
}
}
DirName[i] = '/';
}
} return ;
} /**
* i: this can only be positive
*/
void calculateNextMacAddress( int mac[], int i ) { int macByte5 = ( i + mac[] ) % ;
int macByte4 = ( ( i + mac[] ) / + mac[] ) % ;
int macByte3 = ( ( ( ( i + mac[] ) / ) + mac[] ) / + mac[] ) % ;
int macByte2 = ( ( ( ( ( i + mac[] ) / ) + mac[] ) / + mac[] ) / + mac[] ) % ;
int macByte1 = ( ( ( ( ( ( i + mac[] ) / ) + mac[] ) / + mac[] ) / + mac[] ) / + mac[] ) % ;
int macByte0 = ( ( ( ( ( ( ( i + mac[] ) / ) + mac[] ) / + mac[] ) / + mac[] ) / + mac[] ) / + mac[] ) % ; mac[] = macByte0;
mac[] = macByte1;
mac[] = macByte2;
mac[] = macByte3;
mac[] = macByte4;
mac[] = macByte5; Debug ( "calculate next Mac : %02x:%02x:%02x:%02x:%02x:%02x\n", macByte0, macByte1, macByte2, macByte3, macByte4, macByte5 );
} void calculateNextLisence( char lisence[], int i ) {
int tmp = ;
tmp = changeLisenceByte( &lisence[], i );
tmp = changeLisenceByte( &lisence[], tmp );
tmp = changeLisenceByte( &lisence[], tmp );
tmp = changeLisenceByte( &lisence[], tmp );
tmp = changeLisenceByte( &lisence[], tmp );
tmp = changeLisenceByte( &lisence[], tmp );
tmp = changeLisenceByte( &lisence[], tmp );
tmp = changeLisenceByte( &lisence[], tmp );
tmp = changeLisenceByte( &lisence[], tmp );
tmp = changeLisenceByte( &lisence[], tmp );
tmp = changeLisenceByte( &lisence[], tmp );
tmp = changeLisenceByte( &lisence[], tmp );
tmp = changeLisenceByte( &lisence[], tmp );
tmp = changeLisenceByte( &lisence[], tmp );
tmp = changeLisenceByte( &lisence[], tmp );
tmp = changeLisenceByte( &lisence[], tmp );
tmp = changeLisenceByte( &lisence[], tmp ); Debug ( "calculate next lisence : %s\n", lisence );
} /**
* number: this can be positive or negative
*/
int changeLisenceByte( char * lisenceByte, int number ) {
int tmp = ;
if ( ( lisenceByte[] - ) + number < ) {
tmp = ( ( lisenceByte[] - ) + number ) / - ;
lisenceByte[] = ( + ( ( lisenceByte[] - ) + number ) % ) + ;
} else {
tmp = ( ( lisenceByte[] - ) + number ) / ;
lisenceByte[] = ( ( lisenceByte[] - ) + number ) % + ;
} return tmp;
}
calculate MAC,Lisence,Checksum and generate muti-file的更多相关文章
- 【MySQL】InnoDB: Error: checksum mismatch in data file 报错
参考:http://www.jb51.net/article/66951.htm 用5.7版本启动原5.5实例后,再用5.5启动出现以下报错 InnoDB: Error: checksum misma ...
- Generate BKS File( Bouncy Castle KeyStore)
echo "Enter BKS output file name : \c" read filename echo "Enter BKS Password : \c&qu ...
- generate eml file
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <HTML> <HEAD ...
- Generate input file for OVITO
using System; using System.Collections.Generic; using System.IO; using System.Linq; using System.Tex ...
- Mac Terminal open app with a file opened
open -a /Applications/Sublime Text.app test.cpp
- Mac OS build caffe2 Error:This file was generated by an older version of protoc which is
问题所在 我们可以发现这个错误跟protobuf的版本有关,因此我们可以执行script/diagnose_protobuf.py 我们可以看到,pip install protobuf 和 brew ...
- Windows平台CUDA开发之前的准备工作
CUDA是NVIDIA的GPU开发工具,眼下在大规模并行计算领域有着广泛应用. windows平台上面的CUDA开发之前.最好去NVIDIA官网查看说明,然后下载对应的driver. ToolKits ...
- How to generate a new dictionary file of mmseg
How to generate a new dictionary file of mmseg 0.Usage about mmseg-node memtioned in github : var mm ...
- IAR EWARM Checksum Technical Note
IELFTOOL Checksum - Basic actions EW targets: ARM, RH850, RX, SH, STM8 EW component: General issues ...
随机推荐
- xss脚本注入后端的防护
1.脚本注入最主要的是不要相信用户输入的任何数据,对数据进行转义 可以使用:org.springframework.web.util.HtmlUtils包中的 HtmlUtils.htmlEscape ...
- STL__容器的分类
1.序列式 vector.deque.list 2.关联式 set.multiset.map.multimap 3. ZC: queue.stack 属于什么类型?序列式? 4. 5.
- js 几个重要的特性
背景: 语法借鉴 java 函数借鉴 scheme 原型继承借鉴 self 正则表达式借鉴 Perl 1.动态语言 函数的定义和调用 形参与实参不需要一致 形参可由 argu ...
- McAfee 与 360使用感受
运维给配的 win 10.4G内存 ,装的 McAfee,每次开机啥事不干内存去了55%, 开齐qq.微信.vscode.浏览器就要冲90%,再多开几个网页电脑就卡得很, 最近,卡死机了.. 然后看了 ...
- Codeforces 285C - Building Permutation
285C - Building Permutation 思路:贪心.因为每个数都不同且不超过n,而且长度也为n,所有排列只能为1 2 3 ......n.所以排好序后与对应元素的差值的绝对值加起来就是 ...
- Java JDK5新特性-泛型
2017-10-30 22:47:11 Java 泛型(generics)是 JDK 5 中引入的一个新特性, 泛型提供了编译时类型安全检测机制,该机制允许程序员在编译时检测到非法的类型. 泛型的本质 ...
- 微信公众号开发之如何一键导出微信所有用户信息到Excel
微信开发交流群:148540125 系列文章参考地址 极速开发微信公众号欢迎留言.转发.打赏 项目源码参考地址 点我点我--欢迎Start 极速开发微信公众号系列文章之如何一键导出微信所有用户信息到E ...
- uva-11426-数论
https://vjudge.net/problem/UVA-11426#author=0 求 SUM{ gcd(i,j) | 1<=i<j<=n}, n<4000001. 令 ...
- C# 中的时间(DataTime)
在做报表或查询的时候,常常会预设一些可选的日期范围,如本周.本月.本年等,利用 C# 内置的DateTime基本上都可以实现这些功能. 当前时间: DateTime dt = DateTime.Now ...
- JavaScript学习总结(八)——JavaScript数组
JavaScript中的Array对象就是数组,首先是一个动态数组,无需预先制定大小,而且是一个像Java中数组.ArrayList.Hashtable等的超强综合体. 一.数组的声明 常规方式声明: ...