文章目录
背景
通过代码调用Stable Diffusion的txt2img、img2img接口时,很多时候都不知道应该怎么传参,比如如何指定模型、如何开启并使用Controlnet、如何开启面部修复等等,在sd-webui上F12看到的请求也不是正式调用SD的请求,所以当引入新插件或需要使用新功能时,怎么传参成了一个大问题,网上关于接口传参的资料也很少,接下来就介绍一下,如何在每次通过sd-webui点击生成图片时,获取到完整的请求参数。
开搞
需要使用到开源的项目:https://github.com/huchenlei/sd-webui-api-payload-display
里面只有几个文件,直接打包下载:
data:image/s3,"s3://crabby-images/c6083/c60838ea7d78efce99d5c25181d90f6fafc32706" alt=""
接下来需要做的工作很简单:
-
拷贝.js文件至sd-webui所在目录的javascript目录;
-
拷贝.py文件至sd-webui所在目录的script目录;
data:image/s3,"s3://crabby-images/f4249/f42497654f48dfa2947e70dad5b9087ded43ec16" alt=""
- 拷贝style.css中的内容,粘贴至sd-webui根目录下的style.css文件的末尾;(千万不能覆盖哦,是追加)
data:image/s3,"s3://crabby-images/23e4d/23e4d8fe0e1a61bda97b013f1860669b599ad4d0" alt=""
- 重启sd-webui
使用
打开sd-webui页面,可以看到多了一个按钮
data:image/s3,"s3://crabby-images/cd068/cd0684fa8e9c196f0949a1a9d7a3c3081392a0a7" alt=""
展开就能看到所有的请求参数了
data:image/s3,"s3://crabby-images/c6c9a/c6c9aa605b79cc8e5533644793e37d2e1bbf628d" alt=""
当然,如果要复制所有json的话,可以点击API payload旁边的Copy按钮,会自动复制所有内容。
data:image/s3,"s3://crabby-images/fc186/fc186011165fd199dc059343b1c7e235b53c2a4e" alt=""
遇到的问题
点击Copy按钮时,复制失败,显示:Failed to copy
data:image/s3,"s3://crabby-images/b3a2d/b3a2d9e03f35101a4f1f77ad1b435aed466c1511" alt=""
原因可以认为是js中的代码被浏览器的安全机制拦截了,打开浏览器控制台可以看到:
Cannot read properties of undefined (reading 'writeText')
data:image/s3,"s3://crabby-images/a58bf/a58bf675722483c506cf941cdefc88b0d306f48c" alt=""
可以参考这篇文章解决:Enable the "Insecure origins treated as secure" setting
我用的是HTTP,所以看这一段就行
data:image/s3,"s3://crabby-images/7d7da/7d7da0f46f0be2ae471896a4d5f25c90b6423e53" alt=""
主要就是4步解决:
data:image/s3,"s3://crabby-images/9ca15/9ca15d12e49e87aba5298d58411128ef8de43bbf" alt=""