首先应该有本地部署好的 WEB-UI。
启动项目时打开API接口。
如果你是在Git上copy的项目,在启动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 # 步数
}
基本可选参数如下(请自行修改每项的值,如True或False的大小写,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/