Search for a command to run...
Le tue app mobili stanno perdendo dati degli utenti. L'87% delle app mobili contiene vulnerabilità ad alto rischio. Violazioni OWASP Mobile Top 10 nel 95% delle app. I rifiuti degli app store costano $50K per settimana di ritardo. Le violazioni dei dati degli utenti costano $4.88M per incidente.
Superficie di Attacco Mobile
Automatizza il tuo workflow di sicurezza mobile, dall'analisi del codice statico alla gestione delle vulnerabilità.
python analyze.py \
--name "mobile-banking-app" \
--owner "fintech-company" \
--output json \
--files ./mobile_files_to_scan.txt \
--config ./config/mobile_config.yaml
Plexalyzer orchestra automaticamente strumenti di sicurezza specifici per dispositivi mobili:
{
"data": [
{
"id": "finding-mobile-001",
"type": "finding",
"attributes": {
"title": "Hardcoded Encryption Key in Mobile App",
"description": "AES encryption key hardcoded in iOS application source code",
"severity": "critical",
"file_path": "src/utils/CryptoManager.swift",
"original_line": 23,
"tool": "checkmarx",
"cve": "CWE-798",
"cvssv3_score": 8.9,
"false_positive": false,
"remediation_notes": "Use iOS Keychain for secure key storage and implement key rotation"
}
}
],
"meta": {
"total_findings": 38,
"critical": 7,
"high": 12,
"medium": 15,
"low": 4
}
}
Protezione completa contro le vulnerabilità di sicurezza mobile
1// ✅ Secure iOS implementation 2import Security3 4func savePasswordSecurely(_ password: String) {5 let keychain = Keychain(service: "com.app.credentials")6 keychain["password"] = password7 print("Password securely saved to Keychain")8}9 10// Using iOS Keychain for secure storage11class SecureLoginManager {12 private let keychain = Keychain(service: "com.app.credentials")13 14 func storeCredentials(username: String, password: String) {15 keychain["username"] = username16 keychain["password"] = password17 UserDefaults.standard.set(true, forKey: "isLoggedIn")18 }19}
1// ❌ Vulnerable iOS implementation2func savePassword(_ password: String) {3 UserDefaults.standard.set(password, forKey: "user_password")4 print("Password saved to UserDefaults")5}6 7// Storing sensitive data in UserDefaults8class LoginManager {9 func storeCredentials(username: String, password: String) {10 UserDefaults.standard.set(username, forKey: "username")11 UserDefaults.standard.set(password, forKey: "password")12 UserDefaults.standard.set(true, forKey: "isLoggedIn")13 }14}
1// ✅ Secure Android implementation2EncryptedSharedPreferences encryptedPrefs = EncryptedSharedPreferences.create(3 "secure_prefs",4 MasterKeys.getOrCreate(MasterKeys.AES256_GCM_SPEC),5 this,6 EncryptedSharedPreferences.PrefKeyEncryptionScheme.AES256_SIV,7 EncryptedSharedPreferences.PrefValueEncryptionScheme.AES256_GCM8);9 10// Storing sensitive data encrypted11SharedPreferences.Editor editor = encryptedPrefs.edit();12editor.putString("credit_card", "4532-1234-5678-9012");13editor.putString("api_key", "sk_live_abc123def456");14editor.putString("user_token", "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9...");15editor.apply();16 17// Reading encrypted data18String creditCard = encryptedPrefs.getString("credit_card", "");
1// ❌ Vulnerable Android implementation2SharedPreferences prefs = getSharedPreferences("app_prefs", MODE_PRIVATE);3SharedPreferences.Editor editor = prefs.edit();4 5// Storing sensitive data in plain text6editor.putString("credit_card", "4532-1234-5678-9012");7editor.putString("ssn", "123-45-6789");8editor.putString("api_key", "sk_live_abc123def456");9editor.putString("user_token", "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9...");10editor.apply();11 12// Reading sensitive data13String creditCard = prefs.getString("credit_card", "");14String apiKey = prefs.getString("api_key", "");
1// ✅ Secure network implementation2val client = OkHttpClient.Builder()3 .certificatePinner(4 CertificatePinner.Builder()5 .add("api.bank.com", "sha256/AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA=")6 .add("api.bank.com", "sha256/BBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBB=")7 .build()8 )9 .build()10 11// Implementing proper certificate validation12class SecureNetworkManager {13 private val certificatePinner = CertificatePinner.Builder()14 .add("*.mybank.com", "sha256/primary-cert-hash")15 .add("*.mybank.com", "sha256/backup-cert-hash")16 .build()17 18 private val client = OkHttpClient.Builder()19 .certificatePinner(certificatePinner)20 .connectTimeout(30, TimeUnit.SECONDS)21 .readTimeout(30, TimeUnit.SECONDS)22 .build()23}
1// ❌ Vulnerable network implementation2val client = OkHttpClient.Builder()3 .hostnameVerifier { _, _ -> true } // Accepts all certificates!4 .build()5 6// Disabling SSL verification completely7val trustAllCerts = arrayOf<TrustManager>(object : X509TrustManager {8 override fun checkClientTrusted(chain: Array<X509Certificate>, authType: String) {}9 override fun checkServerTrusted(chain: Array<X509Certificate>, authType: String) {}10 override fun getAcceptedIssuers(): Array<X509Certificate> = arrayOf()11})12 13val sslContext = SSLContext.getInstance("SSL")14sslContext.init(null, trustAllCerts, SecureRandom())15 16val client = OkHttpClient.Builder()17 .sslSocketFactory(sslContext.socketFactory, trustAllCerts[0] as X509TrustManager)18 .hostnameVerifier { _, _ -> true }19 .build()
Soluzioni di sicurezza specializzate per diversi tipi di applicazioni mobili
Validazione di Sicurezza Mobile Pre-Rilascio
# Complete mobile app security validation before app store submission
python analyze.py \
--name "pre-release-security-scan" \
--repository_id "mobile-banking-v2.1" \
--output sarif \
--branch "release/v2.1" \
--auto
# Generates SARIF output for integration with:
# - Xcode security warnings
# - Android Studio security alerts
# - GitHub Advanced Security
# - App store security compliance reports
Completa validazione della sicurezza dell'app mobile prima della sottomissione all'app store:
{
"data": [
{
"id": "finding-mobile-api-001",
"type": "finding",
"attributes": {
"title": "Insecure Direct Object Reference in User API",
"description": "User can access other users' profiles without authorization",
"severity": "high",
"file_path": "src/api/UserController.js",
"original_line": 89,
"tool": "checkmarx",
"cve": "CWE-639",
"cvssv3_score": 7.5,
"false_positive": false,
"remediation_notes": "Implement proper authorization checks for user profile access"
}
},
{
"id": "finding-mobile-api-002",
"type": "finding",
"attributes": {
"title": "Missing Rate Limiting on Payment Endpoint",
"description": "Payment processing endpoint lacks rate limiting controls",
"severity": "medium",
"file_path": "src/api/PaymentController.js",
"original_line": 156,
"tool": "sonarqube",
"cve": "CWE-770",
"cvssv3_score": 6.5,
"false_positive": false,
"remediation_notes": "Implement rate limiting and transaction throttling on payment endpoints"
}
}
],
"meta": {
"total_findings": 22,
"critical": 3,
"high": 7,
"medium": 9,
"low": 3
}
}
Validazione completa della conformità per app store e regolamenti sulla privacy
# iOS App Store compliance
ios_requirements:
data_protection: "ATS (App Transport Security) enforced"
encryption: "256-bit encryption for sensitive data"
permissions: "Minimal permission principle"
privacy_policy: "Required for data collection"
# Google Play Store compliance
android_requirements:
target_sdk: "API level 33+ required"
encryption: "Android Keystore usage mandatory"
permissions: "Runtime permission model"
security_metadata: "Safety section completion"
Minimizzazione dei dati e consenso
Diritti di privacy dei consumatori della California
Protezione della privacy online dei bambini
Legge brasiliana sulla protezione dei dati
Integrazione senza soluzione di continuità con il tuo flusso di lavoro di sviluppo per una sicurezza mobile continua
# Mobile security pipeline
name: Mobile Security Scan
on:
push:
branches: [ main, develop ]
pull_request:
branches: [ main ]
jobs:
mobile_security:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: Mobile SAST Scan
run: |
curl -X POST "{{ secrets.PLEXICUS_API_URL }}/plexalyzer/receive_plexalyzer_message" \
-H "Authorization: Bearer {{ secrets.PLEXICUS_TOKEN }}" \
-d '{
"request": "create-repo",
"extra_data": {
"repository_name": "{{ github.repository }}",
"platform": "mobile",
"branch": "{{ github.ref_name }}"
}
}'
Scansione automatica su push e pull request
Blocca i deployment con vulnerabilità critiche
Suggerimenti di correzione intelligenti e auto-patching
Validazione e reportistica di conformità automatizzata
Problemi di sicurezza comuni trovati nelle applicazioni mobili in produzione
Test di sicurezza completi attraverso il tuo stack di applicazioni mobili
Test di sicurezza delle app iOS e Android
Valutazione delle vulnerabilità delle API di backend
Revisione del codice statica e dinamica
Sicurezza del database e dell'archiviazione
Trasforma i tuoi costi di sicurezza mobile da spese reattive a investimenti proattivi
Standard e framework di sicurezza delle app mobili completi