首页
学习
活动
专区
圈层
工具
发布

黑客扫描全网 Git 配置文件并窃取大量云凭据

暴露的 Git 配置文件Git 配置文件(例如 /.git/config 或 .gitlab-ci.yml)用于定义各种配置,例如存储库路径、分支、远程,有时甚至是 API 密钥、访问令牌和密码等身份验证信息...为方便起见,开发人员可能会将这些密钥包含在私有存储库中,从而使数据传输和 API 交互更加容易,而无需每次都配置或执行身份验证。只要存储库与公共访问适当隔离,这就不会有风险。...扫描只是检查 Laravel 应用程序中的 /.git/config 文件和环境文件 (.env) 是否暴露,其中也可能包含 API 密钥和云凭据。...一旦确定了暴露,就会使用对各种 API 的“curl”命令验证令牌,如果有效,则用于下载私有存储库。再次扫描这些下载的存储库,以获取 AWS、云平台和电子邮件服务提供商的身份验证密钥。...软件开发人员可以通过使用专用的密钥管理工具来存储其密钥,并使用环境变量在运行时配置敏感设置,而不是在 Git 配置文件中对其进行硬编码,从而降低风险。

53110

【Laravel系列7.4】安全相关

大家可以自己尝试一下,接下来我们要看一下如何使用 token 来进行 api 的登录和认证控制。一般情况下,我们可能会使用 jwt 或者 passport 之类的插件来做这种 api 的认证功能。...默认情况下,Laravel 框架虽然提供了 Api 的验证功能,但还需要我们手动的添加一些内容,比如说数据库需要添加一个 api_token 的 varchar 字段,给个 80 左右的长度即可。...接下来你可以自己测试一下效果,在访问 /custom/info 这个接口时,你可以用两种方式来传递 api_token 。...在之前我们已经学习过 PHP 中的加密以及 OpenSSL 的加密,对称加密是需要一个密钥的,这个密钥其实就是我们在安装框架之后使用 php artisan key:generate 生成的那个密钥,它被保存在...哈希 和上面的 Crypt 加密一样,Hash 门面使用的其实就是 password_hash() 的加密方式,Laravel 也只是对它进行了一个简单的封装。

