2016-11-18 5 views
0

Так что я боролся с этим дольше, чем я должен отслеживать.Невозможно получить/использовать проанализированные элементы в пользовательском классе для использования в других классах

Я проанализировал элементы, которые мне нужны, но я не могу понять, как звонить на другие классы. Вот пользовательский класс, который я написал.

class SoapTipParser: NSObject, XMLParserDelegate, NSURLConnectionDelegate { 

    var webData:NSMutableData = NSMutableData() 
    var parser:XMLParser? 
    var flag: Bool? 
    var capturedString: String? 
    var conteudos: [LoginCentralResponse?]? //tips 
    var elementos: LoginCentralResponse? //tip 
    var delegate: SoapTipParserDelegate? 



    func processXmlResponse(data :NSData) { 
     parser = XMLParser(data: webData as Data) 
     parser!.delegate = self 
     parser!.parse() 

    } 

    func loginCentral() { 
     //Envelope com o request 
     var soapMessage = "<soapenv:Envelope xmlns:xsi='http://www.w3.org/2001/XMLSchema-instance' xmlns:xsd='http://www.w3.org/2001/XMLSchema' xmlns:soapenv='http://schemas.xmlsoap.org/soap/envelope/' xmlns:log='LoginCentral'><soapenv:Header/><soapenv:Body><log:LoginCentral soapenv:encodingStyle='http://schemas.xmlsoap.org/soap/encoding/'><Autenticacao xsi:type='urn:Autenticacao' xmlns:urn='urn:RouterBoxMobile'><ChaveIntegracao xsi:type='xsd:string'>sL8xlbkw2454kLx3i832190461000160Lxd5yV055sKc3gHx9346</ChaveIntegracao></Autenticacao><DadosLoginCentral xsi:type='urn:DadosLoginCentral' xmlns:urn='urn:RouterBoxMobile'><Usuario xsi:type='xsd:string'>wagner</Usuario><Senha xsi:type='xsd:string'>mudar123</Senha></DadosLoginCentral></log:LoginCentral></soapenv:Body></soapenv:Envelope>" 


     //link como string 
     let urlString = "https://desenvtest.routerbox.com.br/routerbox/ws_mobile/rbx_server_mobile.php?wsdl" 

     let url = NSURL (string: urlString) 

     //Pega, parsea, e le 
     let theRequest = NSMutableURLRequest(url: url! as URL) 

     let countElements = soapMessage.characters.count 

     theRequest.addValue("text/xml", forHTTPHeaderField: "Content-Type") 
     theRequest.addValue(String(countElements), forHTTPHeaderField: "Content_length") 
     theRequest.httpMethod = "POST" 
     theRequest.httpBody = soapMessage.data(using: String.Encoding.utf8, allowLossyConversion: false) 

     let urlConnection = NSURLConnection(request: theRequest as URLRequest, delegate: self, startImmediately: true) 
     urlConnection!.start() 

     if (urlConnection != nil) { 
      var webData : Void = NSMutableData.initialize() 

     } 

    } 

    func connection(_ connection: NSURLConnection, didFailWithError error: Error) { 


    } 


    func connection(_ connection: NSURLConnection, didReceiveResponse response: URLResponse) { 
     webData.length = 0; 

    } 

    func connection(_ connection: NSURLConnection, didReceiveData data: Data) { 
     webData.append(data as Data) 

    } 

    func connectionDidFinishLoading(_ connection: NSURLConnection) { 
     var xmlStr = NSString(data: webData as Data, encoding: String.Encoding.utf8.rawValue) 
     print(xmlStr) 
     processXmlResponse(data: webData) 
    } 

    //XML Parser 
    func parserDidStartDocument(_ parser: XMLParser) { 
     flag = false 
     capturedString = "" 
     conteudos = [] 

    } 
    func parserDidEndDocument(_ parser: XMLParser) { 

     print("count of tips is \(conteudos!.count)") 

     for (index, conteudo1) in (conteudos?.enumerated())! { 
      print("CodigoCliente e: \(conteudo1?.CodigoCliente)") 
      print("Permissoes são: \(conteudo1?.Permissoes)") 

     } 


    } 

    func parser(_ parser: XMLParser, didStartElement elementName: String, namespaceURI: String?, qualifiedName qName: String?, attributes attributeDict: [String : String] = [:]) { 
     flag = false 
     capturedString = "" 



     if elementName == "CodigoCliente" { 
      flag = true 
     } 
     if elementName == "Permissoes" { 
      flag = true 
     } 
     //print("a") 
    } 

    func parser(_ parser: XMLParser, didEndElement elementName: String, namespaceURI: String?, qualifiedName qName: String?) { 

     flag = false 


     if elementName == "CodigoCliente" { 
      elementos?.CodigoCliente = capturedString 
     } 
     if elementName == "Permissoes" { 
      elementos?.Permissoes = capturedString 
     } 

     //print("ak") 
    } 

    func parser(_ parser: XMLParser, foundCharacters string: String) { 

     if flag! { 
      capturedString = capturedString! + string 
     } 
     //print("akii") 
    } 

    func parser(_ parser: XMLParser, parseErrorOccurred parseError: Error) { 

    } 

} 

Но каждый раз, когда я пытаюсь вызвать разобранные элементы на следующем классе, я получаю нулевые результаты.

+0

Я не понимаю, что это ваша проблема именно? Как вы используете этот класс, я имею в виду, можете ли вы дать код вызова? – OliverM

+0

'var tipParser: SoapTipParser? override func viewDidLoad() { super.viewDidLoad() // Выполняйте любую дополнительную настройку после загрузки представления. tipParser = SoapTipParser() tipParser! .loginCentral() } ' –

+0

И вы тянуть результат? tipParser.elementos следует заполнять после разбора? Или это проблема, что нет данных? – OliverM

ответ

0

Хорошо, я думаю, что я получил его, вы ни разу не инициализирует elementos, так что эти две линии

elementos?.CodigoCliente = capturedString 
elementos?.Permissoes = capturedString 

оба пытаются установить на ноль объекта. Так что ничего не происходит. Вы должны инициализировать свойство elementos, и он должен работать.

Например при определении:

var elementos = LoginCentralResponse() 

(если есть такой инициализатор.)