OWASP 類別: MASVS-PLATFORM:平台互動
總覽
如果廣播接收器實作不當,攻擊者就能傳送惡意意圖,讓有安全漏洞的應用程式執行不應由外部呼叫者執行的動作。
這類安全漏洞通常是指廣播接收器遭到意外匯出,可能是因為在 AndroidManifest 中設定 android:exported="true",或是以程式輔助方式建立廣播接收器,導致接收器預設為公開。如果接收器不含任何意圖篩選器,預設值為 "false";但如果接收器至少含有一項意圖篩選器,android:exported 的預設值為 "true"。
如果開發人員不希望所有應用程式呼叫廣播接收器,但卻刻意匯出,且未適當控管存取權,就可能遭到濫用。
影響
如果廣播接收器實作方式不安全,攻擊者可能會濫用這些接收器,未經授權存取應用程式,並執行開發人員不希望向第三方公開的行為。
因應措施
完全避免這個問題
如要徹底解決這個兩難問題,請將 exported 設為 false:
<receiver android:name=".MyReceiver" android:exported="false">
<intent-filter>
<action android:name="com.example.myapp.MY_ACTION" />
</intent-filter>
</receiver>
使用呼叫和回呼
如果您使用廣播接收器是為了應用程式內部用途 (例如事件完成通知),可以重新架構程式碼,改為傳遞事件完成後會觸發的回呼。
事件完成監聽器
Kotlin
interface EventCompletionListener {
fun onEventComplete(data: String)
}
Java
public interface EventCompletionListener {
public void onEventComplete(String data);
}
安全工作
Kotlin
class SecureTask(private val listener: EventCompletionListener?) {
fun executeTask() {
// Do some work...
// Notify that the event is complete
listener?.onEventComplete("Some secure data")
}
}
Java
public class SecureTask {
final private EventCompletionListener listener;
public SecureTask(EventCompletionListener listener) {
this.listener = listener;
}
public void executeTask() {
// Do some work...
// Notify that the event is complete
if (listener != null) {
listener.onEventComplete("Some secure data");
}
}
}
主要活動
Kotlin
class MainActivity : AppCompatActivity(), EventCompletionListener {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
val secureTask = SecureTask(this)
secureTask.executeTask()
}
override fun onEventComplete(data: String) {
// Handle event completion securely
// ...
}
}
Java
public class MainActivity extends AppCompatActivity implements EventCompletionListener {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
SecureTask secureTask = new SecureTask(this);
secureTask.executeTask();
}
@Override
public void onEventComplete(String data) {
// Handle event completion securely
// ...
}
}
使用權限保護廣播接收器
請只為受保護的廣播 (只有系統層級的應用程式可以傳送的廣播) 或自行宣告的簽章層級權限註冊動態接收器。