Google App Engine RCE漏洞详情

Track-聂风   ·   发表于 2018-05-23 15:58:01   ·   漏洞文章
<p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">原文：<a href="https://sites.google.com/site/testsitehacking/-36k-google-app-engine-rce" target="_blank" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">https://sites.google.com/site/testsitehacking/-36k-google-app-engine-rce</a>&nbsp;(需要科学上网)</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;"><strong style="box-sizing: border-box;">简介</strong></p><hr style="margin-top: 15px; margin-bottom: 15px; border-top: 0px; border-right: 0px; border-left: 0px; border-image: initial; border-bottom-style: solid; border-bottom-color: rgb(221, 221, 221); box-sizing: content-box; height: 0px; background-image: initial; background-position: initial; background-size: initial; background-repeat: initial; background-attachment: initial; background-origin: initial; background-clip: initial; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;"/><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">在2018年初，我接触到了一个非生产型的Google App Engine部署环境，在那里，我可以尽情鼓捣各种内部API，经过一番折腾后，竟然找到了一个得到Google承认的远程代码执行漏洞。为此，我获得了Google漏洞奖励计划颁发的36,337美元奖金。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;"><strong style="box-sizing: border-box;">提示</strong></p><hr style="margin-top: 15px; margin-bottom: 15px; border-top: 0px; border-right: 0px; border-left: 0px; border-image: initial; border-bottom-style: solid; border-bottom-color: rgb(221, 221, 221); box-sizing: content-box; height: 0px; background-image: initial; background-position: initial; background-size: initial; background-repeat: initial; background-attachment: initial; background-origin: initial; background-clip: initial; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;"/><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">您可以尝试运行文中<a href="http://save-the-expanse.appspot.com/" target="_blank" title="Google App Engine应用" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">Google App Engine应用</a>所涉及的一些概念的示例代码。您可以找到该应用程序的源代码，包括gRPC C++ 客户端的源代码和各个Protocol Buffer的定义，这些都可以从本人提供的<a href="https://github.com/ezequielpereira/GAE-RCE" target="_blank" title="GitHub存储库" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">GitHub存储库</a>中找到。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">不久之前，我注意到每个<a href="https://cloud.google.com/appengine/" target="_blank" title="Google App Engine" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">Google App Engine</a>（GAE）应用程序都使用“X-Cloud-Trace-Context”头部来响应所有HTTP请求，所以，我觉得任何返回该头部的网站都可以在GAE上运行。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">在这一想法的指引下，我发现“<a href="http://appengine.google.com/" target="_blank" title="appengine.google.com" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">appengine.google.com</a>”本身就是运行在GAE上的，但是，它却可以执行一些无法在其他地方完成的操作，以及一些普通用户应用程序无法执行的操作，这极大地激发了我的好奇心，所以，我决定搞清楚这到底是咋回事。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">显然，它必须使用一些API、接口或者只有谷歌自己运行的应用才可以使用的东西，并且，也许我们还可以通过某种方式来访问它们，这正是我们要探索的。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">首先，在考察GAE应用程序是如何执行内部操作（例如写日志或<a href="https://cloud.google.com/appengine/docs/standard/java/appidentity#asserting_identity_to_google_apis" target="_blank" title="获取OAuth令牌" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">获取OAuth令牌</a>）之后，我发现，在Java 8环境中，这些操作都是通过向位于<a href="http://169.254.169.253:10001/rpc_http%E7%9A%84%E5%86%85%E9%83%A8HTTP%E7%AB%AF%E7%82%B9%E5%8F%91%E9%80%81Protocol" target="_blank" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">http://169.254.169.253:10001/rpc_http的内部HTTP端点发送Protocol</a>Buffer（PB）消息（采用<a href="https://developers.google.com/protocol-buffers/docs/encoding#structure" target="_blank" title="二进制线路层格式" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">二进制线路层格式</a>）来实现的。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">HTTP请求如下所示：</p><div class="highlight" style="box-sizing: border-box; margin-bottom: 16px; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;"><pre style="padding: 16px; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; border-radius: 3px; margin-top: 0px; margin-bottom: 0px; line-height: 1.6; word-break: normal; word-wrap: normal; white-space: pre-wrap; background-color: rgb(247, 247, 247); border: 1px solid rgba(0, 0, 0, 0.15); box-sizing: border-box; font-variant-numeric: normal; font-variant-east-asian: normal; font-stretch: normal; overflow: auto;">POST&nbsp;/rpc_http&nbsp;HTTP/1.1
Host:&nbsp;169.254.169.253:10001
X-Google-RPC-Service-Endpoint:&nbsp;app-engine-apis
X-Google-RPC-Service-Method:&nbsp;/VMRemoteAPI.CallRemoteAPI
Content-Type:&nbsp;application/octet-stream
Content-Length:&nbsp;<LENGTH><PROTO_MESSAGE></pre></div><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">这里的PB消息实际上是一个“<a href="https://github.com/ezequielpereira/GAE-RCE/blob/c58ccd52d9204a0e5b8c7cf9b82b8e6e06d524a8/protos/apphosting/ext/remote_api/remote_api.proto#L11" target="_blank" title="apphosting.ext.remote_api.Request" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">apphosting.ext.remote_api.Request</a>”消息，包括：<br/>service_name = 要调用的API的名称<br/>method = 要调用的API方法的名称<br/>request = 内部PB请求的字节数据（以二进制线路层格式编码）<br/>request_id = 安全票据（随每个GAE请求一起提供给应用程序），虽然它被标记为可选，但必需提供</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">至于这个HTTP请求的响应，可能是与该API的回复相对应的PB消息，也可能是一个错误消息。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">在Java 8运行时环境下，我们可以通过下列代码行获取相应的安全票据：</p><div class="highlight" style="box-sizing: border-box; margin-bottom: 16px; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;"><pre style="padding: 16px; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; border-radius: 3px; margin-top: 0px; margin-bottom: 0px; line-height: 1.6; word-break: normal; word-wrap: normal; white-space: pre-wrap; background-color: rgb(247, 247, 247); border: 1px solid rgba(0, 0, 0, 0.15); box-sizing: border-box; font-variant-numeric: normal; font-variant-east-asian: normal; font-stretch: normal; overflow: auto;">import&nbsp;com.google.apphosting.api.ApiProxy;import&nbsp;java.lang.reflect.Method;Method&nbsp;getSecurityTicket&nbsp;=&nbsp;ApiProxy.getCurrentEnvironment().getClass().getDeclaredMethod("getSecurityTicket");getSecurityTicket.setAccessible(true);String&nbsp;security_ticket&nbsp;=&nbsp;(String)&nbsp;getSecurityTicket.invoke(ApiProxy.getCurrentEnvironment());</pre></div><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">对于这个过程，我们可以通过一个例子进行说明：如果我想要取得一个可以在“<a href="https://www.googleapis.com/auth/xapi.zoo%E2%80%9D%E8%8C%83%E5%9B%B4%EF%BC%88%E6%B5%8B%E8%AF%95%E8%8C%83%E5%9B%B4%EF%BC%8C%E6%B2%A1%E6%9C%89%E5%AE%9E%E9%99%85%E4%BD%BF%E7%94%A8%EF%BC%89%E5%86%85%E4%BD%BF%E7%94%A8%E7%9A%84Google" target="_blank" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">https://www.googleapis.com/auth/xapi.zoo”范围（测试范围，没有实际使用）内使用的Google</a>&nbsp;OAuth令牌，具体步骤如下所示：</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">1.生成一个“<a href="https://github.com/ezequielpereira/GAE-RCE/blob/c58ccd52d9204a0e5b8c7cf9b82b8e6e06d524a8/protos/apphosting/api/app_identity/app_identity_service.proto#L51" target="_blank" title="apphosting.GetAccessTokenRequest" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">apphosting.GetAccessTokenRequest</a>”消息：<br/>scope = ["<a href="https://www.googleapis.com/auth/xapi.zoo" target="_blank" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">https://www.googleapis.com/auth/xapi.zoo</a>"]<br/>2.生成一个“<a href="https://github.com/ezequielpereira/GAE-RCE/blob/c58ccd52d9204a0e5b8c7cf9b82b8e6e06d524a8/protos/apphosting/ext/remote_api/remote_api.proto#L11" target="_blank" title="apphosting.ext.remote_api.Request" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">apphosting.ext.remote_api.Request</a>”消息：<br/>service_name = "app_identity_service"（该API用于访问GAE服务帐户）</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">method = "GetAccessTokenRequest"<br/>request = 上一步生成的PB消息的字节数据，以二进制线路层格式编码<br/>request_id = 安全票据<br/>3.发送HTTP请求<br/>4.对响应消息进行解码，该响应内容应该是“<a href="https://github.com/ezequielpereira/GAE-RCE/blob/c58ccd52d9204a0e5b8c7cf9b82b8e6e06d524a8/protos/apphosting/api/app_identity/app_identity_service.proto#L57" target="_blank" title="apphosting.GetAccessTokenResponse" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">apphosting.GetAccessTokenResponse</a>”消息</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">由于这个端点可以访问一些内部的东西，所以，我相信它与完成内部操作的“<a href="http://appengine.google.com/" target="_blank" title="appengine.google.com" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">appengine.google.com</a>”域肯定有关，遗憾的是，我在这个HTTP端点中没有找到任何有用的东西。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">最初，我觉得它可能使用了位于同一服务器（169.254.169.253）中的其他端点，因此，我上传了一个静态链接版本的Nmap到GAE，并在该服务器上运行它（为了在GAE中运行二进制文件，我将其与应用程序一起上载，然后在运行时，将它们复制到/tmp目录中，并赋予它们执行权限——因为文件系统的其余文件都是只读的）。具体的例子，请参考<a href="http://save-the-expanse.appspot.com/nmap" target="_blank" title="这里" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">这里</a>。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">我发现，端口4是开放的，所以，我向该端口发送了一些东西。之后，它回复了一堆奇怪的数据，不过，其中也有一些可识别的字符串，在搜索引擎的帮助下，我发现这是一个<a href="https://grpc.io/about/" target="_blank" title="gRPC服务" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">gRPC服务</a>。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">我曾经尝试构建一个在GAE上运行的Java gRPC客户端，但是遇到了一个问题：一方面内置的gRPC库似乎不完整，另一方面，每当我上传一个完整的gRPC库后，它仍“固执地”使用内置的库。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">所以，我构建了一个C++客户端，并在GAE上运行它。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">经过反复试验之后，我发现gRPC服务就像HTTP端点一样，也运行了一个“<a href="https://github.com/ezequielpereira/GAE-RCE/blob/c58ccd52d9204a0e5b8c7cf9b82b8e6e06d524a8/protos/apphosting/base/runtime.proto#L219" target="_blank" title="apphosting.APIHost" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">apphosting.APIHost</a>” API。当然，两者还是有所差异的，比如在PB消息的编码方面，它不仅提供了二进制编码选项，还提供了JSON编码选项，因此，它在测试方面要更容易一些。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">对于该客户端，<a href="http://save-the-expanse.appspot.com/grpc?api=app_identity_service&method=GetDefaultGcsBucketName&req=%7B%7D&setPb=1" target="_blank" title="这里" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">这里</a>提供了一个实例。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">由于在该服务器中没有发现其他东西，因此，我假定“<a href="http://appengine.google.com/" target="_blank" title="appengine.google.com" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">appengine.google.com</a>”在内部执行的操作，要么是借助其他服务器完成的，要么就是使用RPC服务（HTTP/gRPC）调用了某些隐式的API/方法。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">于是，我通过Nmap查找与其有关的服务器，但只找到了<a href="https://cloud.google.com/compute/docs/storing-retrieving-metadata" target="_blank" title="元数据服务器" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">元数据服务器</a>，很明显，它不可能完成上述的操作，所以，我认为它肯定使用了隐式的API，但问题是——如何找到它们呢？</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">首先，我收集了所能找到的所有Protocol Buffer的定义（这些可以从.JAR文件中找到的.CLASS文件以及在运行时找到的二进制文件中提取），并在其中搜索任何可能指向某些隐式API的Protocol Buffer定义（如果读者有兴趣的话，可以从<a href="https://github.com/ezequielpereira/GAE-RCE/tree/master/protos" target="_blank" title="这里" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">这里</a>下载我提取到的所有PB定义）。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">在“<a href="https://github.com/ezequielpereira/GAE-RCE/blob/c58ccd52d9204a0e5b8c7cf9b82b8e6e06d524a8/protos/apphosting/base/appmaster.proto" target="_blank" title="apphosting/base/appmaster.proto" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">apphosting/base/appmaster.proto</a>”文件中，含有几个PB消息，看起来像是修改App Engine内部设置的内部方法，还有一个名为“AppMaster”的API，其中定义了一些方法，这些都是我们所感兴趣的——但是，经过一番尝试之后，我仍然没有找到正确调用这些方法的途径。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">由于在PB定义中没有找到任何隐式的API/方法，所以我不得不到其他地方寻找。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">于是，我将搜索目标转移到二进制文件上面，问题是它们过于庞大，并且里面充满了无用或者无法理解的东西（我是通过字符串+grep来完成搜索的，因为我对逆向工程还不太熟悉），后来，我在一个主要的二进制文件即“java_runtime_launcher_ex”中发现了多命令行参数，这给了我很大的启发：何不考察在GAE环境中运行时会收到哪些参数呢？</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">刚开始的时候，我获取参数的方法是非常费劲的，因为需要将每个可以找到的Java变量与相应的参数联系起来，这几乎是不可能完成的任务。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">然后，我尝试了一些更聪明的方法：用C++创建一个Java库，并使用一个方法来读取传递给启动程序的参数，然后将其返回。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">这种获取参数的方式明显要轻松多了，这是我从一个<a href="https://stackoverflow.com/a/37358751" target="_blank" title="Stack Overflow帖子" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">Stack Overflow帖子</a>中学到的，其中用于获取参数的代码如下所示：</p><div class="highlight" style="box-sizing: border-box; margin-bottom: 16px; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;"><pre style="padding: 16px; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; border-radius: 3px; margin-top: 0px; margin-bottom: 0px; line-height: 1.6; word-break: normal; word-wrap: normal; white-space: pre-wrap; background-color: rgb(247, 247, 247); border: 1px solid rgba(0, 0, 0, 0.15); box-sizing: border-box; font-variant-numeric: normal; font-variant-east-asian: normal; font-stretch: normal; overflow: auto;">int&nbsp;argc&nbsp;=&nbsp;-1;char&nbsp;**argv&nbsp;=&nbsp;NULL;static&nbsp;void&nbsp;getArgs(int&nbsp;_argc,&nbsp;char&nbsp;**_argv,&nbsp;char&nbsp;**_env)&nbsp;{
&nbsp;&nbsp;argc&nbsp;=&nbsp;_argc;
&nbsp;&nbsp;argv&nbsp;=&nbsp;_argv;}__attribute__((section(".init_array")))&nbsp;static&nbsp;void&nbsp;*ctr&nbsp;=&nbsp;(void*)&nbsp;getArgs;</pre></div><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">然后，通过一个简单方法将参数转换为Java数组，<a href="http://save-the-expanse.appspot.com/args" target="_blank" title="这里" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">这里</a>有一个具体的例子。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">运行代码后，我得到了很多参数，其中包括下面这个（为了便于阅读，这里将其分成多行）：</p><div class="highlight" style="box-sizing: border-box; margin-bottom: 16px; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;"><pre style="padding: 16px; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; border-radius: 3px; margin-top: 0px; margin-bottom: 0px; line-height: 1.6; word-break: normal; word-wrap: normal; white-space: pre-wrap; background-color: rgb(247, 247, 247); border: 1px solid rgba(0, 0, 0, 0.15); box-sizing: border-box; font-variant-numeric: normal; font-variant-east-asian: normal; font-stretch: normal; overflow: auto;">--api_call_deadline_map=
&nbsp;&nbsp;app_config_service:60.0,
&nbsp;&nbsp;blobstore:15.0,
&nbsp;&nbsp;datastore_v3:60.0,
&nbsp;&nbsp;datastore_v4:60.0,
&nbsp;&nbsp;file:30.0,
&nbsp;&nbsp;images:30.0,
&nbsp;&nbsp;logservice:60.0,
&nbsp;&nbsp;modules:60.0,
&nbsp;&nbsp;rdbms:60.0,
&nbsp;&nbsp;remote_socket:60.0,
&nbsp;&nbsp;search:10.0,
&nbsp;&nbsp;stubby:10.0</pre></div><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">我很快注意到了一些之前用过的API，比如“logservice”（用于写日志），所以我推断这些都是可以通过内部HTTP端点使用的API。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">此外，我还注意到了“stubby”，之前在某些Google产品的错误消息中见过这个消息（当遇到bug时），并且在<a href="https://landing.google.com/sre/book/chapters/production-environment.html" target="_blank" title="SRE" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">SRE</a>中也读过这方面的东西，所以我判断这是一个RPC的基础结构，并且可能是“<a href="http://appengine.google.com/" target="_blank" title="appengine.google.com" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">appengine.google.com</a>”执行内部操作的一种方式。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">太棒了，现在终于知道一个内部API的名称了，但是，它提供了哪些方法呢？</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">我用C++ gRPC客户端尝试了几个方法名，但是它们都返回了一个错误，说这些方法并不存在，所以，我开始借助Google进行搜索。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">后来，我发现了一篇写于2010年的<a href="https://groups.google.com/d/msg/techos/6koJkAuuVVk/6QJNbjRIy40J" target="_blank" title="文章" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">文章</a>，它指出：</p><div class="highlight" style="box-sizing: border-box; margin-bottom: 16px; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;"><pre style="padding: 16px; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; border-radius: 3px; margin-top: 0px; margin-bottom: 0px; line-height: 1.6; word-break: normal; word-wrap: normal; white-space: pre-wrap; background-color: rgb(247, 247, 247); border: 1px solid rgba(0, 0, 0, 0.15); box-sizing: border-box; font-variant-numeric: normal; font-variant-east-asian: normal; font-stretch: normal; overflow: auto;">The&nbsp;API&nbsp;call&nbsp;stubby.Send()&nbsp;took&nbsp;too&nbsp;long&nbsp;to&nbsp;respond&nbsp;and&nbsp;was&nbsp;cancelled.</pre></div><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">所以，我开始尝试“Send”方法，但系统指出该方法并不存在。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">我相信该方法肯定是存在的，这里的错误消息只是为了隐藏了它存在的事实，同时，现在我仍然无法访问它。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">为此，我试着通过寻找访问确实“不存在”的方法时返回的错误消息（<a href="http://save-the-expanse.appspot.com/grpc?api=app_identity_service&method=SaveTheExpanse" target="_blank" title="示例" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">示例</a>）与为了掩盖真实存在的方法而返回的错误消息（<a href="http://save-the-expanse.appspot.com/grpc?api=stubby&method=Send" target="_blank" title="示例" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">示例</a>）之间的区别来验证上面的判断，并且发现：当从我的gRPC客户端中发送一个未设置"<a href="https://github.com/ezequielpereira/GAE-RCE/blob/c58ccd52d9204a0e5b8c7cf9b82b8e6e06d524a8/protos/apphosting/base/runtime.proto#L176" target="_blank" title="apphosting.APIRequest.pb" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">apphosting.APIRequest.pb</a>"字段（它被标记为可选的，但我总是至少将它设置为一个空字符串或"{}"）的请求的时候，系统会为并不存在的方法（<a href="http://save-the-expanse.appspot.com/grpc?api=app_identity_service&method=SaveTheExpanse&setPb=0" target="_blank" title="示例" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">示例</a>）返回一则“not-exist”错误消息，而对于一个实际存在的方法（<a href="http://save-the-expanse.appspot.com/grpc?api=stubby&method=Send&setPb=0" target="_blank" title="示例" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">示例</a>），系统则会返回一则“incomplete request”错误消息。通过这种方式，我判断出“stubby.Send”方法确实是存在的。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">现在的问题是，如何才能访问它呢？</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">我不知道在生产性的GAE<a href="https://en.wikipedia.org/wiki/Deployment_environment" target="_blank" title="部署环境" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">部署环境</a>中访问它的方式，但我知道，利用某个漏洞（通常，普通的Google用户无法访问非生产性的部署环境），我可以访问staging（<a href="http://staging-appengine.sandbox.googleapis.com/" target="_blank" title="staging-appengine.sandbox.googleapis.com" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">staging-appengine.sandbox.googleapis.com</a>）和测试（<a href="http://test-appengine.sandbox.googleapis.com/" target="_blank" title="test-appengine.sandbox" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">test-appengine.sandbox</a>）性的GAE部署环境。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">对这两种部署环境进行一番研究之后，我找到了调用在其中运行的应用程序的方法：</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">1.上传一个缩放类型为手动缩放的版本（否则无法正常运行，并返回403 Forbidden）</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">2.向“www.appspot.com”发送请求，并将Host头部改为“<project-name>.prom-<qa/nightly>.sandbox.google.com”</project-name></p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">如果您的应用在“save-the-expanse.appspot.com”上运行，则应该用“save-the-expanse”替换“<project-name>”；如果您要将应用上传到staging GAE环境，则应该用“qa”代替“<qa/nightly>”；如果要把该应用上传到测试GAE环境的话，则应该将"<qa/nightly>"换为 "nightly"。</project-name></p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">例如：我是在“the-expanse.prom-nightly.sandbox.google.com”上进行的测试（没有“保存”，因为当时<a href="https://www.imdb.com/title/tt3230854/" target="_blank" title="The Expanse" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">The Expanse</a>还没有被<a href="http://www.newsweek.com/expanse-save-amazon-syfy-season-4-renew-fans-934620" target="_blank" title="撤销" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">撤销</a>）。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;"><strong style="box-sizing: border-box;">漏洞详情</strong></p><hr style="margin-top: 15px; margin-bottom: 15px; border-top: 0px; border-right: 0px; border-left: 0px; border-image: initial; border-bottom-style: solid; border-bottom-color: rgb(221, 221, 221); box-sizing: content-box; height: 0px; background-image: initial; background-position: initial; background-size: initial; background-repeat: initial; background-attachment: initial; background-origin: initial; background-clip: initial; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;"/><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">上传好这个应用程序后，我很快就发现，在非生产（staging/测试）性的GAE环境中，我竟然可以访问“stubby.Send”方法！</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">经过一番快速测试（主要是阅读错误消息并猜测如何解决这些问题）后，我发现了进行简单的Stubby调用的方式：</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">1.使用以下JSON PB消息调用“stubby.GetStubId”方法：</p><div class="highlight" style="box-sizing: border-box; margin-bottom: 16px; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;"><pre style="padding: 16px; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; border-radius: 3px; margin-top: 0px; margin-bottom: 0px; line-height: 1.6; word-break: normal; word-wrap: normal; white-space: pre-wrap; background-color: rgb(247, 247, 247); border: 1px solid rgba(0, 0, 0, 0.15); box-sizing: border-box; font-variant-numeric: normal; font-variant-east-asian: normal; font-stretch: normal; overflow: auto;">{
&nbsp;&nbsp;"host":&nbsp;"<HOST>"}</pre></div><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">将&#39;<host>&#39;设置为要调用的方法所在的位置（例如，“google.com:80”，“pantheon.corp.google.com:80”，“blade：monarch-cloud_prod-streamz”）。</host></p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">“blade：<service>”似乎就像Google使用的内部DNS系统，例如，“blade：cloudresourcemanager-project”在其内部就是“cloudresourcemanager.googleapis.com”（有点像“blade：monarch-cloud_prod-streamz”，但是没有外部的对应物）。</service></p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">2.前一个请求将返回一个JSON PB消息，其中“stub_id”是其唯一的字段，用于存储相应的值。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">3.通过以下JSON PB消息调用“stubby.Send”方法：</p><div class="highlight" style="box-sizing: border-box; margin-bottom: 16px; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;"><pre style="padding: 16px; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; border-radius: 3px; margin-top: 0px; margin-bottom: 0px; line-height: 1.6; word-break: normal; word-wrap: normal; white-space: pre-wrap; background-color: rgb(247, 247, 247); border: 1px solid rgba(0, 0, 0, 0.15); box-sizing: border-box; font-variant-numeric: normal; font-variant-east-asian: normal; font-stretch: normal; overflow: auto;">{
&nbsp;&nbsp;"stubby_method":&nbsp;"/<SERVICE>.<METHOD>",
&nbsp;&nbsp;"stubby_request":&nbsp;"<PB>",
&nbsp;&nbsp;"stub_id":&nbsp;"<STUB_ID>"}</pre></div><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">为了搞清楚“stubby_method”的可能取值，可以使用空的“stubby_request”将其设置为“/ServerStatus.GetServices”，这样就会返回一个“rpc.ServiceList”，从而列出目标系统支持的所有服务。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;"><pb>是PB消息字节数据（采用二进制线路层格式）。</pb></p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">4.如果成功的话，该调用将返回以“stubby_response”作为其唯一字段的JSON PB消息，其中存放响应PB消息的相关字节（采用二进制线路层格式）。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">此后，我进行了一些测试，并没有发现会导致安全隐患的Stubby调用。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">不过，我仍然向谷歌汇报了这个问题，它们将这个问题的优先级定为P1。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">在报告这个问题之后，我又重新进行了回顾，试图找到可以成功用于攻击的一些变体，我注意到，除了“stubby”之外，通过Java启动程序二进制文件中得到的参数中，还有一个名为“app_config_service”的参数，它实际上也是一个隐式的API。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">通过查看之前得到的PB定义，并没有发现这个隐式的API的方法，此外，也没有在Google搜索中找到它们，但后来从“apphosting/base/quotas.proto”中发现了相关的方法。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">例如，其中提到了“<a href="https://github.com/ezequielpereira/GAE-RCE/blob/c58ccd52d9204a0e5b8c7cf9b82b8e6e06d524a8/protos/apphosting/base/quotas.proto#L417" target="_blank" title="APP_CONFIG_SERVICE_GET_APP_CONFIG" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">APP_CONFIG_SERVICE_GET_APP_CONFIG</a>”，并且通过一些测试发现“app_config_service.GetAppConfig”的确是一个隐式的方法。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">“app_config_service”提供了多个方法，但我最感兴趣的方法是“app_config_service.ConfigApp”和“app_config_service.SetAdminConfig”，因为它们可用来完成内部设置，例如设置电子邮件发件人、应用程序的服务帐户ID、忽略配额限制，甚至可以将自己的应用程序设为“<a href="https://github.com/ezequielpereira/GAE-RCE/blob/c58ccd52d9204a0e5b8c7cf9b82b8e6e06d524a8/protos/apphosting/base/appmaster.proto#L106" target="_blank" title="SuperApp" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">SuperApp</a>”（我不知道这意味着什么，但听起来很牛掰），并赋予其“<a href="https://github.com/ezequielpereira/GAE-RCE/blob/c58ccd52d9204a0e5b8c7cf9b82b8e6e06d524a8/protos/apphosting/base/appmaster.proto#L204" target="_blank" title="FILE_GOOGLE3_ACCESS" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">FILE_GOOGLE3_ACCESS</a>”权限（我认为gooogle3是Piper的一部分，存放与gooogle API和服务相关的文件）。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">“app_config_service.SetAdminConfig”方法使用“<a href="https://github.com/ezequielpereira/GAE-RCE/blob/c58ccd52d9204a0e5b8c7cf9b82b8e6e06d524a8/protos/apphosting/base/appmaster.proto#L657" target="_blank" title="apphosting.SetAdminConfigRequest" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">apphosting.SetAdminConfigRequest</a>”作为其请求消息，“app_config_service.ConfigApp”方法使用“<a href="https://github.com/ezequielpereira/GAE-RCE/blob/c58ccd52d9204a0e5b8c7cf9b82b8e6e06d524a8/protos/apphosting/base/appmaster.proto#L85" target="_blank" title="apphosting.GlobalConfig" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">apphosting.GlobalConfig</a>”作为其请求消息。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">通过"<a href="https://github.com/ezequielpereira/GAE-RCE/blob/c58ccd52d9204a0e5b8c7cf9b82b8e6e06d524a8/protos/apphosting/base/quotas.proto" target="_blank" title="apphosting/base/quotas.proto" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">apphosting/base/quotas.proto</a>"，我还发现了其他一些API/方法，如“<a href="https://github.com/ezequielpereira/GAE-RCE/blob/c58ccd52d9204a0e5b8c7cf9b82b8e6e06d524a8/protos/apphosting/base/quotas.proto#L651" target="_blank" title="basement.GaiaLookupByUserEmail" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">basement.GaiaLookupByUserEmail</a>”，等等。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">之后，我向Google提交了这些新发现，他们提高了处理这些问题的优先级，并回复道：</p><div class="highlight" style="box-sizing: border-box; margin-bottom: 16px; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;"><pre style="padding: 16px; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; border-radius: 3px; margin-top: 0px; margin-bottom: 0px; line-height: 1.6; word-break: normal; word-wrap: normal; white-space: pre-wrap; background-color: rgb(247, 247, 247); border: 1px solid rgba(0, 0, 0, 0.15); box-sizing: border-box; font-variant-numeric: normal; font-variant-east-asian: normal; font-stretch: normal; overflow: auto;">请停止进一步的探索，因为您似乎可以轻松地使用这些内部API来破坏一些东西。</pre></div><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">同时，这个安全问题被抄送给了几名员工:</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;"><a id="img0" href="https://xzfile.aliyuncs.com/media/upload/picture/20180523002140-351f6c7a-5ddc-1.png" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;"><img src="https://xzfile.aliyuncs.com/media/upload/picture/20180523002140-351f6c7a-5ddc-1.png" style="height: auto; max-width: 90%; vertical-align: middle; border: 0px; box-sizing: border-box; text-align: center; margin-left: auto; margin-right: auto; display: block; padding: 10px 0px;"/></a></p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">几天后，访问非生产性GAE API和环境时将被阻止，并返回一个错误页面（状态码为“429 Too Many Requests”）。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">您仍然可以在“<a href="http://staging-appengine.sandbox.googleapis.com/" target="_blank" title="staging-appengine.sandbox.googleapis.com" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">staging-appengine.sandbox.googleapis.com</a>”和“<a href="http://test-appengine.sandbox.googleapis.com/" target="_blank" title="test-appengine.sandbox.googleapis.com" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">test-appengine.sandbox.googleapis.com</a>”中看到如下所示的消息。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;"><a id="img1" href="https://xzfile.aliyuncs.com/media/upload/picture/20180523002140-353023b2-5ddc-1.png" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;"><img src="https://xzfile.aliyuncs.com/media/upload/picture/20180523002140-353023b2-5ddc-1.png" style="height: auto; max-width: 90%; vertical-align: middle; border: 0px; box-sizing: border-box; text-align: center; margin-left: auto; margin-right: auto; display: block; padding: 10px 0px;"/></a></p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">后来，我收到以下信件：</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;"><a id="img2" href="https://xzfile.aliyuncs.com/media/upload/picture/20180523002140-3542b23e-5ddc-1.png" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;"><img src="https://xzfile.aliyuncs.com/media/upload/picture/20180523002140-3542b23e-5ddc-1.png" style="height: auto; max-width: 90%; vertical-align: middle; border: 0px; box-sizing: border-box; text-align: center; margin-left: auto; margin-right: auto; display: block; padding: 10px 0px;"/></a></p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">我得到了36，337美元的奖励！</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">直到那时我才意识到，这个安全问题被定性为远程代码执行漏洞（最危险的安全漏洞），这真是太让人惊喜了。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">我向其中一位Google员工咨询了奖励金额问题，得到的回复是，部分奖金是为RCE漏洞支付的（请阅读<a href="https://landing.google.com/sre/" target="_blank" title="SRE" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">SRE</a>，<a href="https://www.google.com/about/appsecurity/reward-program/index.html#rewards" target="_blank" title="RCE漏洞奖金为31,337美元" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">RCE漏洞奖金为31,337美元</a>），而额外的$5k则是为另外一个安全漏洞提供的奖金。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;"><strong style="box-sizing: border-box;">时间线</strong></p><hr style="margin-top: 15px; margin-bottom: 15px; border-top: 0px; border-right: 0px; border-left: 0px; border-image: initial; border-bottom-style: solid; border-bottom-color: rgb(221, 221, 221); box-sizing: content-box; height: 0px; background-image: initial; background-position: initial; background-size: initial; background-repeat: initial; background-attachment: initial; background-origin: initial; background-clip: initial; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;"/><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">2018年2月：发现安全问题</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">2018年2月25日：初次报告（仅限“stubby”API）</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">2018年3月4日、5日：发现并报告了“app_config_service”API</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">2018年3月6日至13日：访问非生产性GAE环境时会被429错误页面所阻止</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">2018年3月13日：奖励36,337美元</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">2018年5月16日：确认并修复漏洞</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;"><strong style="box-sizing: border-box;">作者联系方式：</strong></p><hr style="margin-top: 15px; margin-bottom: 15px; border-top: 0px; border-right: 0px; border-left: 0px; border-image: initial; border-bottom-style: solid; border-bottom-color: rgb(221, 221, 221); box-sizing: content-box; height: 0px; background-image: initial; background-position: initial; background-size: initial; background-repeat: initial; background-attachment: initial; background-origin: initial; background-clip: initial; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;"/><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box; color: rgb(51, 51, 51); font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; letter-spacing: 0.75px;">Email: eze2307<span class="label label-primary">@gmail.com</span></p><p><br/></p>

打赏我,让我更有动力~

0 条回复   |  直到 2018-5-23 | 1552 次浏览
登录后才可发表内容
返回顶部 投诉反馈

© 2016 - 2025 掌控者 All Rights Reserved.