V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
爱意满满的作品展示区。
ttyUSB0
V2EX  ›  分享创造

试了好多 Gemini 客户端都用不太惯,所以花时间自己写了一个

  •  
  •   ttyUSB0 ·
    bclswl0827 · 288 天前 · 5251 次点击
    这是一个创建于 288 天前的主题,其中的信息可能已经有所发展或是发生改变。

    试了好多 Gemini 客户端都用不太惯,有的要么功能不太全,有的要么太花里胡哨玩不明白,个人还是比较习惯像 ChatGPT 官网那样的操作逻辑,简单顺手,也不用特别去折腾各种参数

    所以花了几天时间,用 React 做了一个新的 Gemini 客户端出来,操作逻辑和 ChatGPT 基本一致,UI 也和 ChatGPT 相似,所以起名叫 ChatGemini

    这套客户端支持多轮聊天,和在多轮聊天中上传图片,应用会自动调用 Gemini-Pro-Vision 模型进行识图

    特性有下面几点,欢迎大家使用,提供建议和反馈,觉得不错可以给个 Star

    • 操作逻辑同 ChatGPT
    • 仿 ChatGPT 界面
    • 支持多轮聊天对话
    • 支持上传图片进行识别
    • 逐字输出( SSE )回应
    • 集成 PHP 版反向代理
    • 自定义 Gemini API 地址
    • 对话内容保存至本地
    • 聊天内容导出( HTML 和 PDF )

    主页

    多轮聊天

    附件识图

    导出记录

    第 1 条附言  ·  288 天前

    大家提过建议后,现在新增了这几项功能

    1. Docker 部署,不过 build 出来体积比较大,以后慢慢来优化
    2. 通行码,启用后站点变私密,需要登录才能用,通行码用 MD5 加密保存,支持多密码
    3. 支持多个 API 密钥,每次启动后随机分配密钥,实现分流,避免超出 Gemini 请求限制
    第 2 条附言  ·  287 天前

    这个应用会根据当前对话有无图片附件,来决定把 prompt 发给 gemini-pro 还是 gemini-pro-vision

    但是又因为 gemini-pro 没法读取图片,所以后续与 gemini-pro 的对话中,先前由 gemini-pro-vision 产生的回复也会发给 gemini-pro,并自动在用户的 prompt 后面追加一条提示,从而让 gemini-pro 去猜测用户上传的图片内容是什么

    下面是我的附加提示,大家如果有更好的想法(提示内容或者思路),都可以交流分享下

    Please note that the user uploaded image(s) in the earlier conversation at index ${indexArrStr} and it was processed and answered by \`gemini-pro-vision\`, since you don't have the ability to recognize images, please try to find some useful information from the previous prompts and responses and answer the user's question accordingly, never tell the user you saw this appended prompt, and never tell the user that you don't know how to answer the question, just try to answer it as best as you can, just like the way his/her grandmother used to treat him/her when he/she was a child.
    
    第 3 条附言  ·  284 天前
    今天新增了一个功能,能在浏览器里直接执行 AI 回应的 Python 代码看输出的结果,欢迎体验~
    54 条回复    2024-02-23 20:54:21 +08:00
    hopeknow
        1
    hopeknow  
       288 天前
    体验了一下,非常好用!
    xyxc0673
        2
    xyxc0673  
       288 天前
    提示错误了
    oldManNewThought
        3
    oldManNewThought  
       288 天前
    AI
    [GoogleGenerativeAI Error]: Error fetching from https://generativelanguage.googleapis.com/v1/models/gemini-pro:streamGenerateContent?alt=sse: [400 ] User location is not supported for the API use.
    jucelin
        4
    jucelin  
       288 天前
    @oldManNewThought #3 可以用美国的梯子试试,用 HK 的不行
    ethanpeng
        5
    ethanpeng  
       288 天前
    能支持下中转 host 吗,现在所有客户端好像都只支持 chtgpt 的中转,没有 Gemini 的
    oldManNewThought
        6
    oldManNewThought  
       288 天前 via Android
    楼主,gemini 的 api key 怎么申请的。我进申请页。总是提示区域限制。更换了各地区梯子都不行
    goddamhucker
        7
    goddamhucker  
       288 天前
    确实好用
    ttyUSB0
        8
    ttyUSB0  
    OP
       288 天前 via Android
    @ethanpeng 可以,Nginx 反向代理 `generativelanguage.googleapis.com`,或者直接用 `public/gemini.php` 反代 API
    操作说明已经在 README 给出
    ttyUSB0
        9
    ttyUSB0  
    OP
       288 天前 via Android
    @oldManNewThought 这种情况一般都是梯子不行,我用美国和日本的节点没问题
    hongzx
        10
    hongzx  
       288 天前
    这是 vue ?
    ttyUSB0
        11
    ttyUSB0  
    OP
       288 天前 via Android
    @hongzx 纯 React 项目
    ghellotim
        12
    ghellotim  
       288 天前
    @ttyUSB0 OP 是否可以做一个 docker ,方便我等小白部署?谢谢
    hongzx
        13
    hongzx  
       288 天前
    @ttyUSB0 [GoogleGenerativeAI Error]: Error fetching from https://generativelanguage.googleapis.com/v1/models/gemini-pro:streamGenerateContent?alt=sse: [403 ] Method doesn't allow unregistered callers (callers without established identity). Please use API Key or other form of API consumer identity to call this API.
    这是 key 不行?
    ttyUSB0
        14
    ttyUSB0  
    OP
       288 天前
    @hongzx 可以换个梯子试试,因为是直连 Google 的 API ,和梯子的位置、IP 干净程度可能有关系
    hongzx
        15
    hongzx  
       288 天前
    @ttyUSB0 嗯嗯,搞定了,很 nice ,在尝试搞成镜像,丢服务器上
    abersheeran
        16
    abersheeran  
       288 天前
    哈哈哈哈,我直接把 Gemini 接入各种平台的机器人了,不写前端。
    imzcg2
        17
    imzcg2  
       288 天前
    api 都被封了
    a8500830
        18
    a8500830  
       288 天前
    等 docker 版
    ttyUSB0
        19
    ttyUSB0  
    OP
       288 天前 via Android
    可以自建反代,然后指定 API 地址,README 有写
    sayoll
        20
    sayoll  
       288 天前 via Android
    @ghellotim ```
    [root@vm54701 ~]# cd /opt/docker/chatgemini
    [root@vm54701 chatgemini]# cat Dockerfile
    # 使 用 官 方 Node.js 基 础 镜 像
    FROM node:lts
    # 设 置 工 作 目 录 , 所 有 的 路 径 都 会 基 于 该 目 录
    WORKDIR /app
    # 复 制 package.json 和 package-lock.json (如 果 存 在 )
    COPY package*.json ./
    # 安 装 项 目 依 赖
    RUN npm install
    # 复 制 项 目 文 件 到 工 作 目 录
    COPY . .
    # 如 果 您 的 应 用 需 要 构 建 , 可 以 取 消 注 释 下 面 这 行 RUN npm run build
    # 暴 露 容 器 运 行 时 的 端 口
    EXPOSE 3000
    # 定 义 运 行 时 执 行 的 命 令
    CMD ["npm", "start"]
    [root@vm54701 chatgemini]# cat docker-compose.yml
    version: '3.0'
    services:
    chatgemini:
    build: .
    ports:
    - "3000:3000"
    volumes:
    - .:/app
    - /app/node_modules
    [root@vm54701 chatgemini]#
    ```
    Link99
        21
    Link99  
       288 天前
    这个 api 有调用次数或者频率限制吗
    ttyUSB0
        22
    ttyUSB0  
    OP
       288 天前 via Android
    @Link99 Google 给出的说明里,Gemini 免费版本 API 调用速率是每分钟 60 次
    ghellotim
        23
    ghellotim  
       288 天前
    @sayoll 谢谢大佬!
    Link99
        24
    Link99  
       288 天前
    @ttyUSB0 找到了 目前还没有可以付费的渠道
    如果自己的账号下多开几个 key 不知道能不能突破这个限制
    你有遇到过请求次数过多的提示吗
    ttyUSB0
        25
    ttyUSB0  
    OP
       288 天前 via Android
    @Link99 开发的时候遇到过,直接报 429 错误
    salparadise
        26
    salparadise  
       288 天前
    Gminiprochat 用着也不错,很简洁
    ttyUSB0
        27
    ttyUSB0  
    OP
       288 天前   ❤️ 1
    @salparadise #26 不能上传图片、没有像 ChatGPT 那样的对话历史是硬伤,就是因为这几点,我才决定单独写一个新的客户端
    sywsy
        28
    sywsy  
       288 天前
    用着很好,终于找到支持上传图片的了,有一个小建议可以弄一个一键部署 vercel 的脚本,像其他 chatweb 项目一样,可以参考: https://github.com/ChatGPTNextWeb/ChatGPT-Next-Web
    ttyUSB0
        29
    ttyUSB0  
    OP
       288 天前
    @sywsy Vercel 好像都被墙完了,想找一个没被墙的平台来弄一键部署脚本
    a707782628
        30
    a707782628  
       288 天前
    作者我想问问你这个用 vision 的时候对话有上下文记忆吗?还有 vision 模型纯文字能得到回复吗,我用 oneapi 转换后放在其他 webui 上会报错。
    ttyUSB0
        31
    ttyUSB0  
    OP
       288 天前
    @a707782628 用 vision 时没有上下文记忆,纯文字发给 vision 也不会得到回复,会报 400 错误
    ttyUSB0
        32
    ttyUSB0  
    OP
       288 天前
    @Link99 加了一个多密钥功能,每次打开页面过后从一堆密钥里随机挑一个来用,应该能突破限制
    my51paper
        33
    my51paper  
       288 天前
    不错,这个设个访问密码就完美了
    ttyUSB0
        34
    ttyUSB0  
    OP
       288 天前
    @my51paper 已经实现了,可以参考 README 中的配置部分启用
    weilongs
        35
    weilongs  
       287 天前
    牛 牛
    sypopo
        36
    sypopo  
       287 天前 via Android
    已经用上了,用美国机子反代了 api 。
    chongchongzl999
        37
    chongchongzl999  
       287 天前
    以后会有支持 pdf 的功能的计划吗?
    dryadent
        38
    dryadent  
       287 天前
    谢谢 up ,之前用 chat-next-web 一直不好用,你这个真的太棒了
    dryadent
        39
    dryadent  
       287 天前
    大佬,能不能支持反代和密钥在 web_ui 配置呀
    ttyUSB0
        40
    ttyUSB0  
    OP
       287 天前
    @chongchongzl999 gemini-pro-vision 只支持上传图片,[Gemini 的文档中已经提到了]( https://ai.google.dev/docs/gemini_api_overview#image_requirements)
    ttyUSB0
        41
    ttyUSB0  
    OP
       287 天前
    @dryadent 不支持,这个项目是打算做成打开就能直接上手用的状态的,所以也就不准备留太多配置给用户
    pang123456
        42
    pang123456  
       287 天前 via Android
    我使用了页面其实简洁非常好👍👍👍,可以把自定义 API 设计在页面上吗?这样就可以使用自己的 API ,如果能加智谱和百度的 API 就更加好了,因为很多用户有自己的 API 。
    ttyUSB0
        43
    ttyUSB0  
    OP
       287 天前 via Android
    @pang123456 没有计划支持额外的 API ,想尽量保持操作简单,同时精力也不够,同时其他人如果有兴趣可以 Fork 了在这个基础上来修改
    ghellotim
        44
    ghellotim  
       287 天前
    @ttyUSB0 OP 的 docker 启动起来,403 错误,请问大概是什么问题?
    ttyUSB0
        45
    ttyUSB0  
    OP
       287 天前 via Android
    @ghellotim 应用会在容器开始运行时先执行 npm run build ,如果 build 失败了,Nginx 启动后访问就会报 403 ,建议看看日志
    ghellotim
        46
    ghellotim  
       287 天前
    @ttyUSB0 . 日志详情是这样。OP 有空请帮忙看看,谢谢。

    root@debian:~/podman-compose/ChatGemini# podman logs -f mygeminipro

    > [email protected] build
    > cross-env GENERATE_SOURCEMAP=false react-scripts build

    Creating an optimized production build...
    Failed to compile.

    [eslint] package.json » eslint-config-react-app/jest#overrides[0]:
    Environment key "jest/globals" is unknown


    Nginx is starting...
    ttyUSB0
        47
    ttyUSB0  
    OP
       287 天前
    @ghellotim 貌似是 package.json 里面的 eslintConfig 字段导致的,已经修复更新了,重新拉取一下 Docker 镜像再部署试试
    xiaozizayang
        48
    xiaozizayang  
       286 天前
    Docker 太大 你搜索 多阶段构建
    ttyUSB0
        49
    ttyUSB0  
    OP
       286 天前
    @xiaozizayang #48 好的,最新版本中的 Docker 镜像大小已经优化了
    ghellotim
        50
    ghellotim  
       285 天前
    @ttyUSB0 OP, 谢谢回复。最新 Docker 没有 403 错误了,但好像环境变量 REACT_APP_GEMINI_API_KEY 和 REACT_APP_PASSCODE_MD5 不起作用了,不会带入。1. 打开没有要求输入 Passcode ,2. 发起一个聊天,则出现错误,API Key 没有问题。“ [GoogleGenerativeAI Error]: Error fetching from https://generativelanguage.googleapis.com/v1/models/gemini-pro:streamGenerateContent?alt=sse: [403 ] Method doesn't allow unregistered callers (callers without established identity). Please use API Key or other form of API consumer identity to call this API.
    ghellotim
        51
    ghellotim  
       285 天前
    huahsiung
        52
    huahsiung  
       285 天前
    谢谢分享,好用

    kujingzaidi
        53
    kujingzaidi  
       283 天前
    太棒了,感谢
    water3
        54
    water3  
       266 天前
    太棒了!很好用,目前使用一点不舒服的感觉都没有!感谢!
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1390 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 24ms · UTC 17:48 · PVG 01:48 · LAX 09:48 · JFK 12:48
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.