【原】就IOS发布app时如何保护文本资源的一个方法

简介:

近期的一个app是本地的,数据源来自于本地的一个.json文件,里面的数据是这个app的灵魂。近期快发布该app了,很担心发布后的.ipa包被竞争者解开然后信息发生泄漏。我的处理策略是:打包的时候放的是一个字符串加密过的json文件,就算别人打开也是乱码。在程序加载时就对该文件进行解码,在沙盒里面生成一个解码后的json文件,在程序退出时删除该临时文件。这样可以保证在不影响现有代码的情况下在一定程度上保护数据。电脑出了点故障,随手用C++在windows下实现了一番,文件先用txt,加密算法先用简单的ascii移位。真正要用的时候同理,加密算法可以用其他优秀的加密算法:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
#include "stdafx.h"
#include <iostream>
#include <fstream>
#include <string>
 
using  namespace   std;
 
#define KEY 1
 
int  _tmain( int  argc, _TCHAR* argv[])
{
     string  oneLineStr;
     ifstream inf;
     inf.open( "ReadMe.txt" );
     ofstream outf;
     outf.open( "encode.txt" );
     ofstream outf_recovery;
     outf_recovery.open( "recovery.txt" );
 
     while  (getline(inf, oneLineStr))
     {
         cout<< "加密前:" <<oneLineStr<<endl;
         size_t length = oneLineStr.size();
         for  (size_t i = 0; i < length; i++)
         {
             oneLineStr[i] = ( char )(oneLineStr[i] + KEY); //ascii码改变
         }
         cout<< "该行加密后:" <<oneLineStr<<endl;
         outf<<oneLineStr<<endl;
     }
     outf.close();
     inf.clear();
     cout<< "开始恢复文件============================" ;
     ifstream inf_encode;
     inf_encode.open( "encode.txt" );
     while  (getline(inf_encode, oneLineStr))
     {
         size_t length = oneLineStr.size();
         for  (size_t i = 0; i < length; i++)
         {
             oneLineStr[i] = ( char )(oneLineStr[i] - KEY); //ascii码改变
         }
         cout<< "解密后:" <<oneLineStr<<endl;
         outf_recovery<<oneLineStr<<endl;
     }
 
     inf.close();
     inf_encode.close();
     outf_recovery.close();
     
     int  tmp = 0;
     cin>>tmp;
     
     return  0;
}

 当然,这种方法有个缺陷,对于非常大的文本文件可能会有点耗时,但是正常情况下几乎感觉不出来。不知道还有没有其他更好的方式保护APP包内的文本以及图片资源呢

本文转自编程小翁博客园博客,原文链接:http://www.cnblogs.com/wengzilin/p/3721713.html,如需转载请自行联系原作者

相关文章
|
2月前
|
API 数据安全/隐私保护 iOS开发
利用uni-app 开发的iOS app 发布到App Store全流程
利用uni-app 开发的iOS app 发布到App Store全流程
108 3
|
2月前
|
移动开发 前端开发 数据安全/隐私保护
iOS发布证书.p12文件无密码解决办法及导出带密码的新.p12文件方法
iOS发布证书.p12文件无密码解决办法及导出带密码的新.p12文件方法
45 0
|
2月前
|
JSON JavaScript 安全
iOS应用程序数据保护:如何保护iOS应用程序中的图片、资源和敏感数据
iOS应用程序数据保护:如何保护iOS应用程序中的图片、资源和敏感数据
26 1
|
2月前
|
iOS开发 开发者
一键制作 iOS 上架 App Store 描述文件教程
一键制作 iOS 上架 App Store 描述文件教程
|
2月前
uni-app 185iOS端兼容处理
uni-app 185iOS端兼容处理
37 1
|
17天前
|
开发框架 前端开发 Android开发
专刊:随着技术进步,未来在线生成App将有更多可能性,为移动应用开发带来便利
【4月更文挑战第27天】在数字化时代,移动App变得不可或缺,而在线生成App的技术正逐渐兴起,为开发者提供快捷创建移动应用的途径。本文探讨了网页到App的转变过程,介绍了WebView嵌入、混合式开发框架和云端打包技术等方法,以及在线生成App的步骤、优势和挑战。虽然存在性能和功能限制,但随着技术进步,未来在线生成App将有更多可能性,为移动应用开发带来便利。
|
2月前
|
Android开发 iOS开发 开发者
App备案-iOS云管理式证书 Distribution Managed 公钥及证书SHA-1指纹的获取方法
App备案-iOS云管理式证书 Distribution Managed 公钥及证书SHA-1指纹的获取方法
150 0
|
7天前
|
Android开发
Android APP 隐藏系统软键盘的方法
Android APP 隐藏系统软键盘的方法
14 0
|
15天前
|
前端开发
【专栏】在 create-react-app 中集成 less/sass 预处理器和 react-css-modules 的方法
【4月更文挑战第29天】本文介绍了在 create-react-app 中集成 less/sass 预处理器和 react-css-modules 的方法。首先,通过 `npm` 安装 less 或 sass 依赖,然后修改 `config-overrides.js` 配置文件以支持 less/sass 编译。接着,详细阐述如何使用 less/sass 编写样式。再者,安装 react-css-modules 并配置 webpack,使能样式模块化。最后,展示了如何结合使用 less/sass 和 react-css-modules,以提升前端开发的效率和代码质量。
|
2月前
|
存储 安全 开发工具
APP安全加固怎么做?加固技术、加固方法、加固方案
APP安全加固怎么做?加固技术、加固方法、加固方案
25 3