5

在 GoogleDrive 中编辑文档后,LastModified 值似乎有时不会立即更改。看起来该值将在几分钟内更新。

我试图通过 DriveSDK 获取文档的 Etag,它也发生在 Etag 值上。

这种奇怪的行为使我无法实时获取文档状态(修改与否)。任何建议将不胜感激。

[示例请求和响应] 请求只是 GoogleDrive ListFiles :https ://www.googleapis.com/drive/v2/files

这是响应 JSON 的部分,您可以看到 ModifiedDate 早于 ModifiedByMeDate。

 {
 "kind": "drive#fileList",
 "etag": "\"3NNCnvnQuji-pODa6SMQ6atlc3M/oKnf21kAcJKTCIycS597xCSR2bk\"",
 "selfLink": "https://www.googleapis.com/drive/v2/files",
 "items": [
  {
   "kind": "drive#file",
   "id": "1lZjcJIf3Chuu5upFqtiqfTRnRw7*****rFL_tlO8A",
   "etag": "\"3NNCnvnQuji-pODa6SMQ6atlc3M/MTM1NDY5MzMyMzQ1Mg\"",
   "selfLink": "https://www.googleapis.com/drive/v2/files/1lZjcJIf3Chuu5upFqtiqfTRnRw7wSUjbRurFL_tlO8A",
   "alternateLink": "https://docs.google.com/a/*****.com/document/d/1lZjcJIf3Chuu5upFqtiqfTRnRw7wSUjbRurFL_tlO8A/edit",
   "embedLink": "https://docs.google.com/a/*****.com/document/d/1lZjcJIf3Chuu5upFqtiqfTRnRw7wSUjbRurFL_tlO8A/preview",
   "iconLink": "https://ssl.gstatic.com/docs/doclist/images/icon_11_document_list.png",
   "thumbnailLink": "https://docs.google.com/feeds/vt?gd=true&id=1lZjcJIf3Chuu5upFqtiq*****7wSUjbRurFL_tlO8A&v=22&s=AMedNnoAAAAAU*****UK74n3UiIg0L4TY-NwP3EaAU&sz=s220",
   "title": "TestFile",
   "mimeType": "application/vnd.google-apps.document",
   "labels": {
    "starred": false,
    "hidden": false,
    "trashed": false,
    "restricted": false,
    "viewed": true
   },
   "createdDate": "2012-07-24T08:14:13.918Z",
   "modifiedDate": "2012-12-06T01:49:57.982Z",
   "modifiedByMeDate": "2012-12-06T01:49:57.982Z",
   "lastViewedByMeDate": "2012-12-06T01:50:06.974Z",
   "parents": [
    {
     "kind": "drive#parentReference",
     "id": "0AJ-aGTt-gWksUk9PVA",
     "selfLink": "https://www.googleapis.com/drive/v2/files/1lZjcJIf3Chuu5upFqtiqfTRnRw7wSUjbRurFL_tlO8A/parents/0AJ-aGTt-gWksUk9PVA",
     "parentLink": "https://www.googleapis.com/drive/v2/files/0AJ-aGTt-gWksUk9PVA",
     "isRoot": true
    }
   ],
   "exportLinks": {
    "application/vnd.openxmlformats-officedocument.wordprocessingml.document": "https://docs.google.com/feeds/download/documents/export/Export?id=1l*****huu5upFqtiqfTRnRw7wSUjbRurFL_tlO8A&exportFormat=docx",
    "application/vnd.oasis.opendocument.text": "https://docs.google.com/feeds/download/documents/export/Export?id=1lZjcJIf3Chuu5upF*****SUjbRurFL_tlO8A&exportFormat=odt",
    "text/html": "https://docs.google.com/feeds/download/documents/export/Export?id=1lZjcJIf3Chuu5upFqtiqfTRnRw7wSUj*****L_tlO8A&exportFormat=html",
    "application/rtf": "https://docs.google.com/feeds/download/documents/export/Export?id=1lZjcJIf3Chuu5upFqtiq*****SUjbRurFL_tlO8A&exportFormat=rtf",
    "text/plain": "https://docs.google.com/feeds/download/documents/export/Export?id=1lZjcJIf3Chuu5upFqtiqf*****SUjbRurFL_tlO8A&exportFormat=txt",
    "application/pdf": "https://docs.google.com/feeds/download/documents/export/Export?id=1lZjcJIf3C*****fTRnRw7wSUjbRurFL_tlO8A&exportFormat=pdf"
   },
   "userPermission": {
    "kind": "drive#permission",
    "etag": "\"3NNCnvnQuji-pODa6SMQ6atlc3M/6LfqbkrWujmUe1WSDkyhTxdIUCc\"",
    "id": "me",
    "selfLink": "https://www.googleapis.com/drive/v2/files/1lZjcJIf3Chuu5upFqtiqfTRnRw7wSUjbRurFL_tlO8A/permissions/me",
    "role": "owner",
    "type": "user"
   },
   "quotaBytesUsed": "0",
   "ownerNames": [
    "***** *****"
   ],
   "lastModifyingUserName": "***** *****",
   "editable": true,
   "writersCanShare": true,
   "appDataContents": false
  },
4

3 回答 3

6

这没有回答问题,但我只想评论资源的含义etagmodifiedDate含义FileFile etag似乎只是直接对应于modifiedDate值。的第二部分etag(斜杠之后)只是modifiedDate.

在 Documents List API 中,app:edited除了属性之外,还有一个属性被调用updated(似乎与modifiedDate此处对应)。这些时间戳更改的方式没有明确记录,但我注意到app:edited几乎每次更改都会发生更改(例如,文件加星标,如果我没记错的话,即使是另一个用户)并且updated更改更加有限(例如内容修改和权限更改) )。而etagbefore 直接对应于app:edited,这很好,因为更改app:edited表示确实发生了更改(尽管有时更改太多,例如不同用户为文件加星标,因为它不会真正影响当前用户的元数据)。

我想说的是,我认为 Documents List etag(并且拥有该app:edited属性)比modifiedDate仅拥有 Drive API 更好。后者的问题在于您没有可靠的方法来确定File资源是否已更改。例如,如果您只是想检查File资源是否已更改,则可以使用 files.get 方法和If-None-Match使用etag. 但etag并不总是改变,因为modifiedDate并不总是改变。例如,当有新内容、更改 ACL 或更改描述时,它会更改,但不会更改,例如,当已删除或更改父级时。在比较两种资源时,您无法可靠地确定哪一种较新。添加一个事实modifiedDate可以设置(例如,可以将 设置modifiedDate为更早的值,甚至是一个常量值,并且可以etag使用它)。的预期目的etag丢失了。在很多情况下,我们不能只依赖更改列表,如果etag行为正确,这将有助于确定发生的更改。

我的建议是恢复etag类似于 Documents List API 的行为。并且为了帮助确定哪个资源有更新的信息,也添加回app:edited属性(我认为只记录 的值etag就足够了,就像官方说的第二部分是时间戳的编码,这样我们就可以依赖它来一直在增加)。另外,我认为最好只更改modifiedDate内容修改的属性,而不是其他(例如,不更改 ACL 或更改描述)。

同样,逐字文件etagRevision(List)资源也不是很有用。由于downloadUrl属性会定期更改,因此etag每个Revision列表和整个列表的 s 都会随之更改,从而使其无用(因为您无法使用它来检查修订版是否没有更改)。好在有md5Checksum你可以比较的属性,但在某些情况下它并不可靠。

于 2012-12-06T06:47:29.293 回答
2

Google 的基础架构会在更新后异步更新 Google 文档。据我所知,这会影响 etag、缩略图,可能还会影响 md5sum 和某些修改日期。

Google 的一些文档确认哪些项目是异步的,哪些是同步的,这对开发人员来说非常有用。

于 2012-12-06T02:23:38.313 回答
0

etag 实际上是文件元数据的散列,并且通常在实践中。如果您更改有关常规文件的任何内容(不是文档或工作表,请参见下文),或者只是使用例如“触摸”它

https://www.googleapis.com/drive/v2/files/blah_my_file_id/touch

元数据已更改,您在响应中返回的 etag 将有所不同。我的应用程序,可能还有成千上万的其他应用程序,完全依赖于这种行为。如果您看到不同,它在您的设置中的某个地方。OP 说“你可以看到 ModifiedDate 早于 ModifiedByMeDate”......呃,不是。他们提供的 JSON 响应是相同的。“LastViewedByMeDate”是不同的。

Google Docs、Sheets 等是一个完全不同的系统,因为它们是协作的。协作系统保持个人变化,并且需要非常复杂的逻辑来保持一切正常;它们不仅仅是普通文件。您的云端硬盘“中”的内容只是 Google 洞穴中其他地方运行的进程的快捷方式,您从云端硬盘读取的元数据很可能与最近的更改不同步。谷歌现在撤回的协作实时 API(它可能仍然驱动文档和表格,我不知道)提供了一个 serverRevision 属性,这是跟踪是否发生任何更改的可靠方法。

于 2020-04-28T19:15:44.010 回答