native_flutter_proxy
A Flutter plugin to read system proxy settings from native code and apply them in Dart.
Use it to configure HttpOverrides.global with either the system proxy or a custom proxy.
Key features:
- Read system proxy settings on Android and iOS.
- Auto-update when the system proxy changes via
NativeProxyReader.setProxyChangedCallback. - Apply a custom proxy using
CustomProxy/CustomProxyHttpOverride.
Installing
You should add the following to your pubspec.yaml file:
dependencies:
native_flutter_proxy: ^0.3.0
Quick Start
import 'dart:io';
import 'package:flutter/widgets.dart';
import 'package:native_flutter_proxy/native_flutter_proxy.dart';
Future<void> applyProxy(ProxySetting settings) async {
if (!settings.enabled || settings.host == null) {
HttpOverrides.global = null;
return;
}
CustomProxy(ipAddress: settings.host!, port: settings.port).enable();
}
void main() async {
WidgetsFlutterBinding.ensureInitialized();
try {
final settings = await NativeProxyReader.proxySetting;
await applyProxy(settings);
} catch (e) {
print(e);
}
NativeProxyReader.setProxyChangedCallback((settings) async {
await applyProxy(settings);
});
runApp(MyApp());
}
Auto-update on proxy changes
NativeProxyReader.setProxyChangedCallback is invoked whenever the system proxy
changes, so your app can react immediately (including PAC-based proxies on
Android). Register it once at startup and update your overrides there.
Manual proxy (optional)
If you want to force a proxy (e.g. for debugging), you can set it directly:
final proxy = CustomProxy(ipAddress: '127.0.0.1', port: 8888);
proxy.enable();
For a full example, see example/lib/main.dart.
Libraries
- native_flutter_proxy
- This library is used to create a custom proxy for HTTP requests in Flutter.