当前位置:首页 > 文章列表 > 文章 > php教程 > 使用PHP编程语言进行Unsplash API的图像搜索

使用PHP编程语言进行Unsplash API的图像搜索

2024-03-26 15:05:31 0浏览 收藏
推广推荐
下载万磁搜索绿色版 ➜
支持 PC / 移动端,安全直达

使用PHP和Unsplash API进行图像搜索是一个简单易行的过程。本文介绍了如何注册API密钥、引入Unsplash库、设置搜索参数并进行图像搜索。搜索结果可以通过提取图像URL、描述和拍摄者名称并将其显示在HTML页面上进行显示。遵循本文中的步骤,开发者可以轻松地将Unsplash API集成到他们的Web项目中,从而访问大量免费图像和素材。

随着互联网的发展,图像已经成为数字时代最受欢迎的媒体形式之一。而对于Web开发人员来说,实现基于图像的功能或者美化页面,图像的搜索和使用已经成为web项目开发中不可避免的事情。而Unsplash是其中最受欢迎的免费照片和图像素材库之一。在本篇文章中,我们将介绍如何使用PHP和Unsplash API进行图像搜索。

  1. 注册Unsplash API密钥

首先,您需要注册Unsplash API密钥。注册过程非常简单,只需要打开Unsplash API官网,填写相关信息,就可以获取API密钥。在注册时,需要填写您的个人信息和项目详情。一旦注册成功,您将收到一个API密钥。请记住它,因为您需要在后面的步骤中使用它。

  1. 引入Unsplash API

在项目中引入Unsplash API,可以通过官方提供的Javascript、PHP或Python库的方式引入。在这里,我们选择通过PHP版本的库进行演示。

可以通过composer命令或者直接在项目中下载源代码的方式引入Unsplash API。如果您使用Composer,可以使用以下命令:

composer require unsplash/unsplash

如果您想直接引入源代码,可以下载源代码并解压缩到您的项目根目录下。

  1. 创建Unsplash连接

在您的PHP文件中,使用引入的Unsplash库,创建一个新的Unsplash连接。使用以下代码:

use UnsplashUnsplash;

$accessKey = 'YOUR_ACCESS_KEY';

$unsplash = new Unsplash([
    'accessKey' => $accessKey,
]);

这里,需要填写在注册Unsplash API时获取的API密钥。通过这个示例代码,我们使用Unsplash库创建了一个与Unsplash服务器的连接。

  1. 设置搜索参数

接下来,使用Unsplash API,可以设置任意数量的搜索参数,以在Unsplash库中搜索不同的图像。这里,我们将设置一个搜索参数,通过关键字搜索与旅游相关的图像。使用以下代码:

$keyword = 'travel';
$resultsPerPage = 20;

$searchParams = [
    'query' => $keyword,
    'per_page' => $resultsPerPage,
];

这里,我们设置变量$keyword为'travel',代表我们需要通过这个关键字进行搜索。并且,我们还设置了一个变量$resultsPerPage为20,这代表我们希望从每个搜索结果中获取20张图像。在搜索参数设置完成后,一起传递到搜索函数中进行搜索。

  1. 进行图像搜索

使用设置好的搜索参数,在Unsplash API中搜索图像。使用Unsplash库提供的searchPhotos函数进行搜索,如下所示:

$searchResults = $unsplash->searchPhotos($searchParams);

现在,我们已经成功地搜索了与旅游相关的图像。我们还需要提取这些图像的信息,并将它们显示在Web页面上。

  1. 显示搜索结果

在进行图像搜索后,需要将搜索结果在浏览器中显示出来。使用以下代码,提前每个图像的信息,并将它们放在HTML页面中:

foreach ($searchResults->getResults() as $photo) {
    $imageUrl = $photo->getUrls()['small'];
    $photoDescription = $photo->getDescription();
    $photoCredit = $photo->getUser()['name'];

    echo '<div class="image-container">';
    echo '<img src="'.$imageUrl.'" alt="'.$photoDescription.'">';
    echo '<div class="photo-credit">'.$photoCredit.'</div>';
    echo '</div>';    
}