4.5K40
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    web3服务端身份验证

    从钱包到服务端 第一部分实现非常简单,让用户将钱包连接到我们的前端,并且从获取的钱包地址向服务端发送一个 API 请求。...这里的问题是,任何人都可以用别人的地址向我们发送 API 请求,并且我们无法验证这个地址是否映射到与前端的钱包。 在服务端验证签名 容易忽略的一点,本质上加密钱包只是一个密钥对(私钥和公钥的组合)。...我的签名验证的 PHP 实现[4] 防止签名被利用 我们有一个可以用钱包登录的系统,和一套确保只能本人验证的方法。...但是有一个问题,因为我们总是签名相同的消息,任何一个签名都是账户的永久密钥,永不过期。...这意味着,如果有人通过 MITM 攻击或欺骗我们在别的网站签署相同的消息来拦截它,他们将获得不可撤销的永久访问权限。 为了防止这样的事情发生,我们需要确保每次的消息都不同。

    2.7K10

    PHP 加密 .env 文件

    它是敏感信息(如数据库凭据、API 密钥和其他对应用程序功能和安全性至关重要的机密)的中心枢纽。然而,以明文形式存储敏感信息,即使是在.env文件中,也会带来巨大的安全风险。...加密是降低这些风险的重要一步,可确保即使发生未经授权的访问,您的敏感数据仍然受到保护。本文探讨了在 PHP 环境中加密.env值的实用方法。步骤 1:生成加密密钥首先,我们需要一个强大的加密密钥。...您可以使用 PHP 的openssl_random_pseudo_bytes函数或 其他 PHP 加密库提供的类似方法生成安全密钥。...因此在 Laravel 中,加密.env文件的方法非常简单:php artisan env:encrypt这将把.env加密为.env.encrypted,并提供一个密钥。...您可以使用下面的命令解密该文件:php artisan env:decrypt --key=your-key-here

    49600

    Mysql数据库学习(四):常用Mysql C API 介绍和使用、封装一个访问Mysql数据库的类MysqlDB

    首先,环境是windows +  vs2008,Mysql数据库已经安装好,在使用之前,需要配置工程属性,附加包含目录添加 D:\Program Files\MySQL\MySQL Server 5.6...一、常用Mysql C API 介绍和使用 1.mysql_init MYSQL结构代表一个连接句柄 MYSQL*mysql_init(MYSQL*mysql); 如果mysql是NULL指针,该函数将分配...mysql_free_result 示例代码如下: #include  #include  #include  int main(void) {     //初始化一个连接句柄...二、下面封装MysqlDB类 使用的基本是上面演示过的函数,就不多解释了,直接看代码吧。...long long MysqlDB::GetInsertId() const {     return mysql_insert_id(mysql_);  //auto_increment字段 } 具体使用方法就很简单了

    2.9K20

    Laravel 开发 RESTful API 的一些心得

    最近用 Laravel 写了一段时间的 API,总结一下自己的心得吧。 Start API开发我们可以看到,有些网站用token验证身份,有些用OAuth2.0,当时我也纠结,然后看到一个不错的说法。.../courses/laravel-specification/502/router) 表单验证 可以使用控制器自带的表单验证,更推荐使用表单类(https://laravel-china.org/docs...在有不确定是否输出关联数据时,这是一个很有用的功能!!! 响应输出 当时在 laravel-china 看到的这个帖子,然后觉得这个方式不错,所以自己也这样子,使用基类的方法统一响应输出。...访问 index.html可以查看文档。 在 edit.html写好之后,导出 json,然后粘贴到 api.json文件。 ?...记得也把写好的格式保存到 api.yaml,因为清楚缓存之后,下次访问时会消失 自己写了一个packages 就方便创建控制器,验证,所有控制器继承重写过的基类,响应输出方便。

    4.5K90

    全局梳理、分析、总结 laravel 的核心概念

    有时候一个响应多个 Http 请求,这时候使用 match 方法,也可以使用any 方法,any 方法可以实现响应所有 HTTP 请求的路由。...访问控制(节流) Laravel 包含了一个 middleware 用于控制应用程序对路由的访问。如果想要使用, 请将 throttle 中间件分配给一个路由或者一个路由组。...例如,让我们指定一个经过身份验证并且用户每分钟访问频率不超过 60 次的路由组: Route::middleware('auth:api', 'throttle:60,1')->group(function...要使用路由缓存,你需要将代码从闭包转移到控制器类中) 如果您的应用程序只使用了基于控制器的路由,那么您应该利用 Laravel 的路由缓存。路由缓存会大大减少注册所有路由所需的时间。...绑定基础 绑定一个单例可以在 App\Providers\AppServiceProvider 中的 register 方法中注册。singleton 方法将类或接口绑定到只解析一次的容器中。

    7.2K41

    Python 恶意软件 AndroxGh0st 开始窃取 AWS 密钥

    Laravel 是一个常用的开源 PHP 框架,.env 文件通常包括 AWS、SendGrid 和 Twilio 在内的各种配置信息。...特别是对于 AWS,该恶意软件能够扫描并解析 AWS 密钥,也支持暴力破解密钥。 研究人员最近发现了该恶意软件的多个变种。其中一个与硬编码的用户名 ses_xcatze 有关。...(AWS 密钥生成) AndroxGh0st 有两个最主要的功能,最常见的是检查环境是否支持发送垃圾邮件。AndroxGh0st 通过调用 GetSendQuota 来实现这一点,但并没有后续操作。...尽管如此,尚不清楚 Python 恶意软件是否也可以归因于 Xcatze。...如何检测 为了识别与 AndroxGhost 功能相似的恶意软件,可以查找以下 API 的异常 调用: GetSendQuota CreateUser CreateLoginProfile

    1.8K20

    Laravel 开发 RESTful API 的一些心得

    最近用 Laravel 写了一段时间的 API,总结一下自己的心得吧。 Start API开发我们可以看到,有些网站用token验证身份,有些用OAuth2.0,当时我也纠结,然后看到一个不错的说法。...// more }); 如果前端想跨域,请使用这个很方便的包barryvdh/laravel-cors 一个简单的接口示例 接口代码 验证 API 开发总会离不开验证,这里推荐使用jwt-auth...接口代码 能分离的代码都不要吝啬~~~ 数据转换 Laravel自带的API Resource 用起来真的很方便,不过发现一个问题,--collection的格式总是转不过来,后来直接放弃了 单个的使用...在有不确定是否输出关联数据时,这是一个很有用的功能!!! 响应输出 当时在 laravel-china 看到的这个帖子,然后觉得这个方式不错,所以自己也这样子,使用基类的方法统一响应输出。...要修改图中箭头所示成为api.json的位置 swagger 访问edit.html可以书写文档 编写语法 访问index.html可以查看文档 在edit.html写好之后,导出json

    99710

    JSON Web Token(JWT)教程:一个基于Laravel和AngularJS的例子

    当然,如果我们想避免使用JWE的额外开销,另一个选择是将敏感信息保留在我们的数据库中,并且在需要访问敏感数据时,使用我们的token进行额外的API调用。 为什么需要Web Tokens?...安装Composer依赖 幸运的是,有一个Laravel开发者的社区,并拥有许多优秀的软件包,可以供我们重用和扩展我们的应用程序。...我们可以使用php artisan jwt:generate命令生成该密钥。它将被放置在我们的config/jwt.php文件中。然而,在生产环境中,我们不想在配置文件中使用我们的密码或API密钥。.../signin发出码POST请求,我们验证该用户是否存在,并通过JSON响应返回一个JWT。...如果token无效,不存在或过期,则中间件将抛出一个可以捕获的异常。 在Laravel 5中,我们可以使用app/Exceptions/Handler.php文件捕获异常。

    33.6K10

    基于 Redis 实现简单限流器及其在路由中间件中的应用

    在 Laravel 应用中,路由的访问频率限制功能底层使用的就是通过这种机制实现的限流器。...限流中间件在 Laravel 中的使用 我们知道,在 Laravel 项目中,可以通过 RateLimiter 门面的 for 方法来定义限流逻辑比将其应用到路由中(详见路由文档),也可以直接在 Laravel.../ 路由 10 次,超过限流上限,则返回 429 响应: 对于 Laravel 的 API 路由,默认使用了这个限流中间件(下面这段代码位于 app/Http/Kernel.php): protected...回到 ThrottleRequests 的 handleRequest 方法,我们可以通过 RateLimiter 的 tooManyAttempts 方法判断当前请求是否已经触发限流器的访问上限,初次访问返回值是...接下来,又是一个 $this->cache->add 调用,这不是 Laravel 底层代码的 bug 哈,而是用于统计当前用户访问次数的另一个键值对,键名和 ThrottleRequests 中间件对象设置的键名一致

    3.4K30

    Laravel 中使用 DingoAPI

    ,所有用户可以访问 API_SUBTYPE :项目的简称,或者项目名称 API_VERSION : 版本号 API_PREFIX 和 API_DOMAIN : 前缀和子域名, 前缀或子域名是必须的...,并且同时只有一个 API_NAME : API的名字只有在使用API Blueprint命令生成文档的时候才用到,这个名字作为默认名字以免生成文档时需要手动指定名字。...API_STRICT : 严格解析,值为 true 或 false,默认为 false ,开启严格解析,意味着你不可以使用浏览器来进行访问。...来进行测试 推荐使用 POSTMAN 调试工具, 网址中输入地址 http://laravel-api.test/api/test ,不出意外 应该会输出 hello world 字样 另外一种很常见的访问方式是通过...访问方法和上面一样。 ok,以上就是 laravel 中初步安装 DingoApi ,并且配置的基础教程,更多使用请阅读 官方文档

    2.6K10

    个人开发者使用laravel6通过payjs接入微信支付

    由于我们只能借用第三方平台来实现,虽然多了些手续费,也是可接受的 我选择接入的第三方支付平台是 payJs,以下是关于如何在 laravel6 中接入 payJs 的完整 demo 环境准备 先按以下文章创建一个...laravel6 应用 使用 laravel6 创建应用 laravel6 初始化前端以及引入字体图标 然后,进入 payJs,注册成为会员,提交相关资料,当天就能审核通过 接着下载 payJs 官方扩展包...获取商户号 在 .env 配置商户号 PAYJS_MCHID=商户号 PAYJS_KEY=密钥 将 config/payjs.php 修改为: return [ 'mchid' => env('...PAYJS_MCHID'), 'key' => env('PAYJS_KEY'), // 此地址一般无需更改 'api_url' => 'https://payjs.cn/...是', ]; protected $fillable = ['trade_no', 'is_paid', 'amount', 'subject']; /** * 是否已付款

    2.4K10

    【说站】健身类小程序前后端源码

    参考 Laravel 安装步骤就可以了 小程序源码是 weapp 目录,用 HBuilder 打开,填写自己小程序的 appid 配置好域名即可 推荐使用宝塔安装,比较省事,还有 PHP 相关的扩展需要启用...,有些函数也需要启用(laravel 需要用到一些函数)。.../ 改为你的域名(稍后将说明如何下载配置后端代码),假设你部署后端的域名是 www.abc.com, 那么这里填写 http://www.abc.com/api/ 后端源码,后端基于 laravel...5.8,源码在健身小程序源码压缩包里的api.zip 部署环境 建议使用宝塔面板,配置好 php7.2 + mysql5 ,建立一个站点,然后将解压后的源码上传到该目录下 宝塔面板->网站->本站...那么后台管理地址是 http://www.abc.com/sidong, 用户名 admin 密码 123456 进入后台,首先到 系统设置->商户管理->驷动健身->编辑,配置 小程序id、商户id、密钥等相关信息

    1.5K20

    PHP-web框架Laravel-中间件(一)

    在Laravel中,中间件是处理HTTP请求的一种机制。它可以用来检查请求是否满足某些条件,比如是否已经进行了身份验证或者是否有足够的权限来访问某个资源。...中间件通常用于控制应用程序的访问权限,或者进行一些基于请求的操作,比如日志记录或性能分析。中间件的基本使用在Laravel中,中间件可以通过路由或控制器来指定。...这意味着只有经过身份验证的用户才能访问该路由。中间件类Laravel中的中间件实际上是PHP类。在创建中间件时,可以选择手动创建类,也可以使用Laravel提供的中间件生成器来自动生成。...api中间件组包含一组用于API的中间件,如速率限制和API身份验证。在路由中使用中间件。可以在路由定义中使用中间件。...当访问该路由时,中间件将检查请求中的年龄,并根据需要重定向请求或继续执行下一个操作。

    4.1K31

    Laravel Sanctum API 授权

    简单来说,前后端分离的项目,使用 token 验证登陆状态,可以选它;另外,同类型的还有 jwt 比较火 安装 Laravel 9 已经包含了 Laravel Sanctum,所以下面的步骤看看就行了...这一行,Laravel 9默认是注释掉的,需要取消注释 API 令牌认证 发布 API Tokens 要开始为用户颁发令牌,你的 User 模型应使用 Laravel\Sanctum\HasApiTokens...在存入数据库之前,API 令牌已使用 SHA-256 哈希加密过,但你可以使用 NewAccessToken 实例的 plainTextToken 属性访问令牌的纯文本值。...; 在处理由 Sanctum 验证的传入请求时,你可以使用 tokenCan 方法确定令牌是否具有给定的能力: if ($user->tokenCan('server:update')) { /...有个好消息,sanctum 提供了一个 Artisan 命令,可以实现这个想法: php artisan sanctum:prune-expired 比如,您可以设置一个调度任务用于删除你数据库中所有过期超过

    3.7K30

    Laravel Api实现JWT Token认证

    在开发Api时,处理客户端请求之前,需要对用户进行身份认证,Laravel框架默认为我们提供了一套用户认证体系,在进行web开发时,几乎不用添加修改任何代码,可直接使用,但在进行api开发时,需要我们自己去实现...,并且Laravel框架默认提供的身份认证不是jwt的,需要在数据库中增加api_token字段,记录用户认证token并进行身份校验,如果需要使用jwt,无需添加字段,需要借助三方库来实现。...,服务器就认为该请求是一个合法的请求 JWT概述 token 只是一种思路,一种解决用户授权问题的思考方式,基于这种思路,针对不同的场景可以有很多种的实现。...比如,传统的做法中,服务器会保存生成的 token, 当客户端发送来 token 时,与服务器的进行比对,但是 jwt 的不需要在服务器保存任何 token, 而是使用一套加密 / 解密算法 和 一个密钥...而 jwt 的存在,只要每一台服务器都知道解密密钥,那么每一台服务器都可以拥有验证用户身份的能力. 这样一来,服务器就不再保存任何用户授权的信息了,也就解决了 session 曾出现的问题.

    1.2K20
    领券