Avatar billede Slettet bruger
27. maj 2010 - 13:28 Der er 4 kommentarer og
1 løsning

Fancyupload ekstra formdata

Hej Eksp.

Jeg har nu fået fancyupload til at virke med upload + data til sql. Jeg kan altså uploade multiple images, og sende fil-navnet til databasen. Meeen. jeg ønsker at kunne udvide uploadformen således at jeg kan sende andre oplysninger til databasen. Jeg har dg nogle problemer med at sende formdata til mit uploadscript. Jeg har læst en diskussion der beskriver det således:

Yes FancyUpload can add additional information to your form !!

Exemple js/html :

var up = new FancyUpload2($('demo-status'), $('demo-list'), {
url: $('form-demo').action,
data: 'Value1='+$('FieldName1').get('value')+'&Value2='+$('FieldName2').get('value'),
(...)
<input type="hidden" id="FieldName1" value="Hi world" />
<input type="hidden" id="FieldName2" value="I love FancyUpload" />

Exemple PHP (in my case) :

$Value1 = mysql_real_escape_string($_POST['Value1']);
$Value2 = mysql_real_escape_string($_POST['Value2']);

Men jeg har problemer med at få det til at virke. hvor skal hvad placeres?

Har andre haft problemer med dette - og løst det ???

Kender i andre metoder der virker - eller links til sider der virker. synes virkelig det er svært.

Tak!
Avatar billede RexReptiles Nybegynder
27. maj 2010 - 15:40 #1
umiddelbart forstår jeg ikke hvorfor du ik bare sætter flere inputs på og cheker efter de posts samtidigt med upload uden alt muligt mystisk.

det er ganske simpelt - prøv at vis din upload side
og fortæl hvilke extra info du vil ha med.
Avatar billede Slettet bruger
27. maj 2010 - 17:18 #2
Jeg tror at det er fordi den er flashbaseret og ikke bruger en alm. submit knap at det ikke virker:

min form.php:

<title>FancyUpload 2.1 by Harald Kirschner working demo</title>

    <!-- dynamic assets -->
    <style type="text/css">

#demo-status
{
    background-color:        #F9F7ED;
    padding:                10px 15px;
    width:                    420px;
}

#demo-status .progress
{
    background:                white url(./assets/progress-bar/progress.gif) no-repeat;
    background-position:    +50% 0;
    margin-right:            0.5em;
}

#demo-status .progress-text
{
    font-size:                0.9em;
    font-weight:            bold;
}

#demo-list
{
    list-style:                none;
    width:                    450px;
    margin:                    0;
}

#demo-list li.file
{
    border-bottom:            1px solid #eee;
    background:                url(./assets/file.png) no-repeat 4px 4px;
}
#demo-list li.file.file-uploading
{
    background-image:        url(./assets/uploading.png);
    background-color:        #D9DDE9;
}
#demo-list li.file.file-success
{
    background-image:        url(./assets/success.png);
}
#demo-list li.file.file-failed
{
    background-image:        url(./assets/failed.png);
}

#demo-list li.file .file-name
{
    font-size:                1.2em;
    margin-left:            44px;
    display:                block;
    clear:                    left;
    line-height:            40px;
    height:                    40px;
    font-weight:            bold;
}
#demo-list li.file .file-size
{
    font-size:                0.9em;
    line-height:            18px;
    float:                    right;
    margin-top:                2px;
    margin-right:            6px;
}
#demo-list li.file .file-info
{
    display:                block;
    margin-left:            44px;
    font-size:                0.9em;
    line-height:            20px;
    clear
}
#demo-list li.file .file-remove
{
    clear:                    right;
    float:                    right;
    line-height:            18px;
    margin-right:            6px;
}
    </style>
    <script type="text/javascript" src="mootools-1.2-core-nc.js"></script>
    <script type="text/javascript" src="Swiff.Uploader.js"></script>
    <script type="text/javascript" src="Fx.ProgressBar.js"></script>
    <script type="text/javascript" src="FancyUpload2.js"></script>

    <script type="text/javascript">
        /* <![CDATA[ */

window.addEvent('load', function() {

    // For testing, showing the user the current Flash version.
    //document.getElement('h3 + p').appendText(' Detected Flash ' + Browser.Plugins.Flash.version + '!');
   
    var swiffy = new FancyUpload2($('demo-status'), $('demo-list'), {
        url: $('form-demo').action,
        fieldName: 'photoupload',
        path: 'Swiff.Uploader.swf'
        limitSize: 2 * 1024 * 1024, // 2Mb
        onLoad: function() {
            $('demo-status').removeClass('hide');
            $('demo-fallback').destroy();
        },
        // The changed parts!
        debug: true, // enable logs, uses console.log
        target: 'demo-browse', // the element for the overlay (Flash 10 only)
    });

    /**
    * Various interactions
    */

    $('demo-browse').addEvent('click', function() {
        /**
        * Doesn't work anymore with Flash 10: swiffy.browse();
        * FancyUpload moves the Flash movie as overlay over the link.
        * (see opeion "target" above)
        */
        swiffy.browse();
        return false;
    });

    /**
    * The *NEW* way to set the typeFilter, since Flash 10 does not call
    * swiffy.browse(), we need to change the type manually before the browse-click.
    */
    $('demo-select-images').addEvent('change', function() {
        var filter = null;
        if (this.checked) {
            filter = {'Images (*.jpg, *.jpeg, *.gif, *.png)': '*.jpg; *.jpeg; *.gif; *.png'};
        }
        swiffy.options.typeFilter = filter;
    });

    $('demo-clear').addEvent('click', function() {
        swiffy.removeFile();
        return false;
    });

    $('demo-upload').addEvent('click', function() {
        swiffy.upload();
        return false;
    });

});

    </script>


<a href="http://www.rioleo.org"><img src="http://www.sccs.swarthmore.edu/users/09/leo/images/logo.gif" border="0" /></a>
<h1><a href="http://digitarald.de/project/fancyupload/">FancyUpload 2.1</a> by Harald Kirschner working demo</h1>
<p>Uploads limited to image files, 2MB size or smaller. You can also modify the script to upload certain other file extensions only.</p>
<p>Download <a href="http://www.rioleo.org/counter/click.php?id=18"><strong>FancyUpload, packaged</strong></a> or see <a href="http://www.rioleo.org/getting-fancyupload-to-work.php">related post</a>.</p>


<form action="script.php" method="post" enctype="multipart/form-data" id="form-demo">
    <fieldset id="demo-fallback">
       
        <legend>File Upload</legend>
        <p>
            Selected your photo to upload.<br />
            <strong>This form is just an example fallback for the unobtrusive behaviour of FancyUpload.</strong>
        </p>
        <label for="demo-photoupload">
            Upload Photos:
            <input type="file" name="photoupload" id="demo-photoupload" />
           
    </fieldset>
<label for="ref" class="titlestyle">Vælg Album</label><br />
            <?php
           
            define('INCLUDE_CHECK',true);
           
            require '../connect.php';
            $query  = "SELECT * FROM album";
              $result = mysql_query($query);
            echo "<select class='inputstyle' name='albumname' id='albumname'>";
            while($row = mysql_fetch_array($result, MYSQL_ASSOC))
            {
             
              echo "<option>{$row['name']}</option>";
           
            } 
              echo "</select>";
            ?>
           
        </label>
    <div id="demo-status" class="hide">
        <p>
            <a href="#" id="demo-browse">Browse Files</a> |
            <input type="checkbox" id="demo-select-images" /> Images Only |
            <a href="#" id="demo-clear">Clear List</a> |
            <a href="#" id="demo-upload">Upload</a>
        </p>
        <div>
            <strong class="overall-title">Overall progress</strong><br />
            <img src="./assets/progress-bar/bar.gif" class="progress overall-progress" />
        </div>
        <div>
            <strong class="current-title">File Progress</strong><br />
            <img src="./assets/progress-bar/bar.gif" class="progress current-progress" />
        </div>
        <div class="current-text"></div>
    </div>

    <ul id="demo-list"></ul>
</form>


og mit upload scipt.php:

<?php
include("JSON.php");
$result = array();

if (isset($_FILES['photoupload']) )
{
    $file = $_FILES['photoupload']['tmp_name'];
    $error = false;
    $size = false;

    if (!is_uploaded_file($file) || ($_FILES['photoupload']['size'] > 2 * 1024 * 1024) )
    {
        $error = 'Please upload only files smaller than 2Mb!';
    }
    if (!$error && !($size = @getimagesize($file) ) )
    {
        $error = 'Please upload only images, no other files are supported.';
    }
    if (!$error && !in_array($size[2], array(1, 2, 3, 7, 8) ) )
    {
        $error = 'Please upload only images of type JPEG.';
    }
    if (!$error && ($size[0] < 25) || ($size[1] < 25))
    {
        $error = 'Please upload an image bigger than 25px.';
    }
    else {
        move_uploaded_file($_FILES['photoupload']['tmp_name'], "./uploadedfiles/".$_FILES['photoupload']['name']);
        chmod("./uploadedfiles/".$_FILES['photoupload']['name'], 0777);
    }

    $addr = gethostbyaddr($_SERVER['REMOTE_ADDR']);

    $log = fopen('script.log', 'a');
    fputs($log, ($error ? 'FAILED' : 'SUCCESS') . ' - ' . preg_replace('/^[^.]+/', '***', $addr) . ": {$_FILES['photoupload']['name']} - {$_FILES['photoupload']['size']} byte\n" );
    fclose($log);

    if ($error)
    {
        $result['result'] = 'failed';
        $result['error'] = $error;
    }
    else
    {
                define('INCLUDE_CHECK',true);
               
                require '../connect.php';
                require '../functions.php';
                $nicename=$_FILES['photoupload']['name'];
                $albumname = $_POST['albumname'];
                $sql="INSERT INTO billeder    (url, Name, ref)
                VALUES
                ('$nicename','$nicename','$albumname')";
               
                if (!mysql_query($sql,$link))
                {
                die('Error: mann ' . mysql_error());
                }
 
 
        $result['result'] = 'success';
        $result['size'] = "Uploaded an image ({$size['mime']}) with  {$size[0]}px/{$size[1]}px.";
    }

}
else
{
    $result['result'] = 'error';
    $result['error'] = 'Missing file or internal error!';
}

if (!headers_sent() )
{
    header('Content-type: application/json');
}

echo json_encode($result);

?>
Avatar billede aners Nybegynder
27. maj 2010 - 17:46 #3
Hvis du giver op, så tjek http://swfupload.org/
Avatar billede Slettet bruger
27. maj 2010 - 17:58 #4
lukker..
Avatar billede RexReptiles Nybegynder
27. maj 2010 - 19:08 #5
ja okay, hvis de skulle være så skulle du redigere i flashen til at ha extra inputs og ha det med i event scriptet og flash er ik min stærke side.
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Vi tilbyder markedets bedste kurser inden for webudvikling

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester



Seneste spørgsmål Seneste aktivitet
I dag 06:10 Excel åbner fil i kæmpe format Af Aske i Excel
I går 22:00 Datafordeler Af Lsk i PHP
I går 12:37 Summere beløb pr. dato Af TTA i Excel
31/1022:44 Tilslutte chassic fans Af viking69 i PC
31/1020:28 LED lysstofrør Af ErikHg i Fri debat