在该代码块中,我们将提取每个图像的URL和Description。同时,还将提取每个图像拍摄者的名称(在Unsplash库中称为用户)。然后,将这些信息放入HTML页面中,并将每个图像显示在一个自定义的HTML div中。

  1. 完整的PHP文件示例

最后,将所有上述步骤组合在一起,生成一个完整的PHP文件,如下所示:

<?php
use UnsplashUnsplash;
require_once('vendor/autoload.php');

$accessKey = 'YOUR_ACCESS_KEY';

$unsplash = new Unsplash([
    'accessKey' => $accessKey,
]);

$keyword = 'travel';
$resultsPerPage = 20;

$searchParams = [
    'query' => $keyword,
    'per_page' => $resultsPerPage,
];

$searchResults = $unsplash->searchPhotos($searchParams);
?>

<!DOCTYPE html>
<html>
<head>
    <title>Unsplash Image Search</title>
    <style>
        .image-container {
            max-width: 400px;
            margin-right: 20px;
            display: inline-block;
        }
        .photo-credit {
            font-size: 14px;
            font-style: italic;
            margin-top: 5px;
        }
    </style>
</head>
<body>
    <?php foreach ($searchResults->getResults() as $photo) { ?>
    <?php
        $imageUrl = $photo->getUrls()['small'];
        $photoDescription = $photo->getDescription();
        $photoCredit = $photo->getUser()['name'];
    ?>
    <div class="image-container">
        <img src="<?php echo $imageUrl; ?>" alt="<?php echo $photoDescription; ?>">
        <div class="photo-credit">Photo by <?php echo $photoCredit; ?></div>
    </div>
    <?php } ?>
</body>
</html>

在使用这个PHP文件之前,替换其中字符串'YOUR_ACCESS_KEY',使用在Unsplash API中注册时获取的API密钥。

结论

上面就是我们使用PHP和Unsplash API进行图像搜索的全部流程。在进行Unsplash API图像搜索时,请确保API密钥的安全,并且必须从Unsplash官方获取API密钥。同时,我们需要遵循Unsplash API服务使用规则,在规则允许范围内进行图像搜索和使用。

今天带大家了解了的相关知识,希望对你有所帮助;关于文章的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

Python Web编程工具探秘指南:掌握Django快速入门Python Web编程工具探秘指南:掌握Django快速入门
上一篇
Python Web编程工具探秘指南:掌握Django快速入门
Vue3中的provide/inject函数:实现组件间高级通信
下一篇
Vue3中的provide/inject函数:实现组件间高级通信
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    543次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    516次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    500次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    485次学习
查看更多
AI推荐
  • ChatExcel酷表:告别Excel难题,北大团队AI助手助您轻松处理数据
    ChatExcel酷表
    ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。
    3318次使用
  • Any绘本:开源免费AI绘本创作工具深度解析
    Any绘本
    探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。
    3529次使用
  • 可赞AI:AI驱动办公可视化智能工具,一键高效生成文档图表脑图
    可赞AI
    可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。
    3559次使用
  • 星月写作:AI网文创作神器,助力爆款小说速成
    星月写作
    星月写作是国内首款聚焦中文网络小说创作的AI辅助工具,解决网文作者从构思到变现的全流程痛点。AI扫榜、专属模板、全链路适配,助力新人快速上手,资深作者效率倍增。
    4681次使用
  • MagicLight.ai:叙事驱动AI动画视频创作平台 | 高效生成专业级故事动画
    MagicLight
    MagicLight.ai是全球首款叙事驱动型AI动画视频创作平台,专注于解决从故事想法到完整动画的全流程痛点。它通过自研AI模型,保障角色、风格、场景高度一致性,让零动画经验者也能高效产出专业级叙事内容。广泛适用于独立创作者、动画工作室、教育机构及企业营销,助您轻松实现创意落地与商业化。
    3935次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码