新手向,Stable Diffusion API 接口,在本地调用
AI魔法学院
2023-11-10
分享海报

首先应该有本地部署好的 WEB-UI

启动项目时打开API接口。

如果你是在Gitcopy的项目,在启动web-ui.bat时加上--api的启动参数.

如果是使用秋叶大佬的整合包,请勾选

以及

在这里设置随意用户名和密码。

之后启动Web-UI,确认成功启动。

python脚本里构建request请求,使用POST,尝试请求图片:

import requests

url = "http://127.0.0.1:7860"

payload = {

    "prompt": "puppy dog",

    "steps": 5

}

response = requests.post(url=f'{url}/sdapi/v1/txt2img', json=payload)

r = response.json()

print(r)

如果print出来的结果是一大长串乱码,说明请求成功,这些乱码其实就是图片文件,具体如何转码见下文。

如果结果是:{'detail': 'Not authenticated'}

那么你应该是用的一键启动包进行登录,或是在别的地方设置了用户名和密码,解决方法如下:

启动web-ui后访问  http://localhost:7860/docs

找到这一条:

点开之后是这样的:

点击右上角的 Try it out 按钮,

直接点击Excute提交,网站会弹出让你登录的窗口,输入自己设置的用户名密码即可。

登录后,如果它向你返回的是这样的信息:

说明你已经验证成功了。

接着按F12,开发者工具。

在保持开发者工具打开的情况下,再次点Excute

你会在里面看到,有一个POST请求,点开之后长这样,注意我箭头标出来的这个值:

把他复制下来,在你的Python代码里加上如下一行:

headers = {

    "Authorization": "(里面填写你复制的值,如Basic YWFhYTphYWFh"

}

并且在提交请求的时候,后面加上headers的提交:

response = requests.post(url=f'{url}/sdapi/v1/txt2img', json=payload, headers=headers)

再运行,你就可以成功请求到图片。

当你成功请求图片后,进行如下处理:

r = response.json()

for i in r['images']:

    image = Image.open(io.BytesIO(base64.b64decode(i.split(",", 1)[0])))

    image.save('output.png')

记得在前面加上相应的import

import io

import base64

from PIL import Image

启动,如果成功运行,你就可以在项目目录中看到狗狗的图片,名字叫output.png

在发送请求时,payload里面的值是重点,如果用过sd的应该都比较熟悉了.

这里面大部分都不是必填项,具体每一项的意思,都比较明显,和WebUI里的一一对应,我就不再赘述了。

如果是不太了解json的萌新,可以只选择如下几项:

payload = {

    "prompt": "puppy dog", # 正面提示词

    "negative_prompt": "wrong hands", # 负面提示词

    "steps": 20  # 步数

}

基本可选参数如下(请自行修改每项的值,如TrueFalse的大小写,string替换成的内容):

payload = {

  "enable_hr": false,

  "denoising_strength": 0,

  "firstphase_width": 0,

  "firstphase_height": 0,

  "hr_scale": 2,

  "hr_upscaler": "string",

  "hr_second_pass_steps": 0,

  "hr_resize_x": 0,

  "hr_resize_y": 0,

  "prompt": "",     #  提示词

  "styles": [

    "string"

  ],

  "seed": -1,

  "subseed": -1,

  "subseed_strength": 0,

  "seed_resize_from_h": -1,

  "seed_resize_from_w": -1,

  "sampler_name": "string",

  "batch_size": 1,

  "n_iter": 1,

  "steps": 50,

  "cfg_scale": 7,

  "width": 512,

  "height": 512,

  "restore_faces": false,

  "tiling": false,

  "do_not_save_samples": false,

  "do_not_save_grid": false,

  "negative_prompt": "string",     #  负面提示词

  "eta": 0,

  "s_churn": 0,

  "s_tmax": 0,

  "s_tmin": 0,

  "s_noise": 1,

  "override_settings": {},

  "override_settings_restore_afterwards": true,

  "script_args": [],

  "sampler_index": "Euler",

  "script_name": "string",

  "send_images": true,

  "save_images": false,

  "alwayson_scripts": {}

}

也有更多的可选请求,比较了解http请求和Json数据的老哥请自行访问 ​​​​​http://localhost:7860/docs/

© THE END

转载请联系本网站获得授权

投稿或版权问题请加微信:skillupvip