Fastadmin中使用百度翻译API

在Fastadmin中对接使用百度翻译API

目录

对接使用百度翻译API

使用前准备

项目集成

创建配置文件

封装API请求

调用

总结


对接使用百度翻译API

使用前准备

需要注册百度账号,也可以使用原有的百度账号登录。

在开发者中心找到APPid和密钥,以备开发使用。

项目集成

创建配置文件

在application/extra/中创建translate.php文件。

内容如下:

php 复制代码
<?php
/**
 * 百度翻译API配置文件
 * 文档标注:appid + apikey | 控制台实际:APPID + Secret Key(二者等价)
 * 复制位置:百度翻译开放平台 → 开发者中心 → 申请者信息
 */
return [
    // 你的控制台APPID
    'baidu_appid'    => '你的控制台APPID',
    // 百度翻译密钥
    'baidu_secret'   => '百度翻译密钥'
];
封装API请求

在application/common/service目录下创建Translate.php文件,内容如下:

php 复制代码
<?php
/**
 * FastAdmin 百度翻译通用文本API封装类
 * 支持:单文本翻译
 * 适配:百度翻译通用文本API(个人认证免费版)
 * 依赖:FastAdmin内置httpRequest函数(无需额外扩展curl)
 */
namespace app\common\service;

use think\Exception;

class Translate
{
    // 百度翻译通用文本API接口地址
    private const API_URL = 'http://api.fanyi.baidu.com/api/trans/vip/translate';
    // 百度翻译APPID
    private $appid;
    // 百度翻译秘钥
    private $secretKey;

    /**
     * 构造方法:初始化配置+校验密钥
     * 从extra/translate.php读取配置,避免硬编码
     * @throws Exception
     */
    public function __construct()
    {
        // 读取配置文件中的百度翻译密钥
        $this->appid = config('translate.baidu_appid');
        $this->secretKey = config('translate.baidu_secret');

        // 密钥校验,无配置直接抛异常
        if (empty($this->appid) || empty($this->secretKey)) {
            throw new Exception('请先在application/extra/translate.php配置百度翻译appid和secretKey');
        }
    }

    /**
     * 【基础方法】单文本翻译(百度通用API核心)
     * @param string $text 待翻译文本
     * @param string $from 源语言(auto=自动检测,百度官方默认)
     * @param string $to 目标语言(en=英文/ja=日语/ko=韩语/fr=法语,参考百度官方语言码)
     * @return string 翻译后的纯文本
     * @throws Exception
     */
    public function translateText(string $text, string $from = 'auto', string $to = 'en'): string
    {
        $text = trim($text);
        if (empty($text)) {
            return '';
        }

        // 必要参数
        $salt = rand(32768, 65536); // 随机盐值
        $signStr = $this->appid . $text . $salt . $this->secretKey; // 签名原串
        $sign = md5($signStr); // MD5签名

        $params = [
            'q'     => $text,
            'from'  => $from,
            'to'    => $to,
            'appid' => $this->appid,
            'salt'  => $salt,
            'sign'  => $sign
        ];

        $response = \fast\Http::get(self::API_URL, $params);
        if (empty($response)) {
            throw new Exception('百度翻译API请求失败,无返回数据');
        }

        $result = json_decode($response, true);
        if (json_last_error() !== JSON_ERROR_NONE) {
            throw new Exception('百度翻译API返回格式错误,非有效JSON');
        }

        // 5. 捕获百度API官方错误(关键:方便排查配置/调用问题)
        if (isset($result['error_code'])) {
            $errorMsg = $result['error_msg'] ?? '未知错误';
            throw new Exception("百度翻译失败【错误码:{$result['error_code']}】:{$errorMsg}");
        }

        return $result['trans_result'][0]['dst'] ?? '';
    }
}
调用
php 复制代码
$text = (new Translate())->translateText('中文');
print_r($text);die;

总结

项目功能实现中需要使用翻译实现,整理了百度翻译API使用。

相关推荐
JaguarJack2 天前
告别 Laravel 缓慢的 Blade!Livewire Blaze 来了,为你的 Laravel 性能提速
后端·php·laravel
郑州光合科技余经理2 天前
代码展示:PHP搭建海外版外卖系统源码解析
java·开发语言·前端·后端·系统架构·uni-app·php
QQ5110082852 天前
python+springboot+django/flask的校园资料分享系统
spring boot·python·django·flask·node.js·php
WeiXin_DZbishe2 天前
基于django在线音乐数据采集的设计与实现-计算机毕设 附源码 22647
javascript·spring boot·mysql·django·node.js·php·html5
longxiangam2 天前
Composer 私有仓库搭建
php·composer
上海云盾-高防顾问2 天前
DNS异常怎么办?快速排查+解决指南
开发语言·php
ShoreKiten2 天前
关于解决本地部署sqli-labs无法安装低版本php环境问题
开发语言·php
liliangcsdn2 天前
深入探索TD3算法的推理过程
开发语言·php
troublea3 天前
ThinkPHP vs Laravel:PHP框架终极对决
开发语言·php·laravel
苏天夏3 天前
Passport 插件:Typecho 密码安全的技术守护者
安全·网络安全·php