Android文件加密与解密实践:Cipher类与注意事项

2 下载量 183 浏览量 更新于2024-08-29 1 收藏 183KB PDF 举报
在Android开发中,保护文件安全是常见的需求,特别是在教育培训机构这类场景下,确保下载的视频和文档只能在特定应用中播放,防止课件外泄。本文介绍了一个针对此类需求的文件加密解密实现方法。 首先,加密流程主要包括以下步骤: 1. **加密方法**:当存储文件时,从输入流中读取文件内容,将其转换为字节数组。开发者可以根据项目需求选择合适的加密算法,比如Android系统自带的javax包中的Cipher类提供了AES(Advanced Encryption Standard)对称加密功能。在这个例子中,使用了CipherUtil工具类来处理加密操作,这使得代码更加模块化。 2. **加密过程**:具体来说,通过Cipher类的实例化和调用其加密方法,对字节数组进行加密处理。这里提到的是以32KB为单位进行加密计算,这样可以提高效率并避免一次性读取大量数据导致内存问题。 3. **文件标识**:为了识别加密文件,作者建议在加密后统一添加特定后缀名,如".cipher"。例如,原本的文件"测试.txt"加密后变为"测试.txt.cipher"。 4. **注意事项**: - 判断加密文件:通过文件后缀名识别加密状态。 - 文件长度一致性:在一次性读取文件加密时,文件长度不会改变,但如果分段加密,加密后的密文长度可能与原文档不同,这时需要确保加密和解密过程中保持长度一致,避免解密时出现问题。 5. **代码实现**:文章提供了一个名为`CustomFileCipherUtil`的自定义工具类,用于封装加密和解密操作,包括加密后缀的定义和加密缓冲区大小的设定。 通过这些步骤,项目实现了对文件内容的有效保护,确保只有授权的应用能够访问和解密文件内容。开发者需要熟悉Android的加密机制,如Cipher类的使用,以及在实际操作中处理好文件长度和加密后文件标识的问题。这对于保障应用的安全性和用户体验至关重要。
2009-03-16 上传
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、加密后只有数据被替换,而元素名称仍然是可读的,不会发生变化。