Skip to main content

How to work with Charles proxy server

In this post, I am going to share a technique which will help you in debugging your mobile application code effortlessly even if your server is down.

To set up the Charles server, follow the below steps:
          ·   Install the free Charles software from https://www.charlesproxy.com/download/
·   Open Charles, go to Tools -> Map local
·   In map local window/popup, click add. Add the relevant details like Host, Port(8080), Path, Query of URL.
·   Under "map to" option:- Select the local JSON file
·   Click done and a popup will look like this: (location will have the URL string, the local path will have the path of JSON file)


·   Now go to Tools - Rewrite
·   In the rewrite popup, Select the "Enable rewrite option" and add the previous URL here
·   Add the following rewrite rule


·   Click ok and apply all the settings.
·   Now run the application in simulator and API's response will be read from given local JSON file.

If you are not able to read the data from local json file, then install the certificates from following path:-

1. Reset your simulator
2. In Charles menu, Help > SSL Proxying, and select Install Charles Root Certificate in iOS Simulators
3. Restart your simulator



Comments

Post a Comment

Popular posts from this blog

Play youtube video in iOS app

Youtube video can be played in iOS app using webview. MPMoviePlayerController is not able to open youtube video automatically. Integrate the below script to show thumbnail, clicking on it the video will play in full screen.


NSString *url = @"https://www.youtube.com/embed/8aMHGC6A5zc"; NSString* embedHTML = @"\     <html><head>\     <style type=\"text/css\">\     body {\     background-color: transparent;\     color: white;\     }\     </style>\     </head><body style=\"margin:0\">\     <iframe id=\"yt\" src=\"%@\" type=\"application/x-shockwave-flash\" \     width=\"%0.0f\" height=\"%0.0f\" frameborder=\"0\" feature=player_detailpage allowfullscreen></iframe>\     </body></html>"; NSString* html = [NSStringstringWithFormat:embedHTML, url, self.view.frame.size.width, 200.0];
    [webviewloadHTMLString:html baseURL:nil];


///*******************A…

Disabling print for Production In Swift Project

You'll need to set up a compiler flag to use the Swift preprocessor - go to the Swift Compiler - Custom Flags section of Build Settings to set up a -D DEBUG flag:



Then in your code you can define a DLog() function and only print your message if the DEBUG flag is set:
func DLog(message: String, function: String = __FUNCTION__) { #if DEBUG     println("\(function): \(message)") #endif }

Collection view inside table view with NO vertical scrolling

UICollectionView inside a UITableViewCell — dynamic height?
Given the following structure: TableViewTableViewCellCollectionViewCollectionViewCellCollectionViewCellCollectionViewCell[...variable number of cells or different cell sizes]
The solution is to tell auto layout to compute first the collectionViewCell sizes, then the collection view contentSize, and use it as the size of your cell. This is the UIView method that "does the magic": -(void)systemLayoutSizeFittingSize:(CGSize)targetSize      withHorizontalFittingPriority:(UILayoutPriority)horizontalFittingPriority            verticalFittingPriority:(UILayoutPriority)verticalFittingPriority






Full code is available here to download.
Thanks to this awesome answer.