How to Obfuscate Dynamically Loaded Symbols in iOS Apps
Learn to Obfuscate Dynamically Loaded Symbols in iOS apps, in mobile CI/CD with a Data-Driven DevSecOps™ build system.
What are Dynamically Loaded Symbols?
Dynamically Loaded Symbols, commonly known as Lazy symbols, are symbols found in iOS binaries (Mach-O format). These symbols are imported from other binaries or dynamically linked libraries, be they from the system or third-party sources, yet they aren’t implemented directly within the binary. Every binary might contain lazy symbols from various libraries. What sets lazy symbols apart is their addressing; Their final address is determined only when the app first tries to use them upon loading. In contrast, all other imported symbols have their addresses resolved during the app’s initial launch, rather than at first use. The responsibility for resolving these imported symbols and identifying their addresses falls to the dyld, the dynamic linker component of iOS.
Why It's Necessary to Obfuscate Dynamically Loaded Symbols?
Obfuscating Dynamically Loaded Symbols is vital, especially in the context of defending against static analysis by reversers. Through static analysis, reversers can meticulously extract detailed information about the symbols an app imports. A particular area of concern is the unveiling of cryptographic functions, such as MD5 or SHA256, that the app might be leveraging from system libraries or third-party sources. By discerning which cryptographic methods are in play, reversers not only gain hints about decrypting secured data but also establish a precise anchor pinpointing where and when these functions come into action. Armed with this insight, they can potentially manipulate the app in real-time, disabling or even altering the intended purpose of these imported functions. Given these significant threats, obfuscation stands as not just a protective measure but an imperative shield, ensuring that the app remains inscrutable, safeguarding its intellectual property, data, and overall functionality from potentially disastrous tampering.
Obfuscate Dynamically Loaded Symbols on iOS apps using Appdome
On Appdome, follow these simple steps to create self-defending iOS Apps that Obfuscate Dynamically Loaded Symbols without an SDK or gateway:
-
Upload the Mobile App to Appdome.
-
Upload an app to Appdome’s Mobile App Security Build System
-
Upload Method: Appdome Console or DEV-API
-
iOS Formats: .ipa
-
Obfuscate Dynamically Loaded Symbols Compatible With: Obj-C, C+, Java, Swift, Flutter, React Native, Unity, Xamarin, Cordova and more
-
-
Build the feature: Obfuscate Dynamically Loaded Symbols.
-
Building Obfuscate Dynamically Loaded Symbols by using Appdome’s DEV-API:
-
Create and name the Fusion Set (security template) that will contain the Obfuscate Dynamically Loaded Symbols feature as shown below:
-
Follow the steps in Sections 2.2.1-2.2.2 of this article, Building the Obfuscate Dynamically Loaded Symbols feature via Appdome Console, to add the Obfuscate Dynamically Loaded Symbols feature to this Fusion Set.
-
Open the Fusion Set Detail Summary by clicking the “...” symbol on the far-right corner of the Fusion Set, as shown in Figure 1 above, and get the Fusion Set ID from the Fusion Set Detail Summary (as shown below):
Figure 2: Fusion Set Detail Summary
Note: Annotating the Fusion Set to identify the protection(s) selected is optional only (not mandatory). -
Follow the instructions below to use the Fusion Set ID inside any standard mobile DevOps or CI/CD toolkit like Bitrise, App Center, Jenkins, Travis, Team City, Cirlce CI or other system:
-
Build an API for the app – for instructions, see the tasks under Appdome API Reference Guide
-
Look for sample APIs in Appdome’s GitHub Repository
-
Figure 1: Fusion Set that will contain the Obfuscate Dynamically Loaded Symbols feature
Note: Naming the Fusion Set to correspond to the protection(s) selected is for illustration purposes only (not required). -
-
Building the Obfuscate Dynamically Loaded Symbols feature via Appdome Console
To build the Obfuscate Dynamically Loaded Symbols protection by using Appdome Console, follow the instructions below.
-
Where: Inside the Appdome Console, go to Build > Security Tab > TOTALCode™ Obfuscation section
-
How: Check whether Binding Obfuscation is toggled On (enabled), otherwise enable it . You can see that the feature Obfuscate Dynamically Loaded Symbols is enabled by default, as shown below.
Figure 3: Obfuscate Dynamically Loaded Symbols option
-
When you enable Binding Obfuscation you'll notice that your Fusion Set you created in step 2.1.1 now bears the icon of the protection category that contains Obfuscate Dynamically Loaded Symbols
Figure 4: Fusion Set that displays the newly added Obfuscate Dynamically Loaded Symbols protection
-
Click Build My App at the bottom of the Build Workflow (shown in Figure 3).
-
Congratulations! The Obfuscate Dynamically Loaded Symbols protection is now added to the mobile app -
-
Certify the Obfuscate Dynamically Loaded Symbols feature in iOS Apps.
After building Obfuscate Dynamically Loaded Symbols, Appdome generates a Certified Secure™ certificate to guarantee that the Obfuscate Dynamically Loaded Symbols protection has been added and is protecting the app. To verify that the Obfuscate Dynamically Loaded Symbols protection has been added to the mobile app, locate the protection in the Certified Secure™ certificate as shown below:
Figure 5: Certified Secure™ certificate
Each Certified Secure™ certificate provides DevOps and DevSecOps organizations the entire workflow summary, audit trail of each build, and proof of protection that Obfuscate Dynamically Loaded Symbols has been added to each iOS app. Certified Secure provides instant and in-line DevSecOps compliance certification that Obfuscate Dynamically Loaded Symbols and other mobile app security features are in each build of the mobile app
Prerequisites to Using Obfuscate Dynamically Loaded Symbols:
To use Appdome’s mobile app security build system to Obfuscate Dynamically Loaded Symbols , you’ll need:
- Appdome account (create a free Appdome account here)
- A license for Obfuscate Dynamically Loaded Symbols
- Mobile App (.ipa For iOS)
- Signing Credentials (see Signing Secure Android apps and Signing Secure iOS apps)
Using Appdome, there are no development or coding prerequisites to build secured iOS Apps by using Obfuscate Dynamically Loaded Symbols. There is no SDK and no library to code or implement in the app and no gateway to deploy in your network. All protections are built into each app and the resulting app is self-defending and self-protecting.
Releasing and Publishing Mobile Apps with Obfuscate Dynamically Loaded Symbols
After successfully securing your app by using Appdome, there are several available options to complete your project, depending on your app lifecycle or workflow. These include:
- Customizing, Configuring & Branding Secure Mobile Apps
- Deploying/Publishing Secure mobile apps to Public or Private app stores
- Releasing Secured Android & iOS Apps built on Appdome.
All apps protected by Appdome are fully compatible with any public app store, including Apple App Store, Google Play, Huawei App Gallery and more.
Related Articles:
- iOS Binding Obfuscation, Anti-Reversing in iOS App
- Binary Code Obfuscation, Anti-Reversing Android & iOS
- Non-Native Code Obfuscation, Anti-Reversing for Android & iOS Frameworks
If you have any questions, please send them our way at support.appdome.com or via the chat window on the Appdome platform.
Thank you!
Thanks for visiting Appdome! Our mission is to secure every app on the planet by making mobile app security easy. We hope we’re living up to the mission with your project.