登录 立即注册

首页 > 绿虎论坛 > 网页插件 (发帖)

[网页插件] hu60bot: 立即与openai 对话


『回复列表(128|隐藏机器人聊天)』

80.

@老虎会游泳,为什么一个超速,其他用户无法连接?

(/@Ta/2023-03-30 10:13//)

81.

哦,明白了。超速限制是 php 实现的,不是 nginx ,所以hu60bot也需要实现

(/@Ta/2023-03-30 10:15//)

82.

@rkonfj,我还有一个建议,你可以在HTTP请求中添加头信息,把速率限制转移给单个用户。

比如,把用户的真实IP填充在HTTP_CF_CONNECTING_IP里,然后我在hu60 api里添加真实IP判断。

这个头信息的名称要可自定义,因为我不想让别人猜到来伪造IP记录。

/**
 * 特定IP判定范围
 */
$CC_IP_LIMIT = [
    // 设置特定IP n秒最多能访问的次数
    '127.0.0.1' => 100,
];

/**
 * 真实IP
 */

// 无代理时使用
$CC_REAL_IP = $_SERVER['REMOTE_ADDR'];

// 采用CloudFlare或百度云加速代理时使用
#$CC_REAL_IP = $_SERVER['HTTP_CF_CONNECTING_IP'];
(/@Ta/2023-03-30 10:17//)

83.

@rkonfj,因为现在的超速都算在127.0.0.1头上了,所以大家都连不上。把真实IP填充在头信息里,我就可以把限速算在具体用户头上了。

(/@Ta/2023-03-30 10:18//)

84.

@老虎会游泳,我还不太理解。你现在的架构应该是 nginx 转发流量到 php-fpmhu60bot 吧?

  1. 你可以在HTTP请求中添加头信息,把速率限制转移给单个用户。

怎么加头信息?作为服务端是读取请求头吧?如果是在 nginx 之后,反代的时候 把网络的真实 ip 放在 x-real-ip 中,hu60bot 可以拿到了不是吗?

  1. 因为现在的超速都算在127.0.0.1头上了,所以大家都连不上。把真实IP填充在头信息里,我就可以把限速算在具体用户头上了。

你的超速不是 php 实现的吗?怎么会阻止 websocket 连接?

(/@Ta/2023-03-30 10:28//)

85.

@rkonfj,这里达到了限速,所以没有人可以认证通过。顺便一提 udSySELORQDee6_Jxv-YPMEAsAAA 已经被我设为无效了,所以公开也没关系。

		// 获取sid(跨域时禁用cookie)
		sid := getRequestParam(r, "sid", noCookie)
		if sid == "" || sid == "udSySELORQDee6_Jxv-YPMEAsAAA" {
			m.responseUnauthenticated(ws)
			logrus.Warn("authentication failed: sid not found")
			return
		}

        // 这里达到了限速
		res, err := m.hu60Client.GetProfile(context.Background(), sid)
		if err != nil {
			m.responseUnauthenticated(ws)
			logrus.Warn("authentication failed: ", err.Error())
			return
		}
(/@Ta/2023-03-30 10:38//)

86.

@rkonfj

你可以在HTTP请求中添加头信息,把速率限制转移给单个用户。

图片.png(56.18 KB)

(/@Ta/2023-03-30 10:39//)

87.

@老虎会游泳,明白了。

真实 IP 那个,可以从 nginx 传到 后端 吗?用 IP 来限速好点

(/@Ta/2023-03-30 10:39//)

88.

@rkonfj,如果http.NewRequestWithContext(ctx, http.MethodGet, c.fullURL("/user.index.json")不传递IP,nginx显然不知道用户的IP是什么。

(/@Ta/2023-03-30 10:40//)

89.

@rkonfj,所以我们需要req.Header.Set(一个自定义头信息的变量, 用户的真实IP)

(/@Ta/2023-03-30 10:41//)

90.

@rkonfj,是hu60bot访问了/user.index.json,不是用户访问了/user.index.json,nginx不可能神奇的感知到背后的用户IP是什么。

(/@Ta/2023-03-30 10:42//)

91.

@老虎会游泳,明白了,你说的是 hu60bot 请求 hu60api 时的 ip。我会加一个参数,由管理员来指定这个头的 key, value就是用户的IP。这样hu60bot就可以在这个 api 报超速时,返回ws客户端超速对吧?

hu60bot怎么拿到客户端真实IP?x-real-ip 可以吗?

(/@Ta/2023-03-30 10:47//)

92.

@rkonfjhu60bot怎么拿到客户端真实IP:目前是以下头信息,但我建议不要假定管理员开了代理,首先使用remote addr。除非管理员指定了一个头信息参数,再使用它。

        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header REMOTE-HOST $remote_addr;
(/@Ta/2023-03-30 10:54//)

93.
(/@Ta/2023-03-30 10:54//)

94.

@rkonfj

我会加一个参数,由管理员来指定这个头的 key, value就是用户的IP。这样hu60bot就可以在这个 api 报超速时,返回ws客户端超速对吧?

是的。

(/@Ta/2023-03-30 10:55//)

95.

@老虎会游泳,api 超速时返回的也是 HTML 吗?

(/@Ta/2023-03-30 10:57//)

96.

@rkonfj,我可以添加一个功能来返回JSON

(/@Ta/2023-03-30 10:59//)

97.

@rkonfj,目前有一个头信息:

	header('HTTP/1.1 503 Service Unavailable');
    header('Retry-After: '.$needWaitSeconds);
(/@Ta/2023-03-30 11:00//)

98.

@老虎会游泳,超速后会出现 Retry-After 响应头的话,那没必要再返回 JSON 了

(/@Ta/2023-03-30 11:02//)

99.

@rkonfj,所有 api 都是这样的吧

(/@Ta/2023-03-30 11:02//)

下一页 上一页 5/7页,共128楼

回复需要登录

11月24日 15:58 星期天

本站由hu60wap6华为CPU驱动

备案号: 京ICP备18041936号-1