gogogo
管理员
管理员
  • UID25
  • 粉丝0
  • 关注0
  • 发帖数1377
阅读:2763回复:3

若依 / RuoYi-Vue 部署后 运行访问 提示{"msg":"请求访问:/,认证失败,无法访问系统资源","code":401}

楼主#
更多 发布于:2022-07-15 11:13

部署后 运行访问 提示{"msg":"请求访问:/,认证失败,无法访问系统资源","code":401}


{"msg":"请求访问:/,认证失败,无法访问系统资源","code":401}


部署后
运行访问 提示{"msg":"请求访问:/,认证失败,无法访问系统资源","code":401}


验证码是
http://localhost:8080/captchaImage 请求/失败

提示{"msg":"请求访问:/,认证失败,无法访问系统资源","code":401}

gogogo
管理员
管理员
  • UID25
  • 粉丝0
  • 关注0
  • 发帖数1377
沙发#
发布于:2022-07-15 11:15
Nginx 的配置文件 proxy_pass http://localhost:8080/; 一行,分号前面要以 / 结尾,切记切记!
这是最终解决办法.







有可能是验证码权限和路径问题综合导致的,解决方案:SecurityConfig.java 中 configure方法某行修改为:
.antMatchers("/login", "/**/captchaImage").anonymous(),
CaptchaController.java 中 getCode 的方法注解修改为:@GetMapping("**/captchaImage")
Nginx 的配置文件 proxy_pass http://localhost:8080/; 一行,分号前面要以 / 结尾,切记切记!


5
gogogo
管理员
管理员
  • UID25
  • 粉丝0
  • 关注0
  • 发帖数1377
板凳#
发布于:2022-07-15 12:29
NGINX服务器的反向代理PROXY_PASS配置方法讲解

Nginx的配置还是比较简单的,如:

location ~ /*
{
proxy_pass http://127.0.0.1:8080;
}

或者可以

location /
{
proxy_pass http://127.0.0.1:8080;
}

Apache2的反向代理的配置是:
ProxyPass /ysz/ http://localhost:8080/

然而,如果要配置一个相对复杂的反向代理 Nginx相对Apache2就要麻烦一些了 比如,将url中以/wap/开头的请求转发到后台对应的某台server上 可以再Nginx里设置一个变量,来临时保存/wap/后面的路径信息


location ^~ /wap/
{
if ($request_uri ~ /wap/(\d+)/(.+))
{
set $bucketid $1;
set $params $2;
}
proxy_pass http://mx$bucketid.test.com:6601/$params;
}



也可以首先rewrite一下,然后再代理:
location ^~ /wap/{
rewrite /wap/(\d+)/(.+) /$2?$args break;
proxy_pass http://mx$1.test.com:6601;
}



location ~* /wap/(\d+)/(.+)
{
proxy_pass http://mx$1.test.com:6601/$2?$args;
}


注意上面最后的?$args,表明把原始url最后的get参数也给代理到后台
如果在proxy_pass中使用了变量(不管是主机名变量$1或后面的$2变量),则必须得加这段代码
但如果pass_proxy后没用任何变量,则不需要加,它默认会把所有的url都给代理到后台,如:




location ~* /wap/(\d+)/(.+)
{
proxy_pass http://mx.test.com:6601;
}


而Apache2相对就简单多了:

ProxyPassMatch ^/wap/(.*)$ http://192.168.132.147/$1
 
if ($host ~* www.(.*)){
     set $host_without_www $1;
     rewrite (.*)$ http://$host_without_www/www$1;
   }


url的/问题
在nginx中配置proxy_pass时,当在后面的url加上了/,相当于是绝对根路径,则nginx不会把location中匹配的路径部分代理走;如果没有/,则会把匹配的路径部分也给代理走。



下面四种情况分别用http://192.168.1.4/proxy/test.html 进行访问。
第一种:

location /proxy/ {
    proxy_pass http://127.0.0.1:81/;
}
会被代理到http://127.0.0.1:81/test.html 这个url


第二咱(相对于第一种,最后少一个 /)



location /proxy/ {

     proxy_pass http://127.0.0.1:81;}


会被代理到http://127.0.0.1:81/proxy/test.html 这个url


第三种:

location /proxy/ {
     proxy_pass http://127.0.0.1:81/ftlynx/;
}
会被代理到http://127.0.0.1:81/ftlynx/test.html 这个url。


第四种情况(相对于第三种,最后少一个 / ):

location /proxy/ {     proxy_pass http://127.0.0.1:81/ftlynx;
}会被代理到http://127.0.0.1:81/ftlynxtest.html 这个url

上面的结果都是本人结合日志文件测试过的。从结果可以看出,应该说分为两种情况才正确。即http://127.0.0.1:81 (上面的第二种) 这种和 http://127.0.0.1:81/.... (上面的第1,3,4种) 这种。


https://www.cnblogs.com/lianxuan1768/p/8383804.html
gogogo
管理员
管理员
  • UID25
  • 粉丝0
  • 关注0
  • 发帖数1377
地板#
发布于:2022-07-15 14:45
nginx命令
配置完成后重新启动nginx

nginx -t # 查看nginx状态

nginx -s reload # 重新载入配置文件

nginx -s reopen # 重启 Nginx

nginx -s stop # 停止 Nginx
游客


返回顶部