1

我正在使用Codeigniter-restserverPhonegap中的移动应用程序开发 REST API 。

由于Phonegapindex.html使用加载file://,我的 API 应该支持CORS。我是这个CORS的新手。

我已经设置了标题libraries/REST_Controller.php

header("Access-Control-Allow-Origin: *");
header('Access-Control-Allow-Headers:Origin, X-Requested-With, Content-Type, Accept');

我正在使用Backbone.js

这是我的控制器

// This can be removed if you use __autoload() in config.php OR use Modular Extensions
require APPPATH.'/libraries/REST_Controller.php';

class Prop extends REST_Controller
{
    public function __construct() 
    {
       parent::__construct(); 
       $this->load->database();
    }
    function property_get()
    {
        ...
    }    
    function property_post()
    {
    ...
    }
    function attach_image($file_type) 
    {
            if($this->post($file_type) != ""){
                    save_base64_image($file_type,$this->post($file_type));
                    $this->email->attach($_SESSION[$file_type]);
            }
    }       

    function property_delete()
    {
        ...
    }
function share_post()
    {       
    $email_id = $this->post('emailid');

    $config['mailtype'] = "html";
    $this->email->initialize($config);

    $this->email->from('myid@gmail.com', 'mobile app');
    $this->email->to($email_id); 

    $this->email->subject('subject');
    $this->email->message('message');   

    if ( ! $this->email->send() )
    {
        $this->response("Internal server error.", 500);
    } 
    else 
    {
        $result = new stdClass();
        $result->message = 'Email has been sent.';
        $this->response($result, 200); // 200 being the HTTP response code
    }        

    }

public function send_post()
{
    var_dump($this->request->body);
}


public function send_put()
{
    var_dump($this->put('foo'));
}

}

这是我的 jQuery ajax 调用。

$.ajax( {
        url: PMSApp.apiUrl + "/share/format/json",
        type: 'post',
        dataType: "json",
        contentType: "application/json; charset=utf-8"
    })
    .done(function(response) {
        console.log(JSON.stringify(response));
})
.fail(function(response) {
        console.log(JSON.stringify(response));
})
.always(function(response) {
        console.log(JSON.stringify(response));
}); 

我可以/share/format/json使用 POSTMAN、chrome 扩展名访问此 API,但不能使用file://or localhost://

编辑:

我也试过改成share_post(),效果很好share_gett()。但我需要在 POST 中使用它。

在过去的 48 小时里,我一直坚持这一点。尝试了许多解决方案,但没有任何帮助我解决这个问题。请帮我。

4

2 回答 2

0

您必须使用 Access-Control-Allow-Origin 启动 Chrome

这个线程: https ://superuser.com/questions/384871/overriding-access-control-allow-origin-restriction-in-google-chrome

检查此步骤: Access-Control-Allow-Origin 不允许来源

于 2013-10-14T07:47:37.990 回答
0

Phonegap 提供了将您的 Web 服务域列入白名单的选项。它在config xml http://docs.phonegap.com/en/2.3.0/guide_whitelist_index.md.html中设置访问源

于 2014-09-20T19:23:48.543 回答