文本和二进制转换并加密

写了个文本和二进制互相转换的程序,可以进行简单加密,算法可以说是投机取巧,用了特简单的方法就把汉字和二进制互相转换,程序不大一点,很简单的。

例如转换 :

仍然爱你,我会试着忘记你

11000111 11010011 11000111 10111010 10101111 10101101 11000011 11100010 10100010 10101011 11001101 11010001 10111010 11100000 11001001 11010011 11010110 11000100 11001100 11111011 10111011 11000110 11000011 11100010

代码如下:

#include<iostream>
#include<stdio.h>
#include<string>
#include<stack>
#include<fstream>
#include<sstream>
#include<time.h>
#include<windows.h>
using namespace std;
stack<int> Stransfer(int m);
int f(int n);
int main(void)
{ string s_line,s_word;
    char c,name_in[20],name_out[20];
    short i,j=1,m,n,sum,flag;
clock_t start;
stack<int>st;
cout<<"要做什么呢?/n1,加密 2,解密/n";
    cin>>flag;
getchar();
    start=clock();
   if(flag==1)
   { cout<<"输入加密文件名称:(暂不支持英文名字)/n";
     gets(name_in);
     strcpy(name_out,name_in);
     strcat(name_out,"加密文件.txt");
     ifstream in(name_in);
ofstream out(name_out);
for(;getline(in,s_line);)
{ istringstream sinline(s_line);
   for(;sinline>>s_word;)
   {
     for(i=0;i!=s_word.size();i++)
   {
       m=(int)s_word[i];//此处可以用 putchar(m) 输出当前字符
    m+=256;/转换成汉字可以表示的字符 一个汉字两个字节,分别取之处理
    m=m-j;//简单加密 循环加密
    j++;
    if(j==10)
     j=1;
          st=Stransfer(m);
    while(!st.empty())
    { out<<st.top();
      st.pop();
    }
    out<<' ';
   }
      }
   out<<endl; /输出一个回车符,本段结束
}
   }
   if(flag==2)
   { cout<<"输入解密文件名称:(暂不支持英文名字)/n";
     gets(name_in);
     strcpy(name_out,name_in);
     strcat(name_out,"解密文件.txt");
     ifstream in(name_in);
ofstream out(name_out);
     for(;getline(in,s_line);)
{ istringstream sinline(s_line);
   for(;sinline>>s_word;)
   { sum=0;
       for(i=0;i<s_word.size();i++)
   { n=(s_word[i]-'0')*f(s_word.size()-i-1);
       sum+=n;
   }
        sum=sum+j;/对加密进行还原
   j++;
   if(j==10)
    j=1;
       c=sum;///如果是英文字符,进行转换的时候最高位被去掉,就生成了英文字符
    out<<c;
   }
   out<<endl; /输出一个回车符,本段结束
}
   }
cout<<"/n用时"<<(float)(clock()-start)/CLK_TCK<<"s/n";
system("pause");
return 1;
}
stack<int> Stransfer(int m)
{
stack<int>st;
while(m>=1)
{ st.push(m%2);
    m=m/2;
}
return st;
}
int f(int n)
{ int i;
   int s=1;
for(i=0;i<n;i++)
   s=s*2;
return s;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值