Javascript 图像 URL 验证

IT技术 javascript image function url verify
2021-01-20 16:46:33

我需要验证图像 url 以检查该 url 是否是以下任何扩展名的图像:- jpeg、jpg、gif、png。示例:- 当我们验证这个 url http://www.example.com/asdf.jpg 时,它应该给我们真正的值,并且像这样的 url http://www.example.com/asdf.php应该返回 false。我们如何在 javascript 中执行此操作,而且我想检查 url 的内容类型。这样我们就可以判断 url 是否是图像。

6个回答

您可以使用这样的正则表达式来检查文件扩展名:

function checkURL(url) {
    return(url.match(/\.(jpeg|jpg|gif|png)$/) != null);
}

这会检查 url 是否以这四个扩展名中的任何一个结尾。

我不知道客户端中的 javascript 无法验证与网页不在同一域中的 URL 的内容类型,因为您不能在网页域之外使用 ajax。据我所知,您必须将 URL 发送到服务器进程并让它下载图像,获取内容类型并将其返回给您。

但是,您可以使用如下函数检查图像标签是否可以加载 URL:

function testImage(url, callback, timeout) {
    timeout = timeout || 5000;
    var timedOut = false, timer;
    var img = new Image();
    img.onerror = img.onabort = function() {
        if (!timedOut) {
            clearTimeout(timer);
            callback(url, "error");
        }
    };
    img.onload = function() {
        if (!timedOut) {
            clearTimeout(timer);
            callback(url, "success");
        }
    };
    img.src = url;
    timer = setTimeout(function() {
        timedOut = true;
        // reset .src to invalid URL so it stops previous
        // loading, but doesn't trigger new load
        img.src = "//!!!!/test.jpg";
        callback(url, "timeout");
    }, timeout); 
}

此函数将在未来某个时间使用两个参数调用您的回调:原始 URL 和结果(“成功”、“错误”或“超时”)。你可以在几个 URL 上看到这项工作,有好有坏,在这里:http : //jsfiddle.net/jfriend00/qKtra/


而且,由于现在是 Promises 的时代,这里有一个返回 Promise 的版本:

function testImage(url, timeoutT) {
    return new Promise(function (resolve, reject) {
        var timeout = timeoutT || 5000;
        var timer, img = new Image();
        img.onerror = img.onabort = function () {
            clearTimeout(timer);
            reject("error");
        };
        img.onload = function () {
            clearTimeout(timer);
            resolve("success");
        };
        timer = setTimeout(function () {
            // reset .src to invalid URL so it stops previous
            // loading, but doesn't trigger new load
            img.src = "//!!!!/test.jpg";
            reject("timeout");
        }, timeout);
        img.src = url;
    });
}

而且,一个 jsFiddle 演示:http : //jsfiddle.net/jfriend00/vhtzghkd/

谢谢你的帮助。此功能有效,但我们如何检查 url 的内容类型。我的意思是第一步是检查 url 的扩展名,我想通过添加第二步来检查 url 的内容类型来使其更安全。
2021-03-18 16:46:33
谢谢很多人。你真棒。你节省了我的时间。有用。再次感谢您的支持和时间。
2021-04-02 16:46:33
好吧,如果这个人输入一个 php 文件的 url怎么example.com/asdf.php.jpg那么我们怎么能返回 false 值,因为我们的函数将返回 true。
2021-04-03 16:46:33
@JohnPreston - 我添加了两种方法来测试我的答案的 URL。一,您将 URL 发送到服务器并让它测试内容类型。二,您可以运行一些代码将其加载到图像标签中,看看是否成功。
2021-04-05 16:46:33
对于那些寻求快速使用的人 testImage(inputUrl, function(url, result) {if (result === 'success') {console.log(url)}}, 10000);
2021-04-05 16:46:33

使用 HEAD http 请求方法检查内容类型...

$.ajax({
  type: "HEAD",
  url : "urlValue",
  success: function(message,text,response){
     if(response.getResponseHeader('Content-Type').indexOf("image")!=-1){
           alert("image");
    }
  } 
});

要检查字符串是否包含可以使用 inArray 方法的扩展名,

function checkUrl(url){
   var arr = [ "jpeg", "jpg", "gif", "png" ];
   var ext = url.substring(url.lastIndexOf(".")+1);
   if($.inArray(ext,arr)){
     alert("valid url");
     return true;
  }
}

编辑:更新错字

这里有一个错字:lasIndexOf -> lastIndexOf
2021-03-29 16:46:33
这两个都使用 jQuery,并且 OP 没有标记 jQuery 的问题。
2021-04-03 16:46:33
请修正$.ajax{}$.ajax({})
2021-04-06 16:46:33
Ajax 解决方案很有趣,但在跨站点请求中不起作用,除非启用了 CORS
2021-04-12 16:46:33
let url = "folder/myImage.png";
if ( isValidImageURL(url) ){
    // do something if url is valid image url.
}

function isValidImageURL(str){
    if ( typeof str !== 'string' ) return false;
    return !!str.match(/\w+\.(jpg|jpeg|gif|png|tiff|bmp)$/gi);
}
你能用一个执行示例添加调用这个方法的方式吗?
2021-03-24 16:46:33

要使用正则表达式验证图像 url 字符串,这很简单。

url.match(/^https?:\/\/.+\/.+$/)

我们要检查的只是 url 是否有协议https://、主机名foobar.com、斜杠/和图像名称。无需检查图像扩展名 ( png, jpg...) 因为它不是必需的,浏览器通过它的 headers 检查图像类型

要检查图像是否存在,请将其 url 附加到 Image 构造函数并检查它是否有错误。

const doesImageExist = (url) =>
  new Promise((resolve) => {
    const img = new Image();

    img.src = url;
    img.onload = () => resolve(true);
    img.onerror = () => resolve(false);
  });

一个更灵活的解决方案,支持文件扩展名后的查询参数:

function isImgLink(url) {
    if(typeof url !== 'string') return false;
    return(url.match(/^http[^\?]*.(jpg|jpeg|gif|png|tiff|bmp)(\?(.*))?$/gmi) != null);
}

console.log(isImgLink('https://example.com/img.jpg')); // true
console.log(isImgLink('https://example.com/any-route?param=not-img-file.jpg')); // false
console.log(isImgLink('https://example.com/img.jpg?param=123')); // true