| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586 | aria2 for Android devices=========================aria2 is a lightweight multi-protocol & multi-source download utilityoperated in command-line. It supports HTTP/HTTPS, FTP, BitTorrent andMetalink.Install-------aria2 is not an ordinary Android Java application. It is a C++ nativeapplication and operates in command-line.  You don't have to 'root'your device to use aria2.  Because aria2 is a command-line program,you need a terminal emulator. First install Android Terminal Emulatorfrom Android Market (or build it from source and install. Seehttps://github.com/jackpal/Android-Terminal-Emulator/).1. Copy aria2c executable to ``/mnt/sdcard`` on your device.2. Run Android Terminal Emulator.3. ``mkdir /data/data/jackpal.androidterm/aria2``4. ``cat /mnt/sdcard/aria2c > /data/data/jackpal.androidterm/aria2/aria2c``5. ``chmod 744 /data/data/jackpal.androidterm/aria2/aria2c``6. Add the following commands to the initial command of Android   Terminal Emulator::       export HOME=/data/data/jackpal.androidterm/aria2; cd $HOME7. Exit Android Terminal Emulator.8. Run Android Terminal Emulator again.9. See whether aria2c actually works by invoking ``./aria2c -v``How to use----------See `the online manual<https://aria2.github.io/manual/en/html/>`_.Notes-----aria2c executable was generated using android-ndk-r14b.The following libraries were statically linked.* openssl 1.0.2o* expat 2.2.5* zlib 1.2.11* c-ares 1.14.0* libssh2 1.8.0Since Android does not have ``/etc/resolv.conf``, c-ares (asynchronousDNS resolver) is disabled by default. But name resolution is sometimesa little bit slow, so I recommend to enable c-ares. You can enable itusing ``--async-dns`` and specify DNS servers using``--async-dns-server`` option, like this::  --async-dns --async-dns-server=`getprop net.dns1`,`getprop net.dns2`Additionally, the CA certificates shipped with Android don't locate inthe same place as those of normal Unix-like systems do, so thisworkaround might be useful to securely download files via HTTPS::   cat /etc/security/cacerts/* | aria2c --ca-certificate=/proc/self/fd/0 $@Because it is tedious to type these long parameters every time you usearia2c, the following wrapper shell script would be handy::    #!/system/bin/sh    cat /etc/security/cacerts/* | \    /data/data/jackpal.androidterm/aria2c \      --ca-certificate=/proc/self/fd/0 \      --async-dns \      --async-dns-server=`getprop net.dns1`,`getprop net.dns2` \      "$@"Please note that you need to add executable file mode bit to thiswrapper script too. (e.g., ``chmod 744 /PATH/TO/SCRIPT``)Known Issues------------* Since Android does not have ``/dev/stdout``, ``-l-`` does not work.  ``/proc/self/fd/0`` is a workaround for Android.* Android Terminal Emulator sometimes stops updating console. It looks  like aria2c hangs, but aria2c continues to run.
 |