Codeigniter: строка ошибки не может быть проанализирована как XML - PullRequest
0 голосов
/ 25 сентября 2018

Я пытаюсь интегрировать платежный шлюз, который я нашел на GitHub.Я следовал инструкциям по его установке.Когда я запускаю сайт, я получаю сообщение об ошибке.В нем говорится:

Обнаружено неперехваченное исключение Тип: Сообщение об исключении: Строка не может быть проанализирована как имя файла XML: / Applications / XAMPP / xamppfiles / htdocs / application / library /Nab_library.php

Я скачал zip-файл с gitHub и установил его.

class nab_library {
    private $merchant_id;
    private $password;
    private $payment_url;


    public function __construct($params)
    {
        $this->merchant_id = $params['NAB_merchant_id'];
        $this->password = $params['NAB_password'];
        $this->payment_url = $params['NAB_payment_url'];
    }


    public function pay_now($data)
    {
        $nabXml = '<NABTransactMessage>
            <MerchantInfo>
                <merchantID>'.$this->merchant_id.'</merchantID>
                <password>'.$this->password.'</password>
            </MerchantInfo>
            <RequestType>Payment</RequestType>
            <Payment>
                <TxnList count="1">
                    <Txn ID="1">
                        <txnType>0</txnType>
                        <txnSource>23</txnSource>
                        <amount>'.$data['cost'].'</amount>
                        <currency>AUD</currency>
                        <purchaseOrderNo>A'.$data['purchase_id'].'</purchaseOrderNo>
                        <CreditCardInfo>
                            <cardHolderName>test123</cardHolderName>
                            <cardNumber>'.$data['credit_card_no'].'</cardNumber>
                            <cvv>'.$data['security_code'].'</cvv>
                            <expiryDate>'.$data['expiry_month'].'/'.$data['expiry_year'].'</expiryDate>
                        </CreditCardInfo>
                    </Txn>
                </TxnList>
            </Payment>
        </NABTransactMessage>';

        $result = $this->makeCurlCall(
            $this->payment_url, /* CURL URL */
            "POST", /* CURL CALL METHOD */
            array( /* CURL HEADERS */
                /*<?xml version="1.0" encoding="UTF-8" ?>*/
                "Content-Type: text/xml; charset=utf-8",
                "Accept: text/xml",
                "Pragma: no-cache",
                "Content_length: ".strlen(trim($nabXml))
            ),
            null, /* CURL GET PARAMETERS */
            $nabXml /* CURL POST PARAMETERS AS XML */
        );

        $this->payment_process($result);
    }


    private function makeCurlCall($url, $method = "GET", $headers = null, $gets = null, $posts = null) {
        $ch = curl_init();
        if($gets != null)
        {
            $url.="?".(http_build_query($gets));
        }
        curl_setopt($ch, CURLOPT_URL, $url);
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
        curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);

        if($posts != null)
        {
            curl_setopt($ch, CURLOPT_POSTFIELDS, $posts);
        }
        if($method == "POST") {
            curl_setopt($ch, CURLOPT_POST, true);
        } else if($method == "PUT") {
            curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "PUT");
        } else if($method == "HEAD") {
            curl_setopt($ch, CURLOPT_NOBODY, true);
        }
        if($headers != null && is_array($headers))
        {
            curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);
        }
        $response = curl_exec($ch);
        $code = curl_getinfo($ch,CURLINFO_HTTP_CODE);

        curl_close($ch);
        return array(
            "code" => $code,
            "response" => $response
        );
    }

    /** 
    * Processes the result obtained from the NAB API.
    * 
    * @access public 
    * @param array
    */
    private function payment_process($result)
    {
        $response = new SimpleXMLElement($result['response']);
        $simple = simplexml_load_string($result['response']);
        $approved = (string) $simple->Payment->TxnList->Txn->approved;
        $responseCode = (string) $simple->Payment->TxnList->Txn->responseCode;

        //Display result based on response code found in result array.
        if($approved == 'Yes' && ($responseCode == '00' || $responseCode == '08')){
            echo 'Success: Payment has been successfully made.';
        } else {
            if($responseCode == '101') {
                echo 'Error: Invalid Credit Card Number - Payment was not processed';
            } else if($responseCode == '109') {
                echo 'Error: Invalid CVV2/CVC2 - Payment was not processed';
            } else if($responseCode == '51') {
                echo 'Error: Insufficient Funds - Payment was not processed';
            } else {
                echo 'Error: Unkown Error - Payment was not processed';
            }
        }
    }
}

