Allowing WKWebView to open new windows automatically via WKPreferences.javaScriptCanOpenWindowsAutomatically = true violates least-privilege and can enable abusive pop-ups, phishing flows, and other unwanted navigation. Unless there’s a clear, justified need, keep this disabled to reduce attack surface and improve user trust. If opening windows is required, gate it behind explicit user gestures and tight navigation policies (e.g., allowlists, WKNavigationDelegate) to contain risk.
importWebKit// Create a preferences object for the webview.letwebPreferences=WKPreferences()// COMPLIANT: Explicitly disable the ability for JavaScript to open windows// automatically. This prevents pop-ups and other potentially malicious behavior,// adhering to the principle of least privilege.webPreferences.javaScriptCanOpenWindowsAutomatically=false// Create a webview configuration.letwebConfiguration=WKWebViewConfiguration()webConfiguration.preferences=webPreferences// Initialize the WKWebView with the secure configuration.letwebView=WKWebView(frame:.zero,configuration:webConfiguration)print("WKWebView configured securely.")
원활한 통합. Datadog Code Security를 경험해 보세요
Datadog Code Security
이 규칙을 사용해 Datadog Code Security로 코드를 분석하세요
규칙 사용 방법
1
2
rulesets:- swift-security # Rules to enforce Swift security.
리포지토리 루트에 위의 내용을 포함하는 static-analysis.datadog.yml을 만듭니다
무료 IDE 플러그인을 사용하거나 CI 파이프라인에 Code Security 검사를 추가합니다