Skip to content
forked from apptestai/ios-vnc

iOS VNC server - Use VNC to connect to your iOS device.

License

Notifications You must be signed in to change notification settings

Karazum/ios-vnc

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

43 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

iOS VNC Server

We've been using this in production for the last 3 years at TestingBot.com TestingBot Users can take control of a real iOS device through our website. They can view the device's screen and send taps/keyboard events to the device.

This project provides a VNC endpoint which streams the device's screen to your VNC client. Any keyboard and mouse events your VNC client sends will be sent to the iOS device. This does not require the device to be jailbroken.

Setup

  • Clone this repository

  • Install dependencies (mac):

    • brew install libimobiledevice
    • brew install libpng
    • brew install libvncserver
    • brew install carthage
  • Install dependecies (linux):

    • sudo apt install libimobiledevice-dev
    • sudo apt install libpng-dev
    • sudo apt install libvncserver-dev
    • sudo apt install libcurl4-openssl-dev
ADDED BY JAKOB
  • clone jsmn into folder ./iOSVNCServer/vendor/:

    • git clone https://github.com/zserge/jsmn.git
    • cd jsmn
    • make
  • Now you can build the project on:

    • cd iOSVNCServer && make build

Dependencies

To control the device, you will need to set up WebdriverAgent This project exposes a couple of endpoints to take control of the device. Once you've set this up correctly (signing and ./Scripts/bootstrap.sh), you can run the WebDriverAgent project to expose the endpoint.

Getting Started

The WebDriverAgent project will output a response ServerURLHere->http://[SOME_IP]:8100<-ServerURLHere These values are required and need to be passed to our iosvncserver, together with the udid of the device:

  • To get the udid: idevice_id -l
  • Start a WebDriverAgent session: curl -X POST -H "Content-Type: application/json" \ -d "{\"desiredCapabilities\":{\"bundleId\":\"com.apple.preferences\"}}" \ [SOME_IP]:8100/session
  • Copy the sessionID from this response and pass it to our VNC server:

You can now run the VNC server: ./iosvncserver -u [udid] -H [SOME-IP] -P 8100 -S [session-id]

Point your favorite VNC client to localhost:5901 and you will be able to take control of the real iOS device.

Resources

About

iOS VNC server - Use VNC to connect to your iOS device.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C 97.0%
  • Makefile 3.0%