gitlab类 ls方法及getCommitsByPath方法的错误

回贴
回帖数 5
阅读数 1145
发表时间 2021-09-23 13:16:29
📗
momo 楼主

class gitlab {

        // ...

    public function ls($path, $revision = 'HEAD')
    {
        // ...

        $infos = array();
        foreach($list as $file)
        {
            if(!isset($file->type)) continue;

            $info = new stdClass();
            $info->name = $file->name;
            $info->kind = $file->type == 'blob' ? 'file' : 'dir';

            if($file->type == 'blob')
            {
                $file = $this->files($file->path, $this->branch);

                $info->revision = zget($file, 'revision', '');
                $info->comment  = zget($file, 'comment', '');
                $info->account  = zget($file, 'committer', '');
                $info->date     = zget($file, 'date', '');
                $info->size     = zget($file, 'size', '');
            }
            else
            {

               // <<=============================

              // 在 getCommitsByPath()方法中会使用 urldecode解码, 但是传的参数确没有urlencode编码, 

              // 如此会导致 请求gitlab时, 使用错误的路径. 比如 $file->path = 'xxx+xxx' , 把这个+号直接替换成空格了, 

              // 再比如 $file->path = '%xx%xx' , 这是一个合法的名字, 却接url编码解码了.

                $commits = $this->getCommitsByPath($file->path);
                if(empty($commits)) continue;
2021-09-23 13:17:30 momo 最后编辑
5个回复
禅道-Bee 沙发
谢谢您的反馈,这儿我们反馈给相关同事确认下。
2021-09-23 14:01:11 禅道-李锡碧 回帖
丁国栋 板凳

您好,感谢您的反馈,请问您这是在使用禅道中的哪一个功能遇到问题了?是版本库浏览页面遇到的问题吗?

2021-09-23 15:02:25 丁国栋 回帖
📗
momo #3

随便来个gitlab版本库, 路径上带+号就可以看见问题.

或者类似    %20%2B%2F    这样的名字. 

2021-09-24 09:00:24 momo 最后编辑 2021-09-24 09:00:24 momo 回帖
丁国栋 #4 回复#3
原帖由 momo 于 2021-09-24 08:57:43 发表

随便来个gitlab版本库, 路径上带+号就可以看见问题.

或者类似    %20%2B%2F    这样的名字. 


您好,路径中带+号未能复现,如上面2楼帖子图片所示。  “%20%2B%2F”这种的文件已经复现,我们这边做一下改进。感谢您继续反馈。


2021-09-29 17:04:24 丁国栋 回帖
丁国栋 #5 回复#3
原帖由 momo 于 2021-09-24 08:57:43 发表

随便来个gitlab版本库, 路径上带+号就可以看见问题.

或者类似    %20%2B%2F    这样的名字. 


momo您好,让您久等了,我现在跟您反馈一下我了解到的情况。

禅道会通过GitLab的API 读取Git版本库中文件的信息,其中一个API链接为:https://docs.gitlab.com/ee/api/repository_files.html#get-file-from-repository , 用于获取文件的信息。

由于GitLab API的原因,GitLab 无法有效识别到file_path中的特殊字符“%”,导致API会提示:


{
    "error""file_path should be a valid file path"
}

尽管如此,GitLab自己还是可以识别的。但在RESTfull API中,可能因为HTTP协议的约定可能无法做到有效处理。

因此,我的建议的是不要使用含有“%”这种在URL中有特殊意义的字符。

如果你有更好的建议,欢迎提出。谢谢!

2021-10-24 22:52:01 丁国栋 最后编辑 2021-10-24 22:52:01 丁国栋 回帖
联系人
张淑钧/高级客户经理
电话(微信)
13156280939
QQ号码
2082428410
联系邮箱
zhangshujun@chandao.com
返回顶部
张淑钧
高级客户经理
13156280939
2082428410
统一服务热线 4006-8899-23
我要提问提问有任何问题,您都可以在这里提问。 问题反馈反馈点击这里,让我们聆听您的建议与反馈。