问题描述
通过springboot创建出来的项目,在项目里会有将文件存储到后端服务器的动作,文件存储后默认的权限是rw--------- root root 也就是说除了root具有读写的权限,其他所有用户都没有任何权限。现在想要做个文件预览功能,就需要对他进行可读。
问题解决思路
既然问题出现在创建的权限之上,首先想到的就是解决权限问题,将文件的创建权限改成rw-r-r即可。
问题解决过程
1.根据上面问题的解决思路首先去配置了/etc/bash.bashrc文件,在该文件末尾加了umask 0022(这样修改理论上所有用户创建的文件权限都是644,也就是rw-r-r),然后重新加载该文件source /etc/bash.bashrc之后,登录服务器验证权限修改是否生效:在目录下创建了个文件,发现权限确实对了,然后登录系统使用系统进行上传文件,然后发现应用创建出来的文件权限还是没变,仍然是rw
2.此时感觉是有另外一个地方限制了这个权限,网络上搜索一通后发现一种说法tomcat的配置文件catalina.sh会对创建文件进行权限默认值的设定,这里默认设定就是只有rw----。此时感觉发现了问题的关键处,但是springboot的tomcat都是内置的,并没有catalina.sh这个文件。这可怎么整,然后找了一通发现这个并没有办法在springboot中进行设定,这条问题解决线路到这里就断了(若不是内置tomcat这个问题就很好解决,只需要找到catalina.sh中设定的umask值,进行更改成0022即可)。
3.上面没有成功解决问题,就只能更换思路了,默认创建出来的文件权限是rw------- root root ,那root用户是具有读写权限的,我若是将访问文件的用户设置成 root,这个问题解决也是ok的,下面就朝着这个反向进行重新努力。
4.经过一通搜索发现nginx确实支持这个,只需要我们在nginx.conf开头加入一个配置即可user root;这样通过nginx反向代理出来的静态资源,我们访问时默认都是使用root进行访问的,此时访问文件就有了读写的权限。这样问题就解决了。
总结
这个问题一开始其实解决就有两个角度:
更改文件创建时的默认缺陷
更改访问静态资源时的默认用户
笔者一开始只想到了第一种解决思路,一直在第一条路上深入找解决办法,到最后发现走入了死胡同,才转而想到了第二种,其实问题思考的初始阶段就应该建立好问题的整体思路,多方向进行思考,这样就可以在一条路上受阻后,在另外一条路上继续寻找解决方案。