java一次请求变成两次请求_浏览器发送了两次请求给服务器,服务器只返回后一次请求的内容...

浏览器调用同一个接口,发送了两次请求给服务器端,服务器端代码返回一个随机数给浏览器

框架是SpringMvc+Spring+MyBatis

服务器端代码如下:

@RequestMapping(value = "/test")

@ResponseBody

public Result test(){

result.setSuccess(true);

result.setData(new Random().nextDouble() + System.currentTimeMillis());

return result;

}

chorme的network截图如下,发现两次请求返回的内容是同一个

请求一

7632b8aaf56e2f7489ef1fdb1bdad8f3.png

请求二

2052f318faceb5ce953fe710a53ae6a2.png

有以下几个疑问:

经过多次试验,发现请求是都走到Controller里,但是第一次请求的响应数据没有马上返回给浏览器端,而是和第二次请求的响应一起返回给了前端,并且第一次请求的响应内容居然是第二次响应的内容。

有时候两次请求的响应能不相同,有时候却相同,不知道是什么原因。

分割线1

不少朋友说是因为我发的get请求,导致浏览器认为是缓存原因。

我的实际应用场景是,前台上传多个附件,但是本质是多次上传,然后由后台返回此文件在数据库中的文件id。然后我发现有时上传多个文件时,返回的文件id都是同一个。

如下图所示:两个上传的文件长度是不一样的

文件一

557619510f112f136057237935f6b6fa.png

文件二

8b98a6617557d6f86ebd7e5152bd6bed.png

但是服务器返回的文件id却是一样的:

文件一

c1e256aa193b63875b8d6d60a7d69bdf.png

文件二

d25f4bfc87641dab2fc1e3cbc658bf48.png

分割线2

我已经在URL上加了随机数,来区分是不同的请求,服务器的响应码是200,但是服务器返回的内容还是将第二次请求的响应内容覆盖掉了第一次响应内容

文件一

请求消息

7b622666ff1a5a2574c002ecdf73de6b.png

响应消息

35234d16ab1c01b83bfd34a3f1f64e52.png

文件二

请求消息

befa39387e5aa70f58f3acecad9db857.png

响应消息

5fab65bfa7d5ed76a8beb8913e1bbf4b.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据提供的引用内容,可以得知在使用shiro进行跨域请求时,会出现请求两次的问题。这是因为后台采用了token检验机制,前台发送请求必须将token放到request header中,而请求头中携带自定义参数,浏览器就认为请求是复杂跨域请求,所以浏览器在真正请求之前会发送一次预检请求,检测服务器是否支持真实请求进行跨域访问。 解决方案如下: 1.在后台代码中添加如下配置,允许跨域请求: ```java // 允许跨域请求 response.setHeader("Access-Control-Allow-Origin", "*"); response.setHeader("Access-Control-Allow-Methods", "POST, GET, OPTIONS, DELETE"); response.setHeader("Access-Control-Max-Age", "3600"); response.setHeader("Access-Control-Allow-Headers", "x-requested-with,Authorization"); ``` 2.在shiro配置文件中添加如下配置,允许OPTIONS请求通过: ```xml <bean id="shiroFilter" class="org.apache.shiro.spring.web.ShiroFilterFactoryBean"> <property name="securityManager" ref="securityManager"/> <property name="loginUrl" value="/login"/> <property name="successUrl" value="/index"/> <property name="unauthorizedUrl" value="/unauthorized"/> <property name="filters"> <util:map> <entry key="authc"> <bean class="org.apache.shiro.web.filter.authc.PassThruAuthenticationFilter"/> </entry> </util:map> </property> <property name="filterChainDefinitions"> <value> /login = anon /logout = logout /** = authc </value> </property> </bean> ``` 3.在前端代码中添加如下配置,允许携带自定义参数: ```javascript axios.defaults.headers.common['Authorization'] = 'Bearer ' + token; axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded'; axios.defaults.withCredentials = true; ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值