项目总结--http请求被服务器拦截

17 篇文章 0 订阅
3 篇文章 0 订阅

最近做项目遇到这样一种情况,项目中的http请求在公司的网络下是可以的,但是如果用手机的4G网或者在家里的时候,http请求是不同的。起初我还以为是兼容性的问题,但是在手机进行调试的时候发现请求是已经发出去了,但是在后端的服务器日志上是看不到请求信息的。我猜测是中间做了拦截。果然如此。凡是公司还没出售的产品,都做了这样的限制。直接用IP+端口号(存在跨域的问题,不过后端服务器已经放开,origin:*,都可以访问)的方式访问服务器,因为有白名单(这个下面会做详细的说明)的限制,是访问不通的。
IP+端口号访问的流程如下:
在这里插入图片描述
白名单就是后端服务器设置的拦截校验,相当于账户名,一般白名单都是域名或者IP,如果是在白名单里面,就可以访问后端服务器里面的地址,如果不在,就拒绝访问。公司的网关地址都在这个白名单里面,所以连接公司的wifi可以直接访问,其他网关不在白名单里面,所以访问不了。

那如果不在公司,就没法测试这款产品了。这肯定不行呀。怎么解决这个问题呢?
代理,设置代理,设置代理转化我们的请求

如果加上代理的话,流程如下:
在这里插入图片描述
那在项目中是怎么加代理的呢?以vue为例子,
在webpack.config.js文件中的devServer这一项里面进行配置
这里我就不细说了。

我们项目中的是这样配置代理,直接代理到后端服务器上,不过是通过域名进行访问的。

'/ja_mu_poliy': {
    target: 'http://muadmin-dat.aitech.ltd/',
    changeOrigin: true
  },

通过域名直接访问后端服务器上,这个时候后端服务器会有默认的端口放开,例如8080,这个时候可以访问后端服务器上的8080端口,然后后端服务器的nginx上又做了一个代理转化,转化到10030这个端口号上,因为直接访问后端服务器上的10030端口号是需要白名单的,但是访问后端服务器上的8080这个放开的端口号是可以的,这样利用8080端口号进行处理,把请求转发到自身的10030端口上,这样就不需要白名单校验了,因为是服务器自己本地在做的这样的操作,不是从外部直接访问的这个端口号。 这样代理就完成了。

这个流程如下:

在这里插入图片描述

这样就请求到10030端口上了,然后响应的数据按原路返回。

目前公司的代理流程就是这酱紫的。
总结一下这个流程,以后出了问题,就能直接定位到问题所在了。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在vue-element-admin中,可以使用axios进行转发设置。axios是一个基于Promise的HTTP客户端,用于浏览器和Node.js。它可以将请求发送到后端服务器并接收响应数据。 要设置axios的转发,你可以按照以下步骤进行操作: 1. 打开项目目录下的`src/utils/request.js`文件。这是封装了axios的请求方法的文件。 2. 在该文件中找到`createRequest`函数,在函数体内找到`service`对象。 3. `service`对象是一个axios实例,你可以通过该实例来设置转发。例如,可以使用`service.interceptors.request.use()`方法来添加请求拦截器,使用`service.interceptors.response.use()`方法来添加响应拦截器。 4. 在请求拦截器中,你可以对请求进行一些处理,例如添加请求头、设置token等。 5. 在响应拦截器中,你可以对响应进行一些处理,例如对错误进行统一处理、对返回数据进行格式化等。 6. 另外,你还可以在`src/api`文件夹中的每个API接口文件中,根据需要使用axios进行转发设置。 总结起来,要在vue-element-admin项目中设置axios的转发,你需要找到`src/utils/request.js`文件,并根据需要使用`service.interceptors.request.use()`和`service.interceptors.response.use()`方法进行拦截器的设置。这样可以对请求和响应进行统一处理和转发。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [vue-element-admin:vue-element-admin](https://download.csdn.net/download/weixin_42168745/16228234)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [vue-element-admin-template](https://download.csdn.net/download/weixin_42142062/15991791)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [浏览器显示数据库中数据的条形图柱状图 前后端分离vue.js+spring boot 计算机软件工程课程设计毕业设计 ...](https://download.csdn.net/download/Amzmks/88275824)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值