菜鸟教程小白 发表于 2022-12-13 13:07:25

ios - iOS 上的 SQLite + SQLCipher + FMDatabase


                                            <p><p>我目前在我的 iOS 应用程序中使用 FMDatabase,我对此非常满意。
我打算用 SQLCipher 加密 sqlite 数据库。</p>

<p>这是我的问题:</p>

<p>1) FMDatabase 和 SQLCipher 是否兼容?我想我只需要在 FMDatabase 中添加一个名为 openEncrypted 的新方法……然后为 SQLCipher 完成这项工作。我希望所有 FMDatabase 方法都能正常工作。</p>

<p>2) 实际上,我的应用中有 2 个数据库。然后我在我的应用程序中做一个 ATTACH DATABASE 来加入他们。我只想加密两者之一。它会起作用还是我需要加密 2 个数据库? (一个很关键,另一个不是)</p>

<p>3) 如果我加密这些文件,我真的不明白我必须向 Apple 提供什么(文档)。</p>

<p>谢谢!</p></p>
                                    <br><hr><h1><strong>Best Answer-推荐答案</ strong></h1><br>
                                            <p><p>对于那些正在寻找有关如何完成此操作的简单教程的人,我能够创建一个:<a href="http://www.guilmo.com/fmdb-with-sqlcipher-tutorial/" rel="noreferrer noopener nofollow">http://www.guilmo.com/fmdb-with-sqlcipher-tutorial/</a> </p>

<p>但最重要的部分是,打开您现有的数据库并附加一个新的加密数据库。然后在您的 FMDB 连接中设置 key 。</p>

<p><strong>SQLCipher - 加密数据库</strong></p>

<pre><code>// Import sqlite3.h in your AppDelegate
#import &lt;sqlite3.h&gt;

// Set the new encrypted database path to be in the Documents Folder
NSArray *documentPaths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
NSString *documentDir = ;
NSString *ecDB = ;

// SQL Query. NOTE THAT DATABASE IS THE FULL PATH NOT ONLY THE NAME
const char* sqlQ = [ UTF8String];

sqlite3 *unencrypted_DB;   
if (sqlite3_open(, &amp;unencrypted_DB) == SQLITE_OK) {

    // Attach empty encrypted database to unencrypted database
    sqlite3_exec(unencrypted_DB, sqlQ, NULL, NULL, NULL);

    // export database
    sqlite3_exec(unencrypted_DB, &#34;SELECT sqlcipher_export(&#39;encrypted&#39;);&#34;, NULL, NULL, NULL);

    // Detach encrypted database
    sqlite3_exec(unencrypted_DB, &#34;DETACH DATABASE encrypted;&#34;, NULL, NULL, NULL);

    sqlite3_close(unencrypted_DB);
}
else {
    sqlite3_close(unencrypted_DB);
    NSAssert1(NO, @&#34;Failed to open database with message &#39;%s&#39;.&#34;, sqlite3_errmsg(unencrypted_DB));
}

self.databasePath = ;
</code></pre>

<p>请注意,我们在 SQL Query 中设置了 2 个参数,DATABASE 和 KEY。 DATABASE 应该是您要创建的加密数据库的<strong>完整路径</strong>,在本例中为字符串 ecDB,KEY 参数是用于加密您的数据库的 key ,因此请选择强者</p>

<p>现在在您的 FMDB 函数上,每次打开数据库后调用 <strong></strong>。</p>

<pre><code>// FMDatabase Example
FMDatabase *db = ];
;
;


// FMDatabaseQueue Exmple
FMDatabaseQueue *queue = ];

[queue inDatabase:^(FMDatabase *db) {
    ;
    ...
}];
</code></pre>

<p>如果您有任何问题,请告诉我!</p></p>
                                   
                                                <p style="font-size: 20px;">关于ios - iOS 上的 SQLite &#43; SQLCipher &#43; FMDatabase,我们在Stack Overflow上找到一个类似的问题:
                                                        <a href="https://stackoverflow.com/questions/10106565/" rel="noreferrer noopener nofollow" style="color: red;">
                                                                https://stackoverflow.com/questions/10106565/
                                                        </a>
                                                </p>
                                       
页: [1]
查看完整版本: ios - iOS 上的 SQLite &#43; SQLCipher &#43; FMDatabase