0

用户登录后,我的重定向出现问题。我正在使用 mmdrawer,所以我需要启动它,以便左右菜单显示在下一页上,用户也应该被重定向。然而什么都没有发生。早些时候,我有一个解决方案重定向成员但破坏了应用程序,因此它崩溃了。我正在使用以下代码尝试重定向用户并启动重定向。当我在其他视图控制器上将它用作 ibaction 中的代码时,它可以工作,并且它可以正常工作。

var centerViewController = self.storyboard?.instantiateViewControllerWithIdentifier("Memberarea") as! userOverview

var centerNavController = UINavigationController(rootViewController: centerViewController)

var appDelegate:AppDelegate = UIApplication.sharedApplication().delegate as! AppDelegate

appDelegate.centerContainer!.centerViewController = centerNavController

它正常工作,但不在我下面使用的代码中。我在下面的代码中使用它。

import UIKit

class LoginPage: UIViewController, UITextFieldDelegate {

    @IBOutlet weak var txtUsername: UITextField!
    @IBOutlet weak var txtPassword: UITextField!

    override func viewDidLoad() {
        super.viewDidLoad()
    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
    }

    @IBAction func signinTapped(sender: UIButton) {

        var username:NSString = txtUsername.text
        var password:NSString = txtPassword.text
        var database:NSString = "bfdlogin" as NSString

        if ( username.isEqualToString("") || password.isEqualToString("") ) {
            var alertView:UIAlertView = UIAlertView()
            alertView.title = "Sign in Failed!"
            alertView.message = "Please enter Username and Password"
            alertView.delegate = self
            alertView.addButtonWithTitle("OK")
            alertView.show()
        } else {

            var post:NSString = "username=\(username)&password=\(password)&database=\(database)"

            NSLog("PostData: %@",post);

            var url:NSURL = NSURL(string: "xxxxxxxxx")!

            var postData:NSData = post.dataUsingEncoding(NSASCIIStringEncoding)!

            var postLength:NSString = String( postData.length )

            var request:NSMutableURLRequest = NSMutableURLRequest(URL: url)
            request.HTTPMethod = "POST"
            request.HTTPBody = postData
            request.setValue(postLength as String, forHTTPHeaderField: "Content-Length")
            request.setValue("application/x-www-form-urlencoded", forHTTPHeaderField: "Content-Type")
            request.setValue("application/json", forHTTPHeaderField: "Accept")

            var reponseError: NSError?
            var response: NSURLResponse?

            var urlData: NSData? = NSURLConnection.sendSynchronousRequest(request, returningResponse:&response, error:&reponseError)

            if ( urlData != nil ) {
                let res = response as! NSHTTPURLResponse!;

                NSLog("Response code: %ld", res.statusCode);

                if (res.statusCode >= 200 && res.statusCode < 300)
                {
                    var responseData:NSString  = NSString(data:urlData!, encoding:NSUTF8StringEncoding)!

                    NSLog("Response ==> %@", responseData);

                    var error: NSError?

                    let jsonData:NSDictionary = NSJSONSerialization.JSONObjectWithData(urlData!, options:NSJSONReadingOptions.MutableContainers , error: &error) as! NSDictionary

                    let success:NSInteger = jsonData.valueForKey("success") as! NSInteger

                    //[jsonData[@"success"] integerValue];

                    NSLog("Success: %ld", success);

                    if(success == 1)
                    {
                        NSLog("Login SUCCESS");

                        var prefs:NSUserDefaults = NSUserDefaults.standardUserDefaults()
                        prefs.setObject(username, forKey: "USERNAME")
                        prefs.setInteger(1, forKey: "ISLOGGEDIN")
                        prefs.synchronize()

                        var alertView:UIAlertView = UIAlertView()
                        alertView.title = "Aanmelden  Succesvol"
                        alertView.message = "Klik ok om verder te gaan"
                        alertView.delegate = self
                        alertView.addButtonWithTitle("OK")
                        alertView.show()

                        var centerViewController = self.storyboard?.instantiateViewControllerWithIdentifier("Memberarea") as! userOverview

                        var centerNavController = UINavigationController(rootViewController: centerViewController)

                        var appDelegate:AppDelegate = UIApplication.sharedApplication().delegate as! AppDelegate

                        appDelegate.centerContainer!.centerViewController = centerNavController
                    } else {
                        var error_msg:NSString

                        if jsonData["error_message"] as? NSString != nil {
                            error_msg = jsonData["error_message"] as! NSString
                        } else {
                            error_msg = "Unknown Error"
                        }
                        var alertView:UIAlertView = UIAlertView()
                        alertView.title = "Sign in Failed!"
                        alertView.message = error_msg as String
                        alertView.delegate = self
                        alertView.addButtonWithTitle("OK")
                        alertView.show()

                    }

                } else {
                    var alertView:UIAlertView = UIAlertView()
                    alertView.title = "Sign in Failed!"
                    alertView.message = "Connection Failed"
                    alertView.delegate = self
                    alertView.addButtonWithTitle("OK")
                    alertView.show()
                }
            } else {
                var alertView:UIAlertView = UIAlertView()
                alertView.title = "Sign in Failed!"
                alertView.message = "Connection Failure"
                if let error = reponseError {
                    alertView.message = (error.localizedDescription)
                }
                alertView.delegate = self
                alertView.addButtonWithTitle("OK")
                alertView.show()
            }
        }
    }


    //function to hide the keyboard when tapping outside a text field

    func textFieldShouldReturn(textField: UITextField) -> Bool {
        textField.resignFirstResponder()

        return true;
    }

    //hide keyboard when tapping outside a field

    override func touchesBegan(touches: Set<NSObject>, withEvent event: UIEvent?) {
        self.view.endEditing(true)
    }
}

我不知道出了什么问题以及为什么它不想启动重定向。我在我的 appdelegate 中拥有的 mmdrawer 的较大版本的旧代码会重定向但会使应用程序崩溃。我该如何解决这个问题。我还是很新的斯威夫特。

谢谢。

4

0 回答 0