nginx设置上传目录无执行权限

在windows+iis下,可以设置上传目录,类似:upload,uploadfile,attachments,这样的目录下面无脚本执行权限,从而防止非法用户上传脚本得到webshell
nginx上也很简单,我们使用location。。如下:

location ~ ^/upload/.*\.(php|php5)$
{
deny all;
}

其中upload换为你要设置的目录名字

这条规则的含义是匹配请求连接中开头是/upload/,中间匹配任意字符,结尾匹配.php或者.php5的页面,最后利用deny all禁止访问,这样就防止了上传目录的脚本执行权限




文章来源:DoDo’s Blog
原文地址:http://www.sectop.com/post/40.html

Nginx本身并不直接提供文件上传功能,它主要是用于作为Web服务器来处理和转发HTTP请求。但是,如果你在Nginx中配置了反向代理或者FastCGI等方式来处理上传请求,存在一些常见的安全风险。 其中一个常见的风险是路径遍历攻击,也称为目录穿越攻击。攻击者可能通过修改上传文件的文件名或者构造特定的请求来绕过服务器端的文件路径限制,使其能够上传到非预期的目录,甚至是系统关键目录,从而导致代码执行、文件覆盖或者敏感文件暴露等安全问题。 为了防止这种漏洞的发生,你可以采取以下几个安全措施: 1. 验证文件类型和后缀名:限制上传文件的类型和后缀名,只允许上传特定的文件类型,并且确保文件类型和后缀名的验证是在服务端进行的。不要依赖客户端的验证,因为客户端验证可以被绕过。 2. 限制上传文件大小:限制上传文件的大小,防止上传过大的文件导致服务器资源耗尽。可以通过Nginx配置或后端应用程序来实现。 3. 随机化上传文件保存路径:为每个上传的文件生成一个随机的保存路径,避免使用原始文件名或者可预测的路径,从而增加攻击者猜测路径的难度。 4. 设置适当的文件权限:确保上传的文件保存路径具有适当的文件权限,限制其他用户对上传的文件的访问权限。 5. 对上传文件进行病毒扫描:可以将上传的文件进行病毒扫描,确保上传的文件不包含恶意代码。 请注意,以上只是一些基本的防护措施,具体的安全措施需要根据实际情况和应用程序的需求来进行细化和定制。同时,及时更新Nginx版本和相关组件也是保持服务器安全性的重要措施。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值