将XML简单地加解密的办法(代码)

base64 编码,可以编n次,代价是占用空间增大
  XMLDocument1->LoadFromFile("原文.xml");
  XMLDocument1->Active = true;
  AnsiString  s = EncodeString(XMLDocument1->XML);
  XMLDocument1->ChildNodes->Clear();
  _di_IXMLNode node = XMLDocument1->AddChild("Text");
  node->Text = s;
  XMLDocument1->SaveToFile("加密.xml");

#include <encddecd.hpp>
// 解密
  XMLDocument1->LoadFromFile("加密.xml");
  XMLDocument1->Active = true;
  AnsiString  s = DecodeString(XMLDocument1->DocumentElement->Text);
  XMLDocument1->ChildNodes->Clear();
  XMLDocument1->XML->Text = s;
  XMLDocument1->SaveToFile("原文.xml");

试了一下,可以用。有几处错误,一起修正。

1:
      AnsiString  s = EncodeString(XMLDocument1->XML);
改为: AnsiString  s = EncodeString(XMLDocument1->XML->Text);

2:
  XMLDocument1->XML->Text = s;
// 中间加一行 XMLDocument1->Active = true;
  XMLDocument1->SaveToFile("原文.xml");

解密纠正:
XMLDocument1->LoadFromFile("加密.xml");
 XMLDocument1->Active = true;
 AnsiString  s = DecodeString(XMLDocument1->DocumentElement->ChildNodes->Nodes[WideString("Text")]->Text);

  XMLDocument1->DocumentElement->ChildNodes->Clear();
  XMLDocument1->XML->Text = s;
  XMLDocument1->Active = true;
  XMLDocument1->SaveToFile("原文.xml");

 AnsiString  s = DecodeString(XMLDocument1->DocumentElement->ChildNodes->Nodes[WideString("Text")]->Text);

等同于

AnsiString  s = DecodeString(XMLDocument1->DocumentElement->Text);

只要能保证XMLDocument1->DocumentElement是你放密文的节点即可,
至于其什么名,自己定。

只要把原来可读的XML文件,变成别人看不懂,就已经达到了你的目的。

//注释此行即可。直接访问XMLDocument1,达到目的(在内存里解密,读取xml)。
//XMLDocument1->SaveToFile("原文.xml");

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
xml加密XML Encryption)是w3c加密xml的标准。这个加密过程包括加密xml文档的元素及其子元素,通过加密xml的初始内容将被替换,但其xml格式仍然被完好的保留。 介绍 我们有3个加密xml的方法 1、仅仅使用对称加密的方法加密xml 这种加密方法只使用一个密钥,也就是说无论是加密xml还是解密xml都使用一个相同的密钥。因为这个密钥不会在被加密xml中保存,所以我们需要在加密解密的过程中加载这个密钥并保护它不被窃取。 2、使用对称加密和非对称加密相结合的方法来加密xml 这种方法需要一个用于加密数据的对称密钥和一个用于保护这个对称密钥的非对称密钥。被加密的对称密钥和被加密的数据一起保存在xml文档中。当用私有非对称密钥解密密钥的时候要用公开非对称密钥对密钥进行加密。 本文就将使用这种方法。想学到其他更多的方法请参看MSDN等到更多的信息。 (译者注:非对称加密算法需要两个密钥:公开密钥(publickey)和私有密钥(privatekey)。公开密钥与私有密钥是一对,如果用公开密钥对数据进行加密,只有用对应的私有密钥才能解密;如果用私有密钥对数据进行加密,那么只有用对应的公开密钥才能解密。因为加密解密使用的是两个不同的密钥,所以这种算法叫作非对称加密算法。) 3、使用X.509加密xml,这种方法是用X.509作为非对称密钥,它由诸如VeriSign之类的第三方提供。 方法 不管xml加密是如何完成的,保存加密数据总是用两种方法之一。 1、加密后所有的元素都被命名为 2、加密后只有数据被替换,而元素名称仍然是可读的,不会发生变化。
1、DES(Data Encryption Standard):对称算法,数据加密标准,速度较快,适用于加密大量数据的场合; 2、3DES(Triple DES):是基于DES的对称算法,对一块数据用三个不同的密钥进行三次加密,强度更高; 3、RC2和RC4:对称算法,用变长密钥对大量数据进行加密,比 DES 快; 4、IDEA(International Data Encryption Algorithm)国际数据加密算法,使用 128 位密钥提供非常强的安全性; 5、RSA:由 RSA 公司发明,是一个支持变长密钥的公共密钥算法,需要加密的文件块的长度也是可变的,非对称算法; 6、DSA(Digital Signature Algorithm):数字签名算法,是一种标准的 DSS(数字签名标准),严格来说不算加密算法; 7、AES(Advanced Encryption Standard):高级加密标准,对称算法,是下一代的加密算法标准,速度快,安全级别高,在21世纪AES 标准的一个实现是 Rijndael 算法; 8、BLOWFISH,它使用变长的密钥,长度可达448位,运行速度很快; 9、MD5:严格来说不算加密算法,只能说是摘要算法; 10、PKCS:The Public-Key Cryptography Standards (PKCS)是由美国RSA数据安全公司及其合作伙伴制定的一组公钥密码学标准,其中包括证书申请、证书更新、证书作废表发布、扩展证书内容以及数字签名、数字信封的格式等方面的一系列相关协议。 11、SSF33,SSF28,SCB2(SM1):国家密码局的隐蔽不公开的商用算法,在国内民用和商用的,除这些都不容许使用外,其他的都可以使用; 12、ECC(Elliptic Curves Cryptography):椭圆曲线密码编码学。 13、TEA(Tiny Encryption Algorithm)简单高效的加密算法,加密解密速度快,实现简单等等等等
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值