Biribu
Biribu

Reputation: 3833

NSURLErrorDomain error -999 IOS7

I am experimenting this issue while trying to open a webpage in an ios app. Before ios7 it was working perfect but now we are upgrading our app and this is the only serious problem we have.

About this problem I found that it is produced when a call is made twice. And I think this is what is happening here because if I write a NSLog text in didFailLoadWithError, it shows twice.

I tried ignoring the error but the loading circle is shown ethernally and webpage not loads.

I paste here my code, maybe you can help us or give us a clue.

            #import "WebPoiViewController.h"
            #import "FavoriteManager.h"

            @interface WebPoiViewController ()

            @end

            @implementation WebPoiViewController
            @synthesize webView,urlStr, activityIndicator,title2,poi=_poi,position=_position;


            - (void)viewDidLoad { //We have a NIB file in play here, so I dropped the loadView here.  Just make sure that your loadView is not getting called twice!
                [super viewDidLoad];

                if (self.poi!=nil){
                    self.position = [[FavoriteManager sharedInstance] isPoiInFavoriteList:self.poi];

                    if (self.position==-1){

                        UIButton *button1 = [[UIButton alloc] init];
                        button1.frame=CGRectMake(0,0,30,30);
                        [button1 setBackgroundImage:[UIImage imageNamed: @"Favorites_icon_inactive.png"] forState:UIControlStateNormal];
                        [button1 addTarget:self action:@selector(makeFavorite:) forControlEvents:UIControlEventTouchUpInside];

                        self.navigationItem.rightBarButtonItem = [[UIBarButtonItem alloc]initWithCustomView:button1];


                        //self.navigationItem.rightBarButtonItem= [[UIBarButtonItem alloc]initWithImage:[UIImage imageNamed:@"Favorites_icon_inactive.png"]  style: UIBarButtonItemStylePlain target:self action:@selector(makeFavorite:)];
                    } else {

                        UIButton *button1 = [[UIButton alloc] init];
                        button1.frame=CGRectMake(0,0,30,30);
                        [button1 setBackgroundImage:[UIImage imageNamed: @"Favorites_icon.png"] forState:UIControlStateNormal];
                        [button1 addTarget:self action:@selector(deleteFavorite:) forControlEvents:UIControlEventTouchUpInside];

                        self.navigationItem.rightBarButtonItem = [[UIBarButtonItem alloc]initWithCustomView:button1];
                        //self.navigationItem.rightBarButtonItem= [[UIBarButtonItem alloc]initWithImage:[UIImage imageNamed:@"Favorites_icon.png"]  style: UIBarButtonItemStylePlain target:self action:@selector(deleteFavorite:)];
                    }
                }

                if (nil!=title2&& ![title2 isEqualToString:@""]){
                    self.title=self.title2;
                }
                [self loadView];
            }

            - (IBAction)makeFavorite:(id)sender {
                self.position=[[FavoriteManager sharedInstance] addFavotitePOI:self.poi];
                UIButton *button1 = [[UIButton alloc] init];
                button1.frame=CGRectMake(0,0,30,30);
                [button1 setBackgroundImage:[UIImage imageNamed: @"Favorites_icon.png"] forState:UIControlStateNormal];
                [button1 addTarget:self action:@selector(deleteFavorite:) forControlEvents:UIControlEventTouchUpInside];

                self.navigationItem.rightBarButtonItem = [[UIBarButtonItem alloc]initWithCustomView:button1];

            }

            - (IBAction)deleteFavorite:(id)sender {
                [[FavoriteManager sharedInstance] deleteFavotitePOIat:self.position];
                self.position=-1;
                UIButton *button1 = [[UIButton alloc] init];
                button1.frame=CGRectMake(0,0,30,30);
                [button1 setBackgroundImage:[UIImage imageNamed: @"Favorites_icon_inactive.png"] forState:UIControlStateNormal];
                [button1 addTarget:self action:@selector(makeFavorite:) forControlEvents:UIControlEventTouchUpInside];

                self.navigationItem.rightBarButtonItem = [[UIBarButtonItem alloc]initWithCustomView:button1];

            }

            - (void)loadView {
                UIView *contentView = [[UIView alloc] initWithFrame:[[UIScreen mainScreen] applicationFrame]];
                self.view = contentView;    

                CGRect webFrame = [[UIScreen mainScreen] applicationFrame];
                webFrame.origin.y = 0.0f;
                webView = [[UIWebView alloc] initWithFrame:webFrame];
                webView.backgroundColor = [UIColor blueColor];
                webView.scalesPageToFit = YES;
                webView.autoresizingMask = (UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleHeight);
                webView.delegate = self;

                if([webView respondsToSelector:@selector(scrollView)]){
                    webView.scrollView.bounces = NO; 
                }

                [self.view addSubview: webView];
                if (nil!=self.urlStr && ![urlStr isEqualToString:@""]){
                    NSLog(@"NO ES NIL");
                    //[webView loadRequest:[NSURLRequest requestWithURL:[NSURL URLWithString:self.urlStr]]];

                    [webView loadRequest:[NSURLRequest requestWithURL:[NSURL URLWithString:urlStr]]];
                    activityIndicator = [[UIActivityIndicatorView alloc]initWithActivityIndicatorStyle:UIActivityIndicatorViewStyleGray];
                    activityIndicator.frame = CGRectMake(0.0, 0.0, 40.0, 40.0);
                    //activityIndicator.center = self.view.center;
                    activityIndicator.center = CGPointMake(self.view.frame.size.width/2,self.view.frame.size.height/2);
                    [self.view addSubview: activityIndicator];
                } else{
                    [webView loadHTMLString:@"<html><center><br /><br /><font size=+5>No info<br /><br /></font></center></html>" baseURL:nil];

                }
            }


            #pragma mark WEBVIEW Methods

            - (void)webViewDidStartLoad:(UIWebView *)myWebView
            {
                // starting the load, show the activity indicator in the status bar
                [UIApplication sharedApplication].networkActivityIndicatorVisible = YES;
                [activityIndicator startAnimating];
            }

            - (void)webViewDidFinishLoad:(UIWebView *)myWebView
            {
                // finished loading, hide the activity indicator in the status bar
                [UIApplication sharedApplication].networkActivityIndicatorVisible = NO;
                [activityIndicator stopAnimating];
            }

            - (void)webView:(UIWebView *)myWebView didFailLoadWithError:(NSError *)error
            {
                if([error code] == NSURLErrorCancelled) return; // Ignore this error
                NSLog(@"FAIL");
                // load error, hide the activity indicator in the status bar
                [UIApplication sharedApplication].networkActivityIndicatorVisible = NO;

                // report the error inside the webview
                NSString* errorString = [NSString stringWithFormat:
                                         @"<html><center><br /><br /><font size=+5 color='red'>Error<br /><br />Your request %@</font></center></html>",
                                         error.localizedDescription];
                [webView loadHTMLString:errorString baseURL:nil];
            }

            - (void)didReceiveMemoryWarning{
                [super didReceiveMemoryWarning];
            }

            - (BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation
            {
                return interfaceOrientation != UIInterfaceOrientationPortraitUpsideDown;
            }

            - (BOOL)shouldAutorotate {
                return [self.navigationController shouldAutorotate];
            }

            - (NSUInteger)supportedInterfaceOrientations {
                return [self.navigationController supportedInterfaceOrientations];
            }


            @end

Upvotes: 1

Views: 5324

Answers (1)

Biribu
Biribu

Reputation: 3833

I solved it by myself. I want to share the answer because maybe it helps others with the same problem.

I just added in didFailWithError this code:

    - (void)webView:(UIWebView *)myWebView didFailLoadWithError:(NSError *)error
    {
        if([error code] != NSURLErrorCancelled)  // only goes in if it is not -999
        {
        // load error, hide the activity indicator in the status bar
        [UIApplication sharedApplication].networkActivityIndicatorVisible = NO;

        // report the error inside the webview
        NSString* errorString = [NSString stringWithFormat:
                                 @"<html><center><br /><br /><font size=+5 color='red'>Error<br /><br />Your request %@</font></center></html>",
                                 error.localizedDescription];
        [webView loadHTMLString:errorString baseURL:nil];
        }
        else{
             [webView loadRequest:[NSURLRequest requestWithURL:[NSURL URLWithString:self.urlStr] ]];
        }
    }

Now, if it fail, it tries to repeat the load until it loads. It can be improved by using a counter. Just trying it 5 or 10 times and not more like mine.

Upvotes: 6

Related Questions