How to get full path of selected file on change of <input type=‘file’> using javascript, jquery-ajax?

后端 未结 11 2600
谎友^
谎友^ 2020-11-21 04:36

How to get full path of file while selecting file using




        
相关标签:
11条回答
  • 2020-11-21 05:22

    you should never do so... and I think trying it in latest browsers is useless(from what I know)... all latest browsers on the other hand, will not allow this...

    some other links that you can go through, to find a workaround like getting the value serverside, but not in clientside(javascript)

    Full path from file input using jQuery
    How to get the file path from HTML input form in Firefox 3

    0 讨论(0)
  • 2020-11-21 05:24

    You cannot do so - the browser will not allow this because of security concerns.

    When a file is selected by using the input type=file object, the value of the value property depends on the value of the "Include local directory path when uploading files to a server" security setting for the security zone used to display the Web page containing the input object.

    The fully qualified filename of the selected file is returned only when this setting is enabled. When the setting is disabled, Internet Explorer 8 replaces the local drive and directory path with the string C:\fakepath\ in order to prevent inappropriate information disclosure.

    And other

    You missed ); this at the end of the change event function.

    Also do not create function for change event instead just use it as below,

    <script type="text/javascript">
    
        $(function()
        {
            $('#fileUpload').on('change',function ()
            {
                var filePath = $(this).val();
                console.log(filePath);
            });
        });
    
    </script>
    
    0 讨论(0)
  • 2020-11-21 05:25

    file element has and array call files it contain all necessary stuff you need

    var file = document.getElementById("upload");
    
    file.addEventListener("change", function() {
        for (var i = 0; i < file.files.length; i++) {
            console.log(file.files[i].name);
        }
    }, false);
    
    0 讨论(0)
  • 2020-11-21 05:27

    Try This:

    It'll give you a temporary path not the accurate path, you can use this script if you want to show selected images as in this jsfiddle example(Try it by selectng images as well as other files):-

    JSFIDDLE

    Here is the code :-

    HTML:-

    <input type="file" id="i_file" value=""> 
    <input type="button" id="i_submit" value="Submit">
    <br>
    <img src="" width="200" style="display:none;" />
    <br>
    <div id="disp_tmp_path"></div>
    

    JS:-

    $('#i_file').change( function(event) {
        var tmppath = URL.createObjectURL(event.target.files[0]);
        $("img").fadeIn("fast").attr('src',URL.createObjectURL(event.target.files[0]));
    
        $("#disp_tmp_path").html("Temporary Path(Copy it and try pasting it in browser address bar) --> <strong>["+tmppath+"]</strong>");
    });
    

    Its not exactly what you were looking for, but may be it can help you somewhere.

    0 讨论(0)
  • 2020-11-21 05:30

    You can't. Security stops you for knowing anything about the filing system of the client computer - it may not even have one! It could be a MAC, a PC, a Tablet or an internet enabled fridge - you don't know, can't know and won't know. And letting you have the full path could give you some information about the client - particularly if it is a network drive for example.

    In fact you can get it under particular conditions, but it requires an ActiveX control, and will not work in 99.99% of circumstances.

    You can't use it to restore the file to the original location anyway (as you have absolutely no control over where downloads are stored, or even if they are stored) so in practice it is not a lot of use to you anyway.

    0 讨论(0)
提交回复
热议问题