如何在使用javascript,jquery-ajax更改时获取所选文件的完整路径?

如何使用only name选择文件时获取文件的完整路径

function getFilePath(){
$('input[type=file]').change(function () {
var filePath=$('#fileUpload').val();
});
}

但filePath var包含所选文件的only name,而不是full path。

我在网上搜索过,但出于安全考虑,似乎浏览器(FF,chrome)只是给出文件名。

有没有其他方法来获取所选文件的完整路径?

9个解决方案

113 votes

出于安全原因,浏览器不允许这样做,即浏览器中的JavaScript无法访问文件系统,但是使用HTML5文件API,只有Firefox提供了mozFullPath属性,但如果您尝试获取该值,则返回空字符串:

$('input[type=file]').change(function () {
console.log(this.files[0].mozFullPath);
});
[http://jsfiddle.net/SCK5A/]

所以不要浪费你的时间。

编辑:如果您需要文件的路径来读取文件,则可以使用FileReader API。 以下是关于SO的相关问题:在上传图像之前预览图像。

undefined answered 2019-03-23T17:01:30Z

88 votes

试试这个:

它会给你一个临时路径而不是准确的路径,你可以使用这个脚本,如果你想在这个jsfiddle例子中显示选定的图像(通过selectng图像以及其他文件尝试): -

的jsfiddle

这是代码: -

HTML: -

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) --> ["+tmppath+"]");
});

它不完全是你想要的,但它可以帮助你在某个地方。

DWX answered 2019-03-23T17:02:25Z

18 votes

你不能这样做 - 由于安全问题,浏览器不允许这样做。

使用input type = file对象选择文件时,该值   value属性的值取决于“Include local”的值   将文件上载到服务器时的目录路径“安全设置   用于显示包含输入的Web页面的安全区域   宾语。

仅返回所选文件的完全限定文件名   启用此设置时。 禁用该设置时,Internet   Explorer 8用字符串替换本地驱动器和目录路径   C:\ fakepath \以防止不恰当的信息泄露。

和别的

您在更改事件功能结束时错过了);。

也不要为change事件创建函数而只是使用它,如下所示,

$(function()
{
$('#fileUpload').on('change',function ()
{
var filePath = $(this).val();
console.log(filePath);
});
});
Dipesh Parmar answered 2019-03-23T17:03:27Z
12 votes

你不能。安全性使您无法了解客户端计算机的归档系统 - 它甚至可能没有! 它可能是MAC,PC,平板电脑或支持互联网的冰箱 - 你不知道,不知道也不会知道。 让你拥有完整的路径可以为你提供有关客户端的一些信息 - 特别是如果它是一个网络驱动器。

实际上,您可以在特定条件下获取它,但它需要ActiveX控件,并且在99.99%的情况下不起作用。

你无法使用它将文件恢复到原始位置(因为你完全无法控制下载的存储位置,或者即使存储了它们),所以在实践中它对你来说并没有多大用处。

Rajshekar Reddy answered 2019-03-23T17:04:10Z

10 votes

你的意思是?

$('#i_file').change( function(event) {
var tmppath = URL.createObjectURL(event.target.files[0]);
$("img").fadeIn("fast").attr('src',tmppath);
});
Aytac Gul answered 2019-03-23T17:04:43Z
5 votes

您可以使用以下代码获取上载文件的工作本地URL:

var path = (window.URL || window.webkitURL).createObjectURL(file);
console.log('path', path);
Steffen Brem answered 2019-03-23T17:05:09Z
1 votes

你永远不应该这样....我认为在最新的浏览器中尝试它是没用的(据我所知)..另一方面,所有最新的浏览器,将不允许这....

您可以通过其他一些链接找到一个解决方法,例如获取值服务器端,但不能在客户端(javascript)

使用jQuery从文件输入的完整路径

如何从Firefox 3中的HTML输入表单获取文件路径

bipen answered 2019-03-23T17:05:59Z

1 votes

如果您上传整个文件夹,则可以选择

更改事件将包含:

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

Blauhirn answered 2019-03-23T17:06:32Z

0 votes

文件元素和数组调用files它包含您需要的所有必要的东西

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);
Jeeva Kumar answered 2019-03-23T17:06:58Z