Gradio Auth登录页设置中文

2024-03-14 05:50
文章标签 设置 登录 中文 gradio auth

本文主要是介绍Gradio Auth登录页设置中文,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最近入坑了gradio, 就是一款python框架,可以通过简单的几行代码,就能够帮我们构建一个简易的页面网站,并且可以在里面做相应的逻辑处理。目前该框架在AI领域相对比较火爆,用于给自己的大模型构建操作页面。

官网地址: Gradio

具体操作这里就暂不做介绍了,毕竟我也是新手。我也刚入坑两天。

今天主要介绍一下,昨晚搞到半夜一点遇到的一个问题。就是想做一个登录页面。

gradio 本身是提供了一个简单的登录页面的,我们只需要有一行代码配置就可以实现。

demo.queue(concurrency_count=3).launch(server_name='0.0.0.0',server_port=8082,show_api=False,share=False,inbrowser=False,auth=("zhangsan", '123456'),)

只需要在launch方法里加入auth=("zhangsan", '123456'), 即可,这样我们使用zhangsan/123456就可以登录了。 这里面也可以传入一个元组,配置多个。

登录页面长这样:

整体来说还不错,但是领导提出了新的要求,要把里面的英文都显示成中文。这可麻烦了,就开始大规模查找资料。

比如在github上有就有提出了,想要在登录页面加一个邮箱的需求:

https://github.com/gradio-app/gradio/issues/5073

得到的答案是这样的:

翻译过来:

就是可以通过FastAPI技术去实现,下面是demo

https://github.com/gradio-app/gradio/issues/2790

大概意思就是自己重新开发一套应用,然后和gradio的挂在到一起。看了一下,我觉得作为python新手的我,应该是搞不定的(毕竟连python语法都没搞明白)。

好了,铺垫的差不多了,我们接下来进入正题。我们修改的方法就是修改源码,重新编译。这里有一个非常重要的点,就是一定要编译和你当前版本一直的源码,否则会导致你的应用样式出现问题。尤其是有自定义css的,对于版本是十分敏感的,因为这个我踩了大坑,差点没出来。

先查下自己的gradio版本。

pip list

找到自己的gradio版本, 我的是3.37.0 。 之前由于没有注意观察这里,直接下载了main分支,导致登录页面是成功了,但是里面的样式全都乱了。最后才发现是版本不一致的问题。然后下载源码:

在tag中找到自己版本对应的代码; https://github.com/gradio-app/gradio/tags

然后下载,解压,使用vscode打开。 主要修改的文件为: js/app/src/Login.svelte

这里展示的修改后的效果,源码都是英文的。 这里其实就相当于是写死了。 其实也可以配置成变量。然后在同级目录的lang下面的i18n配置文件中给对应的变量赋值,这样就可以自动实现国际化了。

在新版本里,有几个值使用了变量的,比如提示语,但是像用户名密码都是写死的。

新版本中变量的写法,如果改成变量,一定记得在json中配置对应的值。其他语言也都加一下。

这样打开页面的时候gradio会根据浏览器当前的语言去解析对应的json文件,实现国际化。

好了,源码改好了,接下来就是重新编译了,这个步骤,就要参照CONTRIBUTING.md

在源码的根目录下有。编译之前要准备好相应环境。

然后按照上面的步骤,一个一个执行脚本。 后面有几个是测试的执行的时候可能会有报错,但完全不影响。执行完毕后,他不会生成对应的安装包,但是会把本地安装好的gradio做替换。我们重新打开我们的登录页面,就发现已经发生了变化。

搞定收工。

这种方式只不过也有一些缺陷,就是如果要在多台机器上进行部署,可能需要多次重复上述步骤。这个由于对python部署,不知道能不能把本地的以来打成一个包,直接拿到其他位置安装,有知道的也可以告知一下。

好了以上就是整个内容,整理不易,希望帮到有相同需求的人。一定要注意版本一定要保持一致哦!!

这篇关于Gradio Auth登录页设置中文的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/807396

相关文章

Go语言实现将中文转化为拼音功能

《Go语言实现将中文转化为拼音功能》这篇文章主要为大家详细介绍了Go语言中如何实现将中文转化为拼音功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 有这么一个需求:新用户入职 创建一系列账号比较麻烦,打算通过接口传入姓名进行初始化。想把姓名转化成拼音。因为有些账号即需要中文也需要英

Spring MVC如何设置响应

《SpringMVC如何设置响应》本文介绍了如何在Spring框架中设置响应,并通过不同的注解返回静态页面、HTML片段和JSON数据,此外,还讲解了如何设置响应的状态码和Header... 目录1. 返回静态页面1.1 Spring 默认扫描路径1.2 @RestController2. 返回 html2

四种简单方法 轻松进入电脑主板 BIOS 或 UEFI 固件设置

《四种简单方法轻松进入电脑主板BIOS或UEFI固件设置》设置BIOS/UEFI是计算机维护和管理中的一项重要任务,它允许用户配置计算机的启动选项、硬件设置和其他关键参数,该怎么进入呢?下面... 随着计算机技术的发展,大多数主流 PC 和笔记本已经从传统 BIOS 转向了 UEFI 固件。很多时候,我们也

Linux中chmod权限设置方式

《Linux中chmod权限设置方式》本文介绍了Linux系统中文件和目录权限的设置方法,包括chmod、chown和chgrp命令的使用,以及权限模式和符号模式的详细说明,通过这些命令,用户可以灵活... 目录设置基本权限命令:chmod1、权限介绍2、chmod命令常见用法和示例3、文件权限详解4、ch

python实现自动登录12306自动抢票功能

《python实现自动登录12306自动抢票功能》随着互联网技术的发展,越来越多的人选择通过网络平台购票,特别是在中国,12306作为官方火车票预订平台,承担了巨大的访问量,对于热门线路或者节假日出行... 目录一、遇到的问题?二、改进三、进阶–展望总结一、遇到的问题?1.url-正确的表头:就是首先ur

SpringBoot项目引入token设置方式

《SpringBoot项目引入token设置方式》本文详细介绍了JWT(JSONWebToken)的基本概念、结构、应用场景以及工作原理,通过动手实践,展示了如何在SpringBoot项目中实现JWT... 目录一. 先了解熟悉JWT(jsON Web Token)1. JSON Web Token是什么鬼

使用Spring Cache时设置缓存键的注意事项详解

《使用SpringCache时设置缓存键的注意事项详解》在现代的Web应用中,缓存是提高系统性能和响应速度的重要手段之一,Spring框架提供了强大的缓存支持,通过​​@Cacheable​​、​​... 目录引言1. 缓存键的基本概念2. 默认缓存键生成器3. 自定义缓存键3.1 使用​​@Cacheab

java如何调用kettle设置变量和参数

《java如何调用kettle设置变量和参数》文章简要介绍了如何在Java中调用Kettle,并重点讨论了变量和参数的区别,以及在Java代码中如何正确设置和使用这些变量,避免覆盖Kettle中已设置... 目录Java调用kettle设置变量和参数java代码中变量会覆盖kettle里面设置的变量总结ja

Security OAuth2 单点登录流程

单点登录(英语:Single sign-on,缩写为 SSO),又译为单一签入,一种对于许多相互关连,但是又是各自独立的软件系统,提供访问控制的属性。当拥有这项属性时,当用户登录时,就可以获取所有系统的访问权限,不用对每个单一系统都逐一登录。这项功能通常是以轻型目录访问协议(LDAP)来实现,在服务器上会将用户信息存储到LDAP数据库中。相同的,单一注销(single sign-off)就是指

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取