开发者

Valums Ajax Upload with Codeigniter: Get Parameters!

开发者 https://www.devze.com 2023-02-04 10:40 出处:网络
How do I use paramaters with Valums开发者_JS百科 Uploader and Codeigniter?With Valums the parameters are set like so:

How do I use paramaters with Valums开发者_JS百科 Uploader and Codeigniter?


With Valums the parameters are set like so:

var uploader = new qq.FileUploader({
    element: document.getElementById('file-uploader'),
    action: '/server-side.upload',
    // additional data to send, name-value pairs
    params: {
        param1: 'value1',
        param2: 'value2'
    }
});

or using

uploader.setParams({
   anotherParam: 'value' 
});

if you want it to be aware of the state of your app/

subD="/Pic"
function selectGaleryName()
{
subD=subD+"/3"
alert(subD) // /Pic/3
}


var uploader = new qq.FileUploader({
element: document.getElementById('UploadFile'),
action: 'http://localhost/Farainform/manager/upload.php'
// additional data to send, name-value pairs

onComplete: function(id, fileName, responseJSON){ 

selectGaleryName();

uploader.setParams({
  subDirectory : subD
});

},


});

if you want to set an id and a description for an image you can set these in javascript and then send these. So something like (im using jQuery here):

var description = $('#input_description').val(); //This can be an input 
var id = $('#input_description').att('id');

var uploader = new qq.FileUploader({
    element: document.getElementById('file-uploader'),
    action: '/server-side.upload',
    // additional data to send, name-value pairs
    params: {
        description: description,
        id: id
    }
});

Note I havent tested this code and its for demonstration purposes.


$_GET was always destroyed in the 1.7.3 branch but upgrade to the new CodeIgniter Reactor 2.0 and you'll find that GET strings work out of the box.

When upgraded, use this syntax:

$this->input->get('value1');


I don't know why it is not documented on Valums page, but apparently parameters should be sent not like this

params: {
        param1: 'value1',
        param2: 'value2'}

But like this

data: {param1: 'value1',
       param2: 'value2'}

On server side you could get them with $_REQUEST['param1'];


You have to use PHP's input stream in order to obtain the data.

$fp = fopen('php://input', 'r');

Then read the data as you normally would with a regular file using fread(). Refer to valum's server side code located in server/php.php within the download.


Two related issues that I ran into that might help someone out:

1) var uploader causes issues - try using something like ajaxuploader instead

2) the documented setParams is incorrect for the latest release - it should be setData

The end result should be something like this:

var ajaxuploader = new AjaxUpload(button, {
        action: 'your-server-script.php', 
        name: 'myfile',
        onSubmit : function(file, ext){

            ajaxuploader.setData({
               somevar : 'somevalue',
               anothervar : 'anothervalue'
            });
)};
0

精彩评论

暂无评论...
验证码 换一张
取 消