/* End of file nab_library.php */
/* Location: ./application/libraries/nab_library.php */

просмотр файла:

 <?php echo form_open('Pay_now/index'); ?> 
            <table>
                <tr>
                    <td><label>Booking ID: </label></td>
                    <td><input type="text" name="purchase_id" value="PO1234"></td>
                </tr>
                <tr>
                    <td><label>Cost: $</label></td>
                    <td><input type="text" name="cost" value="120.00"></td>
                </tr>
                <tr>
                    <td><label>Credit Card Number: </label></td>
                    <td><input type="text" name="credit_card_no" value="4444333322221111"></td>
                </tr>
                <tr>
                    <td><label>Expiry Date: </label></td>
                    <td><input type="text" name="expiry_month" value="05"><input type="text" name="expiry_year" value="16"></td>
                </tr>
                <tr>
                    <td><label>CVV: </label></td>
                    <td><input type="text" name="security_code" value="123"></td>
                </tr>
                <tr>
                    <td>&nbsp;</td>
                    <td><input type="submit" name="submit" value="Pay"></td>
                </tr>
            </table>
        </form>

и контроллера: pay_now.php

<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed');

class Pay_now extends CI_Controller {

    /**
     * Index Page for this controller.
     *
     * Maps to the following URL
     *      http://example.com/index.php/pay_now
     *  - or -  
     *      http://example.com/index.php/pay_now/index
     *  - or -
     * Since this controller is set as the default controller in 
     * config/routes.php, it's displayed at http://example.com/
     *
     * So any other public methods not prefixed with an underscore will
     * map to /index.php/pay_now/<method_name>
     * @see http://codeigniter.com/user_guide/general/urls.html
     */
    public function index()
    {
        $this->load->library('form_validation');
        $config = array(
                array(
                    'field'   => 'credit_card_no', 
                    'label'   => 'Credit Card Number', 
                    'rules'   => 'required'
                ),
                array(
                    'field'   => 'expiry_month', 
                    'label'   => 'Expiry Month', 
                    'rules'   => 'required'
                ),
                array(
                    'field'   => 'expiry_year', 
                    'label'   => 'Expiry Year', 
                    'rules'   => 'required'
                ),
                array(
                    'field'   => 'security_code', 
                    'label'   => 'CVV', 
                    'rules'   => 'required'
                ),
                array(
                    'field'   => 'purchase_id', 
                    'label'   => 'Purchase Id/Number', 
                    'rules'   => 'required'
                ),
                array(
                    'field'   => 'cost', 
                    'label'   => 'Cost/Amount', 
                    'rules'   => 'required'
                ),
            );

        $this->form_validation->set_rules($config);

        if ($this->form_validation->run() == FALSE)
        {
            $this->load->view('pay_now');
        } else {
            $params = array(
                'NAB_merchant_id'   =>  $this->config->item('NAB_merchant_id'),
                'NAB_password'      =>  $this->config->item('NAB_password'),
                'NAB_payment_url'   =>  $this->config->item('NAB_payment_url'),
            );

            $this->load->library('nab_library', $params);

            $data['credit_card_no'] = $this->input->post('credit_card_no');
            $data['expiry_month'] = $this->input->post('expiry_month');
            $data['expiry_year'] = $this->input->post('expiry_year');
            $data['security_code'] = $this->input->post('security_code');
            $data['cost'] = $this->input->post('cost') * 100;
            $data['purchase_id'] = $this->input->post('purchase_id');

            $this->nab_library->pay_now($data);
        }
    }
}

/* End of file pay_now.php */
/* Location: ./application/controllers/pay_now.php */
...