Typora设置自动上传图片到图床

Typora设置自动上传图片到图床

方法一:使用php

打开设置界面:

自定义命令:

复制代码
php F:/WWW/php-library/TyporaUploadImage.php  ${filename}

php代码:

php 复制代码
# TyporaUploadImage.php
<?php
// Set the API endpoint URL
// $apiUrl = 'https://sm.ms/api/v2/upload';
$apiUrl = 'https://picui.cn/api/v1/upload';

// Set the API authorization header
// https://picui.cn/user/tokens bruce
$apiKey = '252|3n7rfRxagShT73kuJ8vNFrWpkd5XYsSH5uxxxx';  //这里输入你自己的apiKey
$headers = array(
    'Authorization:Bearer ' . $apiKey,
    'Accept: application/json',
    'Content-Type: multipart/form-data'
);

// Check if there are any image paths provided
if (count($argv) > 1) {
    echo "Upload Success:\n";
    for ($i = 1, $iMax = count($argv); $i < $iMax; $i++) {
        $imagePath = $argv[$i];
        $imageFileName = basename($imagePath);

        // Create the request data
        $data = array(
            'file' => new CURLFile($imagePath, mime_content_type($imagePath), $imageFileName)
        );

        // Initialize the cURL request
        $curl = curl_init($apiUrl);
        curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
        curl_setopt($curl, CURLOPT_HTTPHEADER, $headers);
        curl_setopt($curl, CURLOPT_POST, true);
        curl_setopt($curl, CURLOPT_POSTFIELDS, $data);
        curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false);
        curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);

        // Send the cURL request and get the response
        $response = curl_exec($curl);

        // Check for any cURL errors
        if (curl_errno($curl)) {
            echo 'cURL error (' . $i . '): ' . curl_error($curl) . "\n";
            continue;
        }

        // Decode the JSON response
        $responseData = json_decode($response, true);

        // Check if the upload was successful
        if ($responseData['status']) {
            echo $responseData['data']['links']['url'] . "\n";
        } else {
            echo 'Error (' . $i . '): ' . $responseData['message'] . "\n";
        }

        // Close the cURL connection
        curl_close($curl);
    }
} else {
    echo "Usage: php script.php <image_path1> <image_path2> ...\n";
}
?>

做完这些以后就能自动上传图片了,上面这个方法需要本地有php应用程序。

方法二:使用powershell

如果没有php程序,就直接使用windows自带的powershell吧:

复制代码
powershell -File F:/WWW/php-library/TyporaUploadImage.ps1 ${filename}

代码内容:

powershell 复制代码
# TyporaUploadImage.ps1
# 设置 API 端点 URL 和 API 密钥
$apiUrl = "https://picui.cn/api/v1/upload"
$apiKey = "252|3n7rfRxagShT73kuJ8vNFrWpkd5XYsSH5uzhQxx"

# 设置 HTTP 头
$headers = @{
    "Authorization" = "Bearer $apiKey"
    "Accept" = "application/json"
}

# 检查是否提供了图片路径
if ($args.Count -eq 0) {
    Write-Host "Usage: script.ps1 <image_path1> <image_path2> ..."
    exit
}

Write-Host "Upload Success:"

foreach ($imagePath in $args) {
    # 检查文件是否存在
    if (-Not (Test-Path $imagePath)) {
        Write-Host "Error: File '$imagePath' does not exist."
        continue
    }

    # 获取文件名和 MIME 类型
    $imageFileName = [System.IO.Path]::GetFileName($imagePath)
    $mimeType = Get-Content -Path $imagePath -AsByteStream | 
        . { New-Object System.IO.MemoryStream($_) } |
        . { Add-Type -AssemblyName System.Drawing; New-Object System.Drawing.Bitmap($_) } |
        . { $_.RawFormat.ToString() }

    # 创建 POST 数据
    $boundary = [System.Guid]::NewGuid().ToString()
    $contentType = "multipart/form-data; boundary=$boundary"

    $formData = @"
--$boundary
Content-Disposition: form-data; name="file"; filename="$imageFileName"
Content-Type: $mimeType

$(Get-Content -Raw -Path $imagePath)
--$boundary--
"@

    # 发送 HTTP POST 请求
    try {
        $response = Invoke-RestMethod -Uri $apiUrl -Method Post -Headers $headers -ContentType $contentType -Body $formData
        if ($response.status -eq $true) {
            Write-Host $response.data.links.url
        } else {
            Write-Host "Error: " $response.message
        }
    } catch {
        Write-Host "Error uploading file '$imagePath': $_"
    }
}
相关推荐
奥陌陌3 小时前
android 打印函数调用堆栈
android
用户985120035833 小时前
Compose Navigation 3 深度解析(二):基础用法
android·android jetpack
恋猫de小郭3 小时前
Android 官方正式官宣 AI 支持 AppFunctions ,Android 官方 MCP 和系统级 OpenClaw 雏形
android·前端·flutter
黄林晴4 小时前
Android 17 Beta 2,隐私这把锁又拧紧了
android
Kapaseker4 小时前
研究表明,开发者对Kotlin集合的了解不到 20%
android·kotlin
bqliang4 小时前
Compose 媒体查询 (Media Query API) 🖱️👇🕹️
android·android jetpack
程序员陆业聪13 小时前
Android 平台 AI Agent 技术架构深度解析
android·人工智能
BD_Marathon18 小时前
工厂方法模式
android·java·工厂方法模式
王码码203519 小时前
Flutter for OpenHarmony:socket_io_client 实时通信的事实标准(Node.js 后端的最佳拍档) 深度解析与鸿蒙适配指南
android·flutter·ui·华为·node.js·harmonyos
勇气要爆发19 小时前
吴恩达《LangChain LLM 应用开发精读笔记》2-Models, Prompts and Parsers 模型、提示和解析器
android·笔记·langchain