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

JavascriptJqueryFile UploadFilepath

Javascript Problem Overview


How to get full path of file while selecting file using <input type=‘file’>

<input type="file" id="fileUpload">
<script type="text/javascript">
function getFilePath(){
     $('input[type=file]').change(function () {
         var filePath=$('#fileUpload').val(); 
     });
}
</script>

but the filePath var contains only name of selected file, not the full path.
I searched it on net, but it seems that for security reasons browsers (FF,chrome) just give name of file.
Is there any other way to get full path of selected file?

Javascript Solutions


Solution 1 - Javascript

For security reasons browsers do not allow this, i.e. JavaScript in browser has no access to the File System, however using HTML5 File API, only Firefox provides a mozFullPath property, but if you try to get the value it returns an empty string:

$('input[type=file]').change(function () {
    console.log(this.files[0].mozFullPath);
});

https://jsfiddle.net/SCK5A/

So don't waste your time.

edit: If you need the file's path for reading a file you can use the FileReader API instead. Here is a related question on SO: Preview an image before it is uploaded.

Solution 2 - Javascript

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.

Solution 3 - Javascript

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>

Solution 4 - Javascript

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.

Solution 5 - Javascript

Did you mean this?

$('#i_file').change( function(event) {
var tmppath = URL.createObjectURL(event.target.files[0]);
    $("img").fadeIn("fast").attr('src',tmppath);       
});

Solution 6 - Javascript

You can use the following code to get a working local URL for the uploaded file:

<script type="text/javascript">    
    var path = (window.URL || window.webkitURL).createObjectURL(file);
    console.log('path', path);
</script>

Solution 7 - Javascript

One interesting note: although this isn't available in on the web, if you're using JS in Electron then you can do this.

Using the standard HTML5 file input, you'll receive an extra path property on selected files, containing the real file path.

Full docs here: https://github.com/electron/electron/blob/master/docs/api/file-object.md

Solution 8 - Javascript

You can, if uploading an entire folder is an option for you

<input type="file" webkitdirectory directory multiple/>

change event will contain:

.target.files[...].webkitRelativePath: "FOLDER/FILE.ext"

but it doesn't contain the whole absolute path, only the relative one. Supported in Firefox also.

Solution 9 - Javascript

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)

https://stackoverflow.com/questions/3489133/full-path-from-file-input-using-jquery
https://stackoverflow.com/questions/81180/how-to-get-the-file-path-from-html-input-form-in-firefox-3

Solution 10 - Javascript

One could use the FileReader API for changing the src of an img element.

https://developer.mozilla.org/en-US/docs/Web/API/FileReader/readAsDataURL

Solution 11 - Javascript

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);

Solution 12 - Javascript

You can get the full path of the selected file to upload only by IE11 and MS Edge.

var fullPath = Request.Form.Files["myFile"].FileName;

Solution 13 - Javascript

$('input[type=file]').change(function () {
    console.log(this.files[0].path);
});

This is the correct form.

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestionYogesh PingleView Question on Stackoverflow
Solution 1 - JavascriptRamView Answer on Stackoverflow
Solution 2 - JavascriptDWXView Answer on Stackoverflow
Solution 3 - JavascriptDipesh ParmarView Answer on Stackoverflow
Solution 4 - JavascriptRajshekar ReddyView Answer on Stackoverflow
Solution 5 - JavascriptAytac GulView Answer on Stackoverflow
Solution 6 - JavascriptSteffen BremView Answer on Stackoverflow
Solution 7 - JavascriptTim PerryView Answer on Stackoverflow
Solution 8 - Javascriptphil294View Answer on Stackoverflow
Solution 9 - JavascriptbipenView Answer on Stackoverflow
Solution 10 - Javascriptleonard9500View Answer on Stackoverflow
Solution 11 - JavascriptJeeva KumarView Answer on Stackoverflow
Solution 12 - JavascriptMajid ShahabfarView Answer on Stackoverflow
Solution 13 - JavascriptAlexie01View Answer on Stackoverflow