lnmp一键安装包中配置swoole域名端口映射

2024-06-09 16:48

本文主要是介绍lnmp一键安装包中配置swoole域名端口映射,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

按照官方文档

    location / {proxy_http_version 1.1;proxy_set_header Connection "keep-alive";proxy_set_header X-Real-IP $remote_addr;if (!-e $request_filename) {proxy_pass http://127.0.0.1:9501;}}

添加无效,主要是一键安装包的vhost配置文件中没有 找到 location / { 

有个折中的办法,就是在 location ~ \.php { 下配置,把 if 判断改成如下或者干脆删除判断语句

if (-e $request_filename) {

这样一来,所有到该域名的请求,不管有没有index.php,都会变成端口映射,但这样总感觉太野蛮了

================================================================

后来在配置文件中发现一句 

include /usr/local/nginx/conf/rewrite/thinkphp.conf;

那就编辑这个文件吧,果然 location / 在这里,暂时先这样修改:

location / {# 如果$uri对应的文件存在,在Nginx返回文件,否则把请求交给Swoole处理try_files $uri @swoole;if (!-e $request_filename) {rewrite ^(.*)$ /index.php?s=$1 last;break;}
}location @swoole {proxy_pass http://127.0.0.1:9501;proxy_http_version 1.1;proxy_set_header Connection "keep-alive";# Swoole通过$req->header['x-real-ip']拿到该参数proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forwarded-For $remote_addr;proxy_set_header Host $host;
}

这样最后达到的效果是,url中有index.php的时候正常访问前台页面,无index.php的时候,会跳转到swoole来处理

但是我并不想让用户直接访问域名就能定位到我的swoole请求页面,反复尝试了好久都达不到效果

================================================================

突然灵光一现,完全可以自己另外定义一个location啊

请求的名字还可以自定义,本例中精确匹配 http

于是所有代码都不用动,只需要在配置文件中添加下边代码即可

  location = /http {allow ip白名单1;allow ip白名单2;deny    all;proxy_http_version 1.1;proxy_set_header Connection "keep-alive";proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forwarded-For $remote_addr;proxy_set_header Host $host;if (!-e $request_filename) {proxy_pass http://127.0.0.1:9501;}}

这样连白名单都有了,可以设置只允许 服务器的反向代理IP 访问swoole_http_server

TODO:如何防止有人绕过前端页面直接请求服务器

================================================================

另外还有一种情况,就是域名后随便输入一段字符,会跳出tp的错误界面

想让它跳转404或者直接返回首页

参考 https://blog.csdn.net/u011486871/article/details/79663127 先实现返回首页

将rewrite规则文件注释,在域名主配置文件中添加:

  location / {try_files $uri $uri/ /index.php;}

这样无论输入什么字符都会跳转首页,而index.php入口文件也不会受影响

该方法有问题,会让rewrite失效,还是使用配置文件默认的rewrite规则

如果想跳转,就在tp中自定义错误页面吧

这篇关于lnmp一键安装包中配置swoole域名端口映射的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1045739

相关文章

Python 安装和配置flask, flask_cors的图文教程

《Python安装和配置flask,flask_cors的图文教程》:本文主要介绍Python安装和配置flask,flask_cors的图文教程,本文通过图文并茂的形式给大家介绍的非常详细,... 目录一.python安装:二,配置环境变量,三:检查Python安装和环境变量,四:安装flask和flas

使用Python实现一键隐藏屏幕并锁定输入

《使用Python实现一键隐藏屏幕并锁定输入》本文主要介绍了使用Python编写一个一键隐藏屏幕并锁定输入的黑科技程序,能够在指定热键触发后立即遮挡屏幕,并禁止一切键盘鼠标输入,这样就再也不用担心自己... 目录1. 概述2. 功能亮点3.代码实现4.使用方法5. 展示效果6. 代码优化与拓展7. 总结1.

SpringCloud动态配置注解@RefreshScope与@Component的深度解析

《SpringCloud动态配置注解@RefreshScope与@Component的深度解析》在现代微服务架构中,动态配置管理是一个关键需求,本文将为大家介绍SpringCloud中相关的注解@Re... 目录引言1. @RefreshScope 的作用与原理1.1 什么是 @RefreshScope1.

SpringBoot日志配置SLF4J和Logback的方法实现

《SpringBoot日志配置SLF4J和Logback的方法实现》日志记录是不可或缺的一部分,本文主要介绍了SpringBoot日志配置SLF4J和Logback的方法实现,文中通过示例代码介绍的非... 目录一、前言二、案例一:初识日志三、案例二:使用Lombok输出日志四、案例三:配置Logback一

springboot security之前后端分离配置方式

《springbootsecurity之前后端分离配置方式》:本文主要介绍springbootsecurity之前后端分离配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的... 目录前言自定义配置认证失败自定义处理登录相关接口匿名访问前置文章总结前言spring boot secu

一文详解SpringBoot响应压缩功能的配置与优化

《一文详解SpringBoot响应压缩功能的配置与优化》SpringBoot的响应压缩功能基于智能协商机制,需同时满足很多条件,本文主要为大家详细介绍了SpringBoot响应压缩功能的配置与优化,需... 目录一、核心工作机制1.1 自动协商触发条件1.2 压缩处理流程二、配置方案详解2.1 基础YAML

springboot简单集成Security配置的教程

《springboot简单集成Security配置的教程》:本文主要介绍springboot简单集成Security配置的教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录集成Security安全框架引入依赖编写配置类WebSecurityConfig(自定义资源权限规则

SpringBoot中封装Cors自动配置方式

《SpringBoot中封装Cors自动配置方式》:本文主要介绍SpringBoot中封装Cors自动配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录SpringBoot封装Cors自动配置背景实现步骤1. 创建 GlobalCorsProperties

Spring Boot结成MyBatis-Plus最全配置指南

《SpringBoot结成MyBatis-Plus最全配置指南》本文主要介绍了SpringBoot结成MyBatis-Plus最全配置指南,包括依赖引入、配置数据源、Mapper扫描、基本CRUD操... 目录前言详细操作一.创建项目并引入相关依赖二.配置数据源信息三.编写相关代码查zsRArly询数据库数

SpringBoot配置Ollama实现本地部署DeepSeek

《SpringBoot配置Ollama实现本地部署DeepSeek》本文主要介绍了在本地环境中使用Ollama配置DeepSeek模型,并在IntelliJIDEA中创建一个Sprin... 目录前言详细步骤一、本地配置DeepSeek二、SpringBoot项目调用本地DeepSeek前言随着人工智